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
60
|
#include "tile-shader.hpp"
#include "loader.hpp"
#include <algorithm>
#include <Corrade/Containers/Reference.h>
#include <Corrade/Utility/Resource.h>
#include <Magnum/GL/Context.h>
#include <Magnum/GL/Shader.h>
#include <Magnum/GL/Version.h>
namespace Magnum::Examples {
tile_shader::tile_shader()
{
MAGNUM_ASSERT_GL_VERSION_SUPPORTED(GL::Version::GL460);
GL::Shader vert{GL::Version::GL460, GL::Shader::Type::Vertex};
GL::Shader frag{GL::Version::GL460, GL::Shader::Type::Fragment};
vert.addSource(loader.shader("shaders/tile-shader.vert"));
frag.addSource(loader.shader("shaders/tile-shader.frag"));
#ifdef __clang__
# pragma clang diagnostic push
# pragma clang diagnostic ignored "-Wdeprecated-declarations"
#endif
CORRADE_INTERNAL_ASSERT_OUTPUT(GL::Shader::compile({vert, frag}));
#ifdef __clang__
# pragma clang diagnostic pop
#endif
attachShaders({vert, frag});
CORRADE_INTERNAL_ASSERT_OUTPUT(link());
set_scale({640, 480});
set_camera_offset({0, 0});
}
tile_shader& tile_shader::set_scale(const Vector2& scale)
{
scale_ = scale;
setUniform(ScaleUniform, scale);
return *this;
}
tile_shader& tile_shader::set_camera_offset(Vector2 camera_offset)
{
CORRADE_INTERNAL_ASSERT(std::fabs(camera_offset[0]) <= std::scalbn(1.f, std::numeric_limits<float>::digits));
CORRADE_INTERNAL_ASSERT(std::fabs(camera_offset[1]) <= std::scalbn(1.f, std::numeric_limits<float>::digits));
camera_offset_ = camera_offset;
setUniform(OffsetUniform, camera_offset);
return *this;
}
Vector2 tile_shader::project(Vector3 pt)
{
float x = pt[1], y = pt[0], z = pt[2];
return { x-y, (x+y+z*2)*.75f };
}
} // namespace Magnum::Examples
|