1 /*
2  Copyright (C) 2010-2014 Kristian Duske
3 
4  This file is part of TrenchBroom.
5 
6  TrenchBroom is free software: you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation, either version 3 of the License, or
9  (at your option) any later version.
10 
11  TrenchBroom is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with TrenchBroom. If not, see <http://www.gnu.org/licenses/>.
18  */
19 
20 #include "CreateComplexBrushTool.h"
21 #include "Polyhedron.h"
22 #include "PreferenceManager.h"
23 #include "Preferences.h"
24 #include "Model/Brush.h"
25 #include "Model/BrushBuilder.h"
26 #include "Model/Layer.h"
27 #include "Model/World.h"
28 #include "Renderer/BrushRenderer.h"
29 #include "Renderer/RenderService.h"
30 #include "Renderer/SelectionBoundsRenderer.h"
31 #include "View/MapDocument.h"
32 
33 namespace TrenchBroom {
34     namespace View {
CreateComplexBrushTool(MapDocumentWPtr document)35         CreateComplexBrushTool::CreateComplexBrushTool(MapDocumentWPtr document) :
36         CreateBrushToolBase(false, document) {}
37 
polyhedron() const38         const Polyhedron3& CreateComplexBrushTool::polyhedron() const {
39             return m_polyhedron;
40         }
41 
update(const Polyhedron3 & polyhedron)42         void CreateComplexBrushTool::update(const Polyhedron3& polyhedron) {
43             m_polyhedron = polyhedron;
44             if (m_polyhedron.closed()) {
45                 MapDocumentSPtr document = lock(m_document);
46                 const Model::BrushBuilder builder(document->world(), document->worldBounds());
47                 Model::Brush* brush = builder.createBrush(m_polyhedron, document->currentTextureName());
48                 updateBrush(brush);
49             } else {
50                 updateBrush(NULL);
51             }
52         }
53 
doBrushWasCreated()54         void CreateComplexBrushTool::doBrushWasCreated() {
55             update(Polyhedron3());
56         }
57     }
58 }
59