فهرست منبع

Merge pull request #6214 from Laserlicht/puzzle

puzzlemap fine tuning
Ivan Savenko 2 هفته پیش
والد
کامیت
f13e00850f
2فایلهای تغییر یافته به همراه9 افزوده شده و 2 حذف شده
  1. 7 2
      client/windows/CPuzzleWindow.cpp
  2. 2 0
      client/windows/CPuzzleWindow.h

+ 7 - 2
client/windows/CPuzzleWindow.cpp

@@ -21,6 +21,7 @@
 #include "../widgets/Buttons.h"
 #include "../widgets/Images.h"
 #include "../widgets/TextControls.h"
+#include "../widgets/GraphicalPrimitiveCanvas.h"
 
 #include "../../lib/callback/CCallback.h"
 #include "../../lib/entities/faction/CFaction.h"
@@ -42,7 +43,7 @@ CPuzzleWindow::CPuzzleWindow(const int3 & GrailPos, double discoveredRatio)
 	quitb = std::make_shared<CButton>(Point(670, 538), AnimationPath::builtin("IOK6432.DEF"), CButton::tooltip(LIBRARY->generaltexth->allTexts[599]), std::bind(&CPuzzleWindow::close, this), EShortcut::GLOBAL_RETURN);
 	quitb->setBorderColor(Colors::METALLIC_GOLD);
 
-	mapView = std::make_shared<PuzzleMapView>(Point(8,9), Point(591, 544), grailPos);
+	mapView = std::make_shared<PuzzleMapView>(Point(8,8), Point(592, 544), grailPos);
 	mapView->needFullUpdate = true;
 
 	logo = std::make_shared<CPicture>(ImagePath::builtin("PUZZLOGO"), 607, 3);
@@ -57,7 +58,7 @@ CPuzzleWindow::CPuzzleWindow(const int3 & GrailPos, double discoveredRatio)
 	{
 		const SPuzzleInfo & info = elem;
 
-		auto piece = std::make_shared<CPicture>(info.filename, info.position.x, info.position.y);
+		auto piece = std::make_shared<CPicture>(info.filename, info.position.x + 1, info.position.y);
 		piece->needRefresh = true;
 
 		//piece that will slowly disappear
@@ -71,6 +72,10 @@ CPuzzleWindow::CPuzzleWindow(const int3 & GrailPos, double discoveredRatio)
 			visiblePieces.push_back(piece);
 		}
 	}
+
+	border = std::make_shared<GraphicalPrimitiveCanvas>(Rect(Point(6,6), Point(596, 548)));
+	for(int i = 0; i < 3; i++)
+		border->addRectangle(Point(i, i), Point(border->pos.w - i * 2, border->pos.h - i * 2), Colors::BLACK);
 }
 
 void CPuzzleWindow::showAll(Canvas & to)

+ 2 - 0
client/windows/CPuzzleWindow.h

@@ -16,6 +16,7 @@ class CLabel;
 class CButton;
 class CResDataBar;
 class PuzzleMapView;
+class GraphicalPrimitiveCanvas;
 
 /// Puzzle screen which gets uncovered when you visit obilisks
 class CPuzzleWindow : public CWindowObject
@@ -24,6 +25,7 @@ private:
 	int3 grailPos;
 	std::shared_ptr<PuzzleMapView> mapView;
 	std::shared_ptr<CPicture> logo;
+	std::shared_ptr<GraphicalPrimitiveCanvas> border;
 	std::shared_ptr<CLabel> title;
 	std::shared_ptr<CButton> quitb;
 	std::shared_ptr<CResDataBar> resDataBar;