mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 18:26:41 +00:00 
			
		
		
		
	Allow dragging map even when a marker is hovered
This commit is contained in:
		
							parent
							
								
									603e558fb7
								
							
						
					
					
						commit
						18be152ab1
					
				
					 2 changed files with 23 additions and 4 deletions
				
			
		|  | @ -319,12 +319,11 @@ namespace MWGui | ||||||
|             markerWidget->setUserString("ToolTipType", "Layout"); |             markerWidget->setUserString("ToolTipType", "Layout"); | ||||||
|             markerWidget->setUserString("ToolTipLayout", "TextToolTipOneLine"); |             markerWidget->setUserString("ToolTipLayout", "TextToolTipOneLine"); | ||||||
|             markerWidget->setUserString("Caption_TextOneLine", MyGUI::TextIterator::toTagsString(marker.mNote)); |             markerWidget->setUserString("Caption_TextOneLine", MyGUI::TextIterator::toTagsString(marker.mNote)); | ||||||
|             markerWidget->setColour(MyGUI::Colour(1.0,0.3,0.3)); |  | ||||||
|             markerWidget->setNormalColour(MyGUI::Colour(1.0,0.3,0.3)); |             markerWidget->setNormalColour(MyGUI::Colour(1.0,0.3,0.3)); | ||||||
|             markerWidget->setHoverColour(MyGUI::Colour(1.0,0.5,0.5)); |             markerWidget->setHoverColour(MyGUI::Colour(1.0,0.5,0.5)); | ||||||
|             markerWidget->setUserData(marker); |             markerWidget->setUserData(marker); | ||||||
|             markerWidget->setNeedMouseFocus(true); |             markerWidget->setNeedMouseFocus(true); | ||||||
|             markerWidget->eventMouseButtonDoubleClick += MyGUI::newDelegate(this, &LocalMapBase::onCustomMarkerDoubleClicked); |             customMarkerCreated(markerWidget); | ||||||
|             mCustomMarkerWidgets.push_back(markerWidget); |             mCustomMarkerWidgets.push_back(markerWidget); | ||||||
|         } |         } | ||||||
|         redraw(); |         redraw(); | ||||||
|  | @ -411,6 +410,7 @@ namespace MWGui | ||||||
|             // Used by tooltips to not show the tooltip if marker is hidden by fog of war
 |             // Used by tooltips to not show the tooltip if marker is hidden by fog of war
 | ||||||
|             markerWidget->setUserString("IsMarker", "true"); |             markerWidget->setUserString("IsMarker", "true"); | ||||||
|             markerWidget->setUserData(markerPos); |             markerWidget->setUserData(markerPos); | ||||||
|  |             doorMarkerCreated(markerWidget); | ||||||
| 
 | 
 | ||||||
|             mDoorMarkerWidgets.push_back(markerWidget); |             mDoorMarkerWidgets.push_back(markerWidget); | ||||||
|         } |         } | ||||||
|  | @ -753,6 +753,8 @@ namespace MWGui | ||||||
|         markerWidget->setUserString("ToolTipLayout", "TextToolTipOneLine"); |         markerWidget->setUserString("ToolTipLayout", "TextToolTipOneLine"); | ||||||
|         markerWidget->setUserString("Caption_TextOneLine", name); |         markerWidget->setUserString("Caption_TextOneLine", name); | ||||||
|         markerWidget->setDepth(Global_MarkerLayer); |         markerWidget->setDepth(Global_MarkerLayer); | ||||||
|  |         markerWidget->eventMouseDrag += MyGUI::newDelegate(this, &MapWindow::onMouseDrag); | ||||||
|  |         markerWidget->eventMouseButtonPressed += MyGUI::newDelegate(this, &MapWindow::onDragStart); | ||||||
|         ++_counter; |         ++_counter; | ||||||
| 
 | 
 | ||||||
|         CellId cell; |         CellId cell; | ||||||
|  | @ -928,6 +930,19 @@ namespace MWGui | ||||||
|             (*it)->setVisible(alpha == 1); |             (*it)->setVisible(alpha == 1); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void MapWindow::customMarkerCreated(MyGUI::Widget *marker) | ||||||
|  |     { | ||||||
|  |         marker->eventMouseDrag += MyGUI::newDelegate(this, &MapWindow::onMouseDrag); | ||||||
|  |         marker->eventMouseButtonPressed += MyGUI::newDelegate(this, &MapWindow::onDragStart); | ||||||
|  |         marker->eventMouseButtonDoubleClick += MyGUI::newDelegate(this, &MapWindow::onCustomMarkerDoubleClicked); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     void MapWindow::doorMarkerCreated(MyGUI::Widget *marker) | ||||||
|  |     { | ||||||
|  |         marker->eventMouseDrag += MyGUI::newDelegate(this, &MapWindow::onMouseDrag); | ||||||
|  |         marker->eventMouseButtonPressed += MyGUI::newDelegate(this, &MapWindow::onDragStart); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     // -------------------------------------------------------------------
 |     // -------------------------------------------------------------------
 | ||||||
| 
 | 
 | ||||||
|     EditNoteDialog::EditNoteDialog() |     EditNoteDialog::EditNoteDialog() | ||||||
|  |  | ||||||
|  | @ -119,7 +119,8 @@ namespace MWGui | ||||||
|         virtual void notifyPlayerUpdate() {} |         virtual void notifyPlayerUpdate() {} | ||||||
|         virtual void notifyMapChanged() {} |         virtual void notifyMapChanged() {} | ||||||
| 
 | 
 | ||||||
|         virtual void onCustomMarkerDoubleClicked(MyGUI::Widget* sender) {} |         virtual void customMarkerCreated(MyGUI::Widget* marker) {} | ||||||
|  |         virtual void doorMarkerCreated(MyGUI::Widget* marker) {} | ||||||
| 
 | 
 | ||||||
|         void updateMagicMarkers(); |         void updateMagicMarkers(); | ||||||
|         void addDetectionMarkers(int type); |         void addDetectionMarkers(int type); | ||||||
|  | @ -199,6 +200,7 @@ namespace MWGui | ||||||
|         void onMouseDrag(MyGUI::Widget* _sender, int _left, int _top, MyGUI::MouseButton _id); |         void onMouseDrag(MyGUI::Widget* _sender, int _left, int _top, MyGUI::MouseButton _id); | ||||||
|         void onWorldButtonClicked(MyGUI::Widget* _sender); |         void onWorldButtonClicked(MyGUI::Widget* _sender); | ||||||
|         void onMapDoubleClicked(MyGUI::Widget* sender); |         void onMapDoubleClicked(MyGUI::Widget* sender); | ||||||
|  |         void onCustomMarkerDoubleClicked(MyGUI::Widget* sender); | ||||||
|         void onNoteEditOk(); |         void onNoteEditOk(); | ||||||
|         void onNoteEditDelete(); |         void onNoteEditDelete(); | ||||||
|         void onNoteEditDeleteConfirm(); |         void onNoteEditDeleteConfirm(); | ||||||
|  | @ -235,7 +237,9 @@ namespace MWGui | ||||||
| 
 | 
 | ||||||
|         virtual void onPinToggled(); |         virtual void onPinToggled(); | ||||||
|         virtual void onTitleDoubleClicked(); |         virtual void onTitleDoubleClicked(); | ||||||
|         virtual void onCustomMarkerDoubleClicked(MyGUI::Widget* sender); | 
 | ||||||
|  |         virtual void doorMarkerCreated(MyGUI::Widget* marker); | ||||||
|  |         virtual void customMarkerCreated(MyGUI::Widget *marker); | ||||||
| 
 | 
 | ||||||
|         virtual void notifyPlayerUpdate(); |         virtual void notifyPlayerUpdate(); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue