File: WaterProxy.h

package info (click to toggle)
vcmi 1.1.0%2Bdfsg-1
  • links: PTS, VCS
  • area: contrib
  • in suites: bookworm
  • size: 14,672 kB
  • sloc: cpp: 181,738; sh: 220; python: 178; ansic: 69; objc: 66; xml: 59; makefile: 34
file content (59 lines) | stat: -rw-r--r-- 1,473 bytes parent folder | download
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
/*
 * WaterProxy.h, 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
 *
 */

#pragma once
#include "Zone.h"

VCMI_LIB_NAMESPACE_BEGIN

struct RouteInfo
{
	rmg::Area blocked;
	int3 visitable;
	int3 boarding;
	rmg::Area water;
};

class WaterProxy: public Modificator
{
public:
	MODIFICATOR(WaterProxy);
	
	//subclass to store disconnected parts of water zone
	struct Lake
	{
		rmg::Area area; //water tiles
		std::map<int3, int> distanceMap; //distance map for lake
		std::map<int, rmg::Tileset> reverseDistanceMap;
		std::map<TRmgTemplateZoneId, rmg::Area> neighbourZones; //zones boardered. Area - part of land
		std::set<TRmgTemplateZoneId> keepConnections;
	};
		
	bool waterKeepConnection(TRmgTemplateZoneId zoneA, TRmgTemplateZoneId zoneB);
	RouteInfo waterRoute(Zone & dst);
	
	void process() override;
	void init() override;
	char dump(const int3 &) override;
	const std::vector<Lake> & getLakes() const;
	
protected:
	void collectLakes();
	
	bool placeShipyard(Zone & land, const Lake & lake, si32 guard, RouteInfo & info);
	bool placeBoat(Zone & land, const Lake & lake, RouteInfo & info);
		
protected:	
	std::vector<Lake> lakes; //disconnected parts of zone. Used to work with water zones
	std::map<int3, int> lakeMap; //map tile on lakeId which is position of lake in lakes array +1
};


VCMI_LIB_NAMESPACE_END