summaryrefslogtreecommitdiffstats
path: root/Tools/QtBiomeVisualiser/BiomeView.h
blob: 4d8b3d5281f350b4ddb53595f307dc84daa48674 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
#pragma once

#include <QWidget>
#include <memory>
#include "RegionCache.h"
#include "ChunkSource.h"





class BiomeView : public QWidget
{
	typedef QWidget super;
	Q_OBJECT

  public:
	explicit BiomeView(QWidget * parent = NULL);

	QSize minimumSizeHint() const;
	QSize sizeHint() const;

	/** Replaces the chunk source used by the biome view to get the chunk biome data.
	The entire view is then invalidated and regenerated. */
	void setChunkSource(std::shared_ptr<ChunkSource> a_ChunkSource);

	/** Sets the position of the central pixel of the map to the specified point and redraws the view. */
	void setPosition(int a_BlockX, int a_BlockZ);

	/** Sets the zoom level to the specified value and redraws the view. */
	void setZoomLevel(double a_ZoomLevel);

  signals:
	/** Signalled when the user uses the wheel to scroll upwards. */
	void wheelUp();

	/** Signalled when the user uses the wheel to scroll downwards. */
	void wheelDown();

	/** Signalled when the user presses a key to increase zoom. */
	void increaseZoom();

	/** Signalled when the user presses a key to decrease zoom. */
	void decreaseZoom();

	/** Emitted when the user moves the mouse, to reflect the current block under the cursor. */
	void hoverChanged(int a_BlockX, int a_BlockZ, int a_Biome);

  public slots:
	/** Redraw the entire widget area. */
	void redraw();

	/** A specified region has become available, redraw it. */
	void regionAvailable(int a_RegionX, int a_RegionZ);

	/** Reloads the current chunk source and redraws the entire workspace. */
	void reload();

  protected:
	double m_X, m_Z;
	double m_Zoom;

	/** Cache for the loaded chunk data. */
	RegionCache m_Cache;

	/** The entire view's contents in an offscreen image. */
	QImage m_Image;

	/** Coords of the mouse for the previous position, used while dragging. */
	int m_LastX, m_LastY;

	/** Set to true when the user has a mouse button depressed, and is dragging the view. */
	bool m_IsMouseDragging;

	/** Accumulator for the mouse wheel's delta. When the accumulator hits a threshold, the view zooms. */
	int m_MouseWheelDelta;

	/** Data used for rendering a chunk that hasn't been loaded yet */
	uchar m_EmptyChunkImage[16 * 16 * 4];

	/** Data placeholder for chunks that aren't valid. */
	short m_EmptyChunkBiomes[16 * 16];


	/** Draws the specified chunk into m_Image */
	void drawChunk(int a_ChunkX, int a_ChunkZ);

	/** Returns true iff the biome view has been initialized to contain proper biome data. */
	bool hasData(void) const { return m_Cache.hasData(); }

	/** Called when the widget is resized */
	virtual void resizeEvent(QResizeEvent *) override;

	/** Paints the entire widget */
	virtual void paintEvent(QPaintEvent *) override;

	/** Called when the user presses any mouse button. */
	virtual void mousePressEvent(QMouseEvent * a_Event);

	/** Called when the user moves the mouse. */
	virtual void mouseMoveEvent(QMouseEvent * a_Event);

	/** Called when the user releases a previously held mouse button. */
	virtual void mouseReleaseEvent(QMouseEvent * a_Event) override;

	/** Called when the user rotates the mouse wheel. */
	virtual void wheelEvent(QWheelEvent * a_Event) override;

	/** Called when the user presses a key. */
	virtual void keyPressEvent(QKeyEvent * a_Event) override;
};