Skip to content

Commit

Permalink
Set rect event processing fixed.
Browse files Browse the repository at this point in the history
  • Loading branch information
darina committed Jul 7, 2016
1 parent c21f80c commit 67fafc6
Show file tree
Hide file tree
Showing 5 changed files with 18 additions and 85 deletions.
44 changes: 7 additions & 37 deletions drape_frontend/navigator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -26,30 +26,17 @@ Navigator::Navigator()
{
}

void Navigator::SetFromRect2(m2::AnyRectD const & r)
void Navigator::SetFromScreen(ScreenBase const & screen)
{
ScreenBase tmp = m_Screen;

m2::RectD const & worldR = df::GetWorldRect();

tmp.SetFromRect2d(r);
tmp = ScaleInto(tmp, worldR);

m_Screen = tmp;

if (!m_InAction)
m_StartScreen = tmp;
VisualParams const & p = VisualParams::Instance();
SetFromScreen(screen, p.GetTileSize(), p.GetVisualScale());
}

void Navigator::SetScreen(ScreenBase const & screen)
void Navigator::SetFromScreen(ScreenBase const & screen, uint32_t tileSize, double visualScale)
{
m2::RectD const & worldR = df::GetWorldRect();
ScreenBase tmp = screen;
tmp = ScaleInto(tmp, worldR);
ScreenBase tmp = ScaleInto(screen, df::GetWorldRect());

VisualParams const & p = VisualParams::Instance();

if (!CheckMaxScale(tmp, p.GetTileSize(), p.GetVisualScale()))
if (!CheckMaxScale(tmp, tileSize, visualScale))
{
int const scale = scales::GetUpperStyleScale() - 1;
m2::RectD newRect = df::GetRectForDrawScale(scale, screen.GetOrg());
Expand All @@ -75,26 +62,9 @@ void Navigator::SetFromRect(m2::AnyRectD const & r)

void Navigator::SetFromRect(m2::AnyRectD const & r, uint32_t tileSize, double visualScale)
{
m2::RectD const & worldR = df::GetWorldRect();

ScreenBase tmp = m_Screen;

tmp.SetFromRect(r);
tmp = ScaleInto(tmp, worldR);
if (!CheckMaxScale(tmp, tileSize, visualScale))
{
int const scale = scales::GetUpperStyleScale() - 1;
m2::RectD newRect = df::GetRectForDrawScale(scale, r.Center());
newRect.Scale(m_Screen.GetScale3d());
CheckMinMaxVisibleScale(newRect, scale, m_Screen.GetScale3d());
tmp = m_Screen;
tmp.SetFromRect(m2::AnyRectD(newRect));
ASSERT(CheckMaxScale(tmp, tileSize, visualScale), ());
}
m_Screen = tmp;

if (!m_InAction)
m_StartScreen = tmp;
SetFromScreen(tmp, tileSize, visualScale);
}

void Navigator::CenterViewport(m2::PointD const & p)
Expand Down
6 changes: 3 additions & 3 deletions drape_frontend/navigator.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -18,11 +18,11 @@ class Navigator
public:
Navigator();

void SetScreen(ScreenBase const & screen);
void SetFromRect(m2::AnyRectD const & r);
void SetFromRect2(m2::AnyRectD const & r);
void CenterViewport(m2::PointD const & p);
void SetFromRect(m2::AnyRectD const & r, uint32_t tileSize, double visualScale);
void SetFromScreen(ScreenBase const & screen);
void SetFromScreen(ScreenBase const & screen, uint32_t tileSize, double visualScale);
void CenterViewport(m2::PointD const & p);

void OnSize(int w, int h);

Expand Down
46 changes: 8 additions & 38 deletions drape_frontend/user_event_stream.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -287,7 +287,7 @@ void UserEventStream::ApplyAnimations()
{
ScreenBase screen;
if (m_animationSystem.GetScreen(GetCurrentScreen(), screen))
m_navigator.SetScreen(screen);
m_navigator.SetFromScreen(screen);

Animation::SwitchPerspectiveParams switchPerspective;
if (m_animationSystem.SwitchPerspective(switchPerspective))
Expand Down Expand Up @@ -366,9 +366,7 @@ bool UserEventStream::SetScale(m2::PointD const & pxScaleCenter, double factor,

bool UserEventStream::SetCenter(m2::PointD const & center, int zoom, bool isAnim)
{
ScreenBase const & currentScreen = GetCurrentScreen();

ScreenBase screen = currentScreen;
ScreenBase screen = GetCurrentScreen();
if (zoom == kDoNotChangeZoom)
{
GetTargetScreen(screen);
Expand Down Expand Up @@ -427,45 +425,17 @@ bool UserEventStream::SetScreen(ScreenBase const & endScreen, bool isAnim)
}

ResetMapPlaneAnimations();
m_navigator.SetScreen(endScreen);
m_navigator.SetFromScreen(endScreen);
return true;
}

bool UserEventStream::SetRect(m2::AnyRectD const & rect, bool isAnim)
{
//isAnim = false;
if (isAnim)
{
auto onStartHandler = [this](ref_ptr<Animation> animation)
{
if (m_listener)
m_listener->OnAnimationStarted(animation);
};

m2::AnyRectD const startRect = GetCurrentRect();
ScreenBase const & screen = GetCurrentScreen();

drape_ptr<Animation> anim = GetSetRectAnimation(screen, startRect, rect);
if (!df::IsAnimationAllowed(anim->GetDuration(), screen))
{
anim.reset();
double const moveDuration = PositionInterpolator::GetMoveDuration(startRect.GlobalCenter(),
rect.GlobalCenter(), screen);
if (moveDuration > kMaxAnimationTimeSec)
anim = GetPrettyMoveAnimation(screen, startRect, rect);
}

if (anim != nullptr)
{
anim->SetOnStartAction(onStartHandler);
m_animationSystem.CombineAnimation(move(anim));
return false;
}
}
ScreenBase tmp = GetCurrentScreen();
tmp.SetFromRects(rect, tmp.PixelRectIn3d());
tmp.MatchGandP3d(rect.GlobalCenter(), tmp.PixelRectIn3d().Center());

ResetMapPlaneAnimations();
m_navigator.SetFromRect2(rect);
return true;
return SetScreen(tmp, isAnim);
}

bool UserEventStream::InterruptFollowAnimations(bool force)
Expand Down Expand Up @@ -551,7 +521,7 @@ bool UserEventStream::SetFollowAndRotate(m2::PointD const & userPos, m2::PointD
}

ResetMapPlaneAnimations();
m_navigator.SetScreen(screen);
m_navigator.SetFromScreen(screen);
return true;
}

Expand Down
6 changes: 0 additions & 6 deletions geometry/screenbase.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -143,12 +143,6 @@ void ScreenBase::SetFromRect(m2::AnyRectD const & glbRect)
SetFromRects(glbRect, m_PixelRect);
}

void ScreenBase::SetFromRect2d(m2::AnyRectD const & glbRect)
{
SetFromRects(glbRect, PixelRectIn3d());
MatchGandP3d(glbRect.GlobalCenter(), PixelRectIn3d().Center());
}

void ScreenBase::SetFromParams(m2::PointD const & org, double angle, double scale)
{
m_Scale = scale;
Expand Down
1 change: 0 additions & 1 deletion geometry/screenbase.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,6 @@ class ScreenBase
m2::PointD const & org, double scale, double angle);

void SetFromRect(m2::AnyRectD const & rect);
void SetFromRect2d(m2::AnyRectD const & glbRect);

void SetFromParams(m2::PointD const & org, double angle, double scale);
void SetFromRects(m2::AnyRectD const & glbRect, m2::RectD const & pxRect);
Expand Down

0 comments on commit 67fafc6

Please sign in to comment.