139 lines
3.2 KiB
C
Raw Normal View History

2012-03-16 00:25:18 +02:00
/*
2013-02-24 18:40:43 +01:00
Minetest
2013-02-24 19:38:45 +01:00
Copyright (C) 2010-2013 celeron55, Perttu Ahola <celeron55@gmail.com>
2012-03-16 00:25:18 +02:00
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 2.1 of the License, or
2012-03-16 00:25:18 +02:00
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
2012-03-16 00:25:18 +02:00
You should have received a copy of the GNU Lesser General Public License along
2012-03-16 00:25:18 +02:00
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#pragma once
2012-03-16 00:25:18 +02:00
2012-06-17 04:00:31 +03:00
#include "irrlichttypes_extrabloated.h"
2012-03-16 00:25:18 +02:00
#include "map.h"
#include "camera.h"
2012-12-20 21:19:49 +04:00
#include <set>
#include <map>
2012-03-16 00:25:18 +02:00
struct MapDrawControl
{
// Overrides limits by drawing everything
bool range_all = false;
2012-03-16 00:25:18 +02:00
// Wanted drawing range
float wanted_range = 0.0f;
2012-03-16 00:25:18 +02:00
// Maximum number of blocks to draw
u32 wanted_max_blocks = 0;
// show a wire frame for debugging
bool show_wireframe = false;
2012-03-16 00:25:18 +02:00
};
class Client;
class ITextureSource;
/*
ClientMap
2012-03-16 00:25:18 +02:00
This is the only map class that is able to render itself on screen.
*/
class ClientMap : public Map, public scene::ISceneNode
{
public:
ClientMap(
Client *client,
MapDrawControl &control,
s32 id
);
virtual ~ClientMap() = default;
2012-03-16 00:25:18 +02:00
s32 mapType() const
{
return MAPTYPE_CLIENT;
}
void drop()
{
ISceneNode::drop();
}
void updateCamera(const v3f &pos, const v3f &dir, f32 fov, const v3s16 &offset)
2012-03-16 00:25:18 +02:00
{
m_camera_position = pos;
m_camera_direction = dir;
m_camera_fov = fov;
m_camera_offset = offset;
2012-03-16 00:25:18 +02:00
}
/*
Forcefully get a sector from somewhere
*/
MapSector * emergeSector(v2s16 p);
//void deSerializeSector(v2s16 p2d, std::istream &is);
/*
ISceneNode methods
*/
virtual void OnRegisterSceneNode();
virtual void render()
{
video::IVideoDriver* driver = SceneManager->getVideoDriver();
driver->setTransform(video::ETS_WORLD, AbsoluteTransformation);
renderMap(driver, SceneManager->getSceneNodeRenderPass());
}
virtual const aabb3f &getBoundingBox() const
2012-03-16 00:25:18 +02:00
{
return m_box;
}
void getBlocksInViewRange(v3s16 cam_pos_nodes,
v3s16 *p_blocks_min, v3s16 *p_blocks_max);
void updateDrawList();
2012-03-16 00:25:18 +02:00
void renderMap(video::IVideoDriver* driver, s32 pass);
int getBackgroundBrightness(float max_d, u32 daylight_factor,
int oldvalue, bool *sunlight_seen_result);
void renderPostFx(CameraMode cam_mode);
2012-03-16 00:25:18 +02:00
// For debug printing
virtual void PrintInfo(std::ostream &out);
const MapDrawControl & getControl() const { return m_control; }
f32 getCameraFov() const { return m_camera_fov; }
2012-03-16 00:25:18 +02:00
private:
Client *m_client;
aabb3f m_box = aabb3f(-BS * 1000000, -BS * 1000000, -BS * 1000000,
BS * 1000000, BS * 1000000, BS * 1000000);
2012-03-16 00:25:18 +02:00
MapDrawControl &m_control;
v3f m_camera_position = v3f(0,0,0);
v3f m_camera_direction = v3f(0,0,1);
f32 m_camera_fov = M_PI;
v3s16 m_camera_offset;
2012-12-20 21:19:49 +04:00
std::map<v3s16, MapBlock*> m_drawlist;
2012-12-20 21:19:49 +04:00
std::set<v2s16> m_last_drawn_sectors;
bool m_cache_trilinear_filter;
bool m_cache_bilinear_filter;
bool m_cache_anistropic_filter;
2012-03-16 00:25:18 +02:00
};