| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 | 
							- /*
 
-  * MapViewActions.cpp, part of VCMI engine
 
-  *
 
-  * Authors: listed in file AUTHORS in main folder
 
-  *
 
-  * License: GNU General Public License v2.0 or later
 
-  * Full text of license available in license.txt file, in main folder
 
-  *
 
-  */
 
- #include "StdInc.h"
 
- #include "MapViewActions.h"
 
- #include "IMapRendererContext.h"
 
- #include "MapView.h"
 
- #include "MapViewModel.h"
 
- #include "../CGameInfo.h"
 
- #include "../adventureMap/AdventureMapInterface.h"
 
- #include "../gui/CGuiHandler.h"
 
- #include "../gui/CursorHandler.h"
 
- #include "../../lib/CConfigHandler.h"
 
- MapViewActions::MapViewActions(MapView & owner, const std::shared_ptr<MapViewModel> & model)
 
- 	: model(model)
 
- 	, owner(owner)
 
- 	, isSwiping(false)
 
- {
 
- 	pos.w = model->getPixelsVisibleDimensions().x;
 
- 	pos.h = model->getPixelsVisibleDimensions().y;
 
- 	addUsedEvents(LCLICK | RCLICK | MCLICK | HOVER | MOVE);
 
- }
 
- bool MapViewActions::swipeEnabled() const
 
- {
 
- #if defined(VCMI_ANDROID) || defined(VCMI_IOS)
 
- 	return settings["general"]["swipe"].Bool();
 
- #else
 
- 	return settings["general"]["swipeDesktop"].Bool();
 
- #endif
 
- }
 
- void MapViewActions::setContext(const std::shared_ptr<IMapRendererContext> & context)
 
- {
 
- 	this->context = context;
 
- }
 
- void MapViewActions::clickLeft(tribool down, bool previousState)
 
- {
 
- 	if(indeterminate(down))
 
- 		return;
 
- 	if(swipeEnabled())
 
- 	{
 
- 		if(handleSwipeStateChange(static_cast<bool>(down)))
 
- 		{
 
- 			return; // if swipe is enabled, we don't process "down" events and wait for "up" (to make sure this wasn't a swiping gesture)
 
- 		}
 
- 	}
 
- 	else
 
- 	{
 
- 		if(down == false)
 
- 			return;
 
- 	}
 
- 	int3 tile = model->getTileAtPoint(GH.getCursorPosition() - pos.topLeft());
 
- 	if(context->isInMap(tile))
 
- 		adventureInt->onTileLeftClicked(tile);
 
- }
 
- void MapViewActions::clickRight(tribool down, bool previousState)
 
- {
 
- 	if(isSwiping)
 
- 		return;
 
- 	int3 tile = model->getTileAtPoint(GH.getCursorPosition() - pos.topLeft());
 
- 	if(down && context->isInMap(tile))
 
- 		adventureInt->onTileRightClicked(tile);
 
- }
 
- void MapViewActions::clickMiddle(tribool down, bool previousState)
 
- {
 
- 	handleSwipeStateChange(static_cast<bool>(down));
 
- }
 
- void MapViewActions::mouseMoved(const Point & cursorPosition)
 
- {
 
- 	handleHover(cursorPosition);
 
- 	handleSwipeMove(cursorPosition);
 
- }
 
- void MapViewActions::handleSwipeMove(const Point & cursorPosition)
 
- {
 
- 	// unless swipe is enabled, swipe move only works with middle mouse button
 
- 	if(!swipeEnabled() && !GH.isMouseButtonPressed(MouseButton::MIDDLE))
 
- 		return;
 
- 	// on mobile platforms with enabled swipe any button is enough
 
- 	if(swipeEnabled() && (!GH.isMouseButtonPressed() || GH.multifinger))
 
- 		return;
 
- 	if(!isSwiping)
 
- 	{
 
- 		static constexpr int touchSwipeSlop = 16;
 
- 		Point distance = (cursorPosition - swipeInitialRealPos);
 
- 		// try to distinguish if this touch was meant to be a swipe or just fat-fingering press
 
- 		if(std::abs(distance.x) + std::abs(distance.y) > touchSwipeSlop)
 
- 			isSwiping = true;
 
- 	}
 
- 	if(isSwiping)
 
- 	{
 
- 		Point swipeTargetPosition = swipeInitialViewPos + swipeInitialRealPos - cursorPosition;
 
- 		owner.onMapSwiped(swipeTargetPosition);
 
- 	}
 
- }
 
- bool MapViewActions::handleSwipeStateChange(bool btnPressed)
 
- {
 
- 	if(btnPressed)
 
- 	{
 
- 		swipeInitialRealPos = GH.getCursorPosition();
 
- 		swipeInitialViewPos = model->getMapViewCenter();
 
- 		return true;
 
- 	}
 
- 	if(isSwiping) // only accept this touch if it wasn't a swipe
 
- 	{
 
- 		owner.onMapSwipeEnded();
 
- 		isSwiping = false;
 
- 		return true;
 
- 	}
 
- 	return false;
 
- }
 
- void MapViewActions::handleHover(const Point & cursorPosition)
 
- {
 
- 	int3 tile = model->getTileAtPoint(cursorPosition - pos.topLeft());
 
- 	if(!context->isInMap(tile))
 
- 	{
 
- 		CCS->curh->set(Cursor::Map::POINTER);
 
- 		return;
 
- 	}
 
- 	adventureInt->onTileHovered(tile);
 
- }
 
- void MapViewActions::hover(bool on)
 
- {
 
- 	if(!on)
 
- 	{
 
- 		GH.statusbar()->clear();
 
- 		CCS->curh->set(Cursor::Map::POINTER);
 
- 	}
 
- }
 
 
  |