3 Copyright (C) 2010-2013 celeron55, Perttu Ahola <celeron55@gmail.com>
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU Lesser General Public License as published by
7 the Free Software Foundation; either version 2.1 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public License along
16 with this program; if not, write to the Free Software Foundation, Inc.,
17 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
22 #include "irrlichttypes_extrabloated.h"
30 // Wanted drawing range
31 float wanted_range = 0.0f;
32 // Overrides limits by drawing everything
33 bool range_all = false;
34 // Allow rendering out of bounds
35 bool allow_noclip = false;
36 // show a wire frame for debugging
37 bool show_wireframe = false;
43 std::vector<std::pair<v3s16,scene::IMeshBuffer*>> bufs;
46 struct MeshBufListList
49 * Stores the mesh buffers of the world.
50 * The array index is the material's layer.
51 * The vector part groups vertices by material.
53 std::vector<MeshBufList> lists[MAX_TILE_LAYERS];
56 void add(scene::IMeshBuffer *buf, v3s16 position, u8 layer);
61 class PartialMeshBuffer;
66 This is the only map class that is able to render itself on screen.
69 class ClientMap : public Map, public scene::ISceneNode
74 RenderingEngine *rendering_engine,
75 MapDrawControl &control,
81 bool maySaveBlocks() override
88 ISceneNode::drop(); // calls destructor
91 void updateCamera(v3f pos, v3f dir, f32 fov, v3s16 offset);
94 Forcefully get a sector from somewhere
96 MapSector * emergeSector(v2s16 p) override;
102 virtual void OnRegisterSceneNode() override;
104 virtual void render() override
106 video::IVideoDriver* driver = SceneManager->getVideoDriver();
107 driver->setTransform(video::ETS_WORLD, AbsoluteTransformation);
108 renderMap(driver, SceneManager->getSceneNodeRenderPass());
111 virtual const aabb3f &getBoundingBox() const override
116 void getBlocksInViewRange(v3s16 cam_pos_nodes,
117 v3s16 *p_blocks_min, v3s16 *p_blocks_max, float range=-1.0f);
118 void updateDrawList();
119 // @brief Calculate statistics about the map and keep the blocks alive
120 void touchMapBlocks();
121 void updateDrawListShadow(v3f shadow_light_pos, v3f shadow_light_dir, float radius, float length);
122 // Returns true if draw list needs updating before drawing the next frame.
123 bool needsUpdateDrawList() { return m_needs_update_drawlist; }
124 void renderMap(video::IVideoDriver* driver, s32 pass);
126 void renderMapShadows(video::IVideoDriver *driver,
127 const video::SMaterial &material, s32 pass, int frame, int total_frames);
129 int getBackgroundBrightness(float max_d, u32 daylight_factor,
130 int oldvalue, bool *sunlight_seen_result);
132 void renderPostFx(CameraMode cam_mode);
134 // For debug printing
135 void PrintInfo(std::ostream &out) override;
137 const MapDrawControl & getControl() const { return m_control; }
138 f32 getWantedRange() const { return m_control.wanted_range; }
139 f32 getCameraFov() const { return m_camera_fov; }
141 void onSettingChanged(const std::string &name);
145 // update the vertex order in transparent mesh buffers
146 void updateTransparentMeshBuffers();
149 // Orders blocks by distance to the camera
150 class MapBlockComparer
153 MapBlockComparer(const v3s16 &camera_block) : m_camera_block(camera_block) {}
155 bool operator() (const v3s16 &left, const v3s16 &right) const
157 auto distance_left = left.getDistanceFromSQ(m_camera_block);
158 auto distance_right = right.getDistanceFromSQ(m_camera_block);
159 return distance_left > distance_right || (distance_left == distance_right && left > right);
163 v3s16 m_camera_block;
167 // reference to a mesh buffer used when rendering the map.
168 struct DrawDescriptor {
171 scene::IMeshBuffer *m_buffer;
172 const PartialMeshBuffer *m_partial_buffer;
174 bool m_reuse_material:1;
175 bool m_use_partial_buffer:1;
177 DrawDescriptor(v3s16 pos, scene::IMeshBuffer *buffer, bool reuse_material) :
178 m_pos(pos), m_buffer(buffer), m_reuse_material(reuse_material), m_use_partial_buffer(false)
181 DrawDescriptor(v3s16 pos, const PartialMeshBuffer *buffer) :
182 m_pos(pos), m_partial_buffer(buffer), m_reuse_material(false), m_use_partial_buffer(true)
185 scene::IMeshBuffer* getBuffer();
186 void draw(video::IVideoDriver* driver);
190 RenderingEngine *m_rendering_engine;
192 aabb3f m_box = aabb3f(-BS * 1000000, -BS * 1000000, -BS * 1000000,
193 BS * 1000000, BS * 1000000, BS * 1000000);
195 MapDrawControl &m_control;
197 v3f m_camera_position = v3f(0,0,0);
198 v3f m_camera_direction = v3f(0,0,1);
199 f32 m_camera_fov = M_PI;
200 v3s16 m_camera_offset;
201 bool m_needs_update_transparent_meshes = true;
203 std::map<v3s16, MapBlock*, MapBlockComparer> m_drawlist;
204 std::map<v3s16, MapBlock*> m_drawlist_shadow;
205 bool m_needs_update_drawlist;
207 std::set<v2s16> m_last_drawn_sectors;
209 bool m_cache_trilinear_filter;
210 bool m_cache_bilinear_filter;
211 bool m_cache_anistropic_filter;
212 u16 m_cache_transparency_sorting_distance;
214 bool m_new_occlusion_culler;
215 bool m_enable_raytraced_culling;