|  | @@ -16,7 +16,6 @@
 | 
											
												
													
														|  |  #include "../lib/mapping/CMapEditManager.h"
 |  |  #include "../lib/mapping/CMapEditManager.h"
 | 
											
												
													
														|  |  #include "../lib/TerrainHandler.h"
 |  |  #include "../lib/TerrainHandler.h"
 | 
											
												
													
														|  |  #include "../lib/mapObjects/CObjectClassesHandler.h"
 |  |  #include "../lib/mapObjects/CObjectClassesHandler.h"
 | 
											
												
													
														|  | -#include "../lib/rmg/modificators/ObstaclePlacer.h"
 |  | 
 | 
											
												
													
														|  |  #include "../lib/CSkillHandler.h"
 |  |  #include "../lib/CSkillHandler.h"
 | 
											
												
													
														|  |  #include "../lib/spells/CSpellHandler.h"
 |  |  #include "../lib/spells/CSpellHandler.h"
 | 
											
												
													
														|  |  #include "../lib/CHeroHandler.h"
 |  |  #include "../lib/CHeroHandler.h"
 | 
											
										
											
												
													
														|  | @@ -26,7 +25,7 @@
 | 
											
												
													
														|  |  #include "maphandler.h"
 |  |  #include "maphandler.h"
 | 
											
												
													
														|  |  #include "mainwindow.h"
 |  |  #include "mainwindow.h"
 | 
											
												
													
														|  |  #include "inspector/inspector.h"
 |  |  #include "inspector/inspector.h"
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | 
 |  | +#include "VCMI_Lib.h"
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  MapController::MapController(MainWindow * m): main(m)
 |  |  MapController::MapController(MainWindow * m): main(m)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
										
											
												
													
														|  | @@ -217,6 +216,18 @@ void MapController::setMap(std::unique_ptr<CMap> cmap)
 | 
											
												
													
														|  |  		}
 |  |  		}
 | 
											
												
													
														|  |  	);
 |  |  	);
 | 
											
												
													
														|  |  	_map->getEditManager()->getUndoManager().clearAll();
 |  |  	_map->getEditManager()->getUndoManager().clearAll();
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	initObstaclePainters(_map.get());
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +void MapController::initObstaclePainters(CMap * map)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	for (auto terrain : VLC->terrainTypeHandler->objects)
 | 
											
												
													
														|  | 
 |  | +	{
 | 
											
												
													
														|  | 
 |  | +		auto terrainId = terrain->getId();
 | 
											
												
													
														|  | 
 |  | +		_obstaclePainters[terrainId] = std::make_unique<EditorObstaclePlacer>(map);
 | 
											
												
													
														|  | 
 |  | +		_obstaclePainters[terrainId]->collectPossibleObstacles(terrainId);
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  void MapController::sceneForceUpdate()
 |  |  void MapController::sceneForceUpdate()
 | 
											
										
											
												
													
														|  | @@ -397,8 +408,11 @@ void MapController::commitObstacleFill(int level)
 | 
											
												
													
														|  |  		return;
 |  |  		return;
 | 
											
												
													
														|  |  	
 |  |  	
 | 
											
												
													
														|  |  	//split by zones
 |  |  	//split by zones
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -	std::map<TerrainId, std::unique_ptr<EditorObstaclePlacer>> terrainSelected;
 |  | 
 | 
											
												
													
														|  | 
 |  | +	for (auto & painter : _obstaclePainters)
 | 
											
												
													
														|  | 
 |  | +	{
 | 
											
												
													
														|  | 
 |  | +		painter.second->clearBlockedArea();
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  | 
 |  | +	
 | 
											
												
													
														|  |  	for(auto & t : selection)
 |  |  	for(auto & t : selection)
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  |  		auto tl = _map->getTile(t);
 |  |  		auto tl = _map->getTile(t);
 | 
											
										
											
												
													
														|  | @@ -406,14 +420,11 @@ void MapController::commitObstacleFill(int level)
 | 
											
												
													
														|  |  			continue;
 |  |  			continue;
 | 
											
												
													
														|  |  		
 |  |  		
 | 
											
												
													
														|  |  		auto terrain = tl.terType->getId();
 |  |  		auto terrain = tl.terType->getId();
 | 
											
												
													
														|  | -		//FIXME: This map can be populated once at launch, not need to collect objects every time
 |  | 
 | 
											
												
													
														|  | -		terrainSelected[terrain] = std::make_unique<EditorObstaclePlacer>(_map.get());
 |  | 
 | 
											
												
													
														|  | -		terrainSelected[terrain]->addBlockedTile(t);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		_obstaclePainters[terrain]->addBlockedTile(t);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	
 |  |  	
 | 
											
												
													
														|  | -	for(auto & sel : terrainSelected)
 |  | 
 | 
											
												
													
														|  | 
 |  | +	for(auto & sel : _obstaclePainters)
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  | -		sel.second->collectPossibleObstacles(sel.first);
 |  | 
 | 
											
												
													
														|  |  		sel.second->placeObstacles(CRandomGenerator::getDefault());
 |  |  		sel.second->placeObstacles(CRandomGenerator::getDefault());
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 |