mirror of
https://github.com/cookiengineer/audacity
synced 2025-10-24 15:23:52 +02:00
Reimplement the narrowed hot zone for vertical ruler...
... Don't define the TrackPanelCell to be narrower. Instead, change its hit-test routine, and only if it is a Wave track. Previous implementation had the unintended consequence, that a click in the area excluded from vertical zooming was treated as a click on the background outside of all tracks, causing de-selection of all tracks.
This commit is contained in:
@@ -3545,10 +3545,9 @@ void TrackPanelCellIterator::UpdateRect()
|
||||
}
|
||||
case CellType::VRuler:
|
||||
{
|
||||
const int kGuard = 5; // 5 pixels to reduce risk of VZooming accidentally
|
||||
mRect.x = kTrackInfoWidth;
|
||||
// Right edge of the VRuler is inactive.
|
||||
mRect.width = mPanel->GetLeftOffset() - mRect.x -kGuard;
|
||||
mRect.width = mPanel->GetLeftOffset() - mRect.x;
|
||||
mRect.y += kTopMargin;
|
||||
mRect.height -= (kBottomMargin + kTopMargin);
|
||||
}
|
||||
|
@@ -31,12 +31,16 @@ std::vector<UIHandlePtr> WaveTrackVRulerControls::HitTest
|
||||
const AudacityProject *pProject)
|
||||
{
|
||||
std::vector<UIHandlePtr> results;
|
||||
auto pTrack = Track::Pointer<WaveTrack>( FindTrack().get() );
|
||||
if (pTrack) {
|
||||
auto result = std::make_shared<WaveTrackVZoomHandle>(
|
||||
pTrack, st.rect, st.state.m_y );
|
||||
result = AssignUIHandlePtr(mVZoomHandle, result);
|
||||
results.push_back(result);
|
||||
|
||||
const int kGuard = 5; // 5 pixels to reduce risk of VZooming accidentally
|
||||
if ( st.state.GetX() <= st.rect.GetRight() - kGuard ) {
|
||||
auto pTrack = Track::Pointer<WaveTrack>( FindTrack().get() );
|
||||
if (pTrack) {
|
||||
auto result = std::make_shared<WaveTrackVZoomHandle>(
|
||||
pTrack, st.rect, st.state.m_y );
|
||||
result = AssignUIHandlePtr(mVZoomHandle, result);
|
||||
results.push_back(result);
|
||||
}
|
||||
}
|
||||
|
||||
auto more = TrackVRulerControls::HitTest(st, pProject);
|
||||
|
Reference in New Issue
Block a user