summaryrefslogtreecommitdiffstats
path: root/libdimensionxx
diff options
context:
space:
mode:
authorTavian Barnes <tavianator@gmail.com>2009-07-06 16:37:44 +0000
committerTavian Barnes <tavianator@gmail.com>2009-07-06 16:37:44 +0000
commitc54af1b6644216335361e61e770037aca1527756 (patch)
tree206f7b14798cec287f8f6112b29840664aaf5758 /libdimensionxx
parent4922d448896abe5330f106f21fd6a3b0651ae9eb (diff)
downloaddimension-c54af1b6644216335361e61e770037aca1527756.tar.xz
New GL C++ wrapper.
Diffstat (limited to 'libdimensionxx')
-rw-r--r--libdimensionxx/Makefile.am2
-rw-r--r--libdimensionxx/cameras.cpp16
-rw-r--r--libdimensionxx/dimensionxx.hpp1
-rw-r--r--libdimensionxx/dimensionxx/cameras.hpp3
-rw-r--r--libdimensionxx/dimensionxx/gl.hpp64
-rw-r--r--libdimensionxx/dimensionxx/png.hpp2
-rw-r--r--libdimensionxx/gl.cpp72
-rw-r--r--libdimensionxx/png.cpp2
8 files changed, 158 insertions, 4 deletions
diff --git a/libdimensionxx/Makefile.am b/libdimensionxx/Makefile.am
index 9c22cd5..75287e0 100644
--- a/libdimensionxx/Makefile.am
+++ b/libdimensionxx/Makefile.am
@@ -25,6 +25,7 @@ nobase_include_HEADERS = dimensionxx.hpp \
dimensionxx/color.hpp \
dimensionxx/cookie.hpp \
dimensionxx/geometry.hpp \
+ dimensionxx/gl.hpp \
dimensionxx/object.hpp \
dimensionxx/objects.hpp \
dimensionxx/png.hpp \
@@ -41,6 +42,7 @@ libdimensionxx_la_SOURCES = $(nobase_include_HEADERS) \
camera.cpp \
cameras.cpp \
color.cpp \
+ gl.cpp \
error.cpp \
object.cpp \
objects.cpp \
diff --git a/libdimensionxx/cameras.cpp b/libdimensionxx/cameras.cpp
index fb11dcf..a7a8255 100644
--- a/libdimensionxx/cameras.cpp
+++ b/libdimensionxx/cameras.cpp
@@ -22,7 +22,7 @@
namespace Dimension
{
- // Create a sphere
+ // Create a perspective camera
Perspective_Camera::Perspective_Camera(const Matrix& trans)
: Camera(dmnsn_new_perspective_camera(trans.dmnsn()))
{
@@ -31,9 +31,21 @@ namespace Dimension
}
}
- // Delete a sphere
+ // Delete a perspective camera
Perspective_Camera::~Perspective_Camera()
{
dmnsn_delete_perspective_camera(m_camera);
}
+
+ Matrix
+ Perspective_Camera::trans()
+ {
+ return Matrix(dmnsn_get_perspective_camera_trans(m_camera));
+ }
+
+ void
+ Perspective_Camera::trans(const Matrix& trans)
+ {
+ dmnsn_set_perspective_camera_trans(m_camera, trans.dmnsn());
+ }
}
diff --git a/libdimensionxx/dimensionxx.hpp b/libdimensionxx/dimensionxx.hpp
index bc52580..b552dd3 100644
--- a/libdimensionxx/dimensionxx.hpp
+++ b/libdimensionxx/dimensionxx.hpp
@@ -31,6 +31,7 @@
#include <dimensionxx/geometry.hpp>
#include <dimensionxx/color.hpp>
#include <dimensionxx/canvas.hpp>
+#include <dimensionxx/gl.hpp>
#include <dimensionxx/png.hpp>
#include <dimensionxx/object.hpp>
#include <dimensionxx/objects.hpp>
diff --git a/libdimensionxx/dimensionxx/cameras.hpp b/libdimensionxx/dimensionxx/cameras.hpp
index 85105cb..4e67d64 100644
--- a/libdimensionxx/dimensionxx/cameras.hpp
+++ b/libdimensionxx/dimensionxx/cameras.hpp
@@ -31,6 +31,9 @@ namespace Dimension
public:
Perspective_Camera(const Matrix& trans);
virtual ~Perspective_Camera();
+
+ Matrix trans();
+ void trans(const Matrix& trans);
};
}
diff --git a/libdimensionxx/dimensionxx/gl.hpp b/libdimensionxx/dimensionxx/gl.hpp
new file mode 100644
index 0000000..ef875df
--- /dev/null
+++ b/libdimensionxx/dimensionxx/gl.hpp
@@ -0,0 +1,64 @@
+/*************************************************************************
+ * Copyright (C) 2008 Tavian Barnes <tavianator@gmail.com> *
+ * *
+ * This file is part of The Dimension Library. *
+ * *
+ * The Dimension Library 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 3 of the *
+ * License, or (at your option) any later version. *
+ * *
+ * The Dimension Library 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. *
+ * *
+ * You should have received a copy of the GNU Lesser General Public *
+ * License along with this program. If not, see *
+ * <http://www.gnu.org/licenses/>. *
+ *************************************************************************/
+
+// C++ wrapper for libdimension GL support
+
+#ifndef DIMENSIONXX_GL_HPP
+#define DIMENSIONXX_GL_HPP
+
+#include <istream>
+#include <ostream>
+
+namespace Dimension
+{
+ class GL_Drawer
+ {
+ public:
+ GL_Drawer(Canvas& canvas);
+ ~GL_Drawer();
+
+ void draw();
+
+ private:
+ // Copying prohibited
+ GL_Drawer(const GL_Drawer&);
+ GL_Drawer& operator=(const GL_Drawer&);
+
+ Canvas* m_canvas;
+ bool m_drawn;
+ };
+
+ class GL_Reader
+ {
+ public:
+ // GL_Reader();
+ // ~GL_Reader();
+
+ Canvas read(unsigned int x0, unsigned int y0,
+ unsigned int width, unsigned int height);
+
+ private:
+ // Copying prohibited
+ GL_Reader(const GL_Reader&);
+ GL_Reader& operator=(const GL_Reader&);
+ };
+}
+
+#endif /* DIMENSIONXX_GL_HPP */
diff --git a/libdimensionxx/dimensionxx/png.hpp b/libdimensionxx/dimensionxx/png.hpp
index 17cb883..2b99531 100644
--- a/libdimensionxx/dimensionxx/png.hpp
+++ b/libdimensionxx/dimensionxx/png.hpp
@@ -18,7 +18,7 @@
* <http://www.gnu.org/licenses/>. *
*************************************************************************/
-// C++ wrapper for libdimension PNG support. PNG_Canvas derives from Canvas.
+// C++ wrapper for libdimension PNG support
#ifndef DIMENSIONXX_PNG_HPP
#define DIMENSIONXX_PNG_HPP
diff --git a/libdimensionxx/gl.cpp b/libdimensionxx/gl.cpp
new file mode 100644
index 0000000..5c0a7bb
--- /dev/null
+++ b/libdimensionxx/gl.cpp
@@ -0,0 +1,72 @@
+/*************************************************************************
+ * Copyright (C) 2008 Tavian Barnes <tavianator@gmail.com> *
+ * *
+ * This file is part of The Dimension Library. *
+ * *
+ * The Dimension Library 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 3 of the *
+ * License, or (at your option) any later version. *
+ * *
+ * The Dimension Library 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. *
+ * *
+ * You should have received a copy of the GNU Lesser General Public *
+ * License along with this program. If not, see *
+ * <http://www.gnu.org/licenses/>. *
+ *************************************************************************/
+
+#include "dimensionxx.hpp"
+#include <cstdio>
+
+namespace Dimension
+{
+ GL_Drawer::GL_Drawer(Canvas& canvas)
+ : m_canvas(&canvas), m_drawn(false)
+ {
+ // Optimize the canvas for GL drawing
+ dmnsn_gl_optimize_canvas(m_canvas->dmnsn());
+ }
+
+ // Draw the canvas if it hasn't been drawn yet
+ GL_Drawer::~GL_Drawer()
+ {
+ if (!m_drawn) {
+ try {
+ draw();
+ } catch (...) {
+ dmnsn_error(SEVERITY_MEDIUM,
+ "Drawing canvas to GL failed in GL_Drawer destructor.");
+ }
+ }
+ }
+
+ // Draw the canvas to the current openGL buffer
+ void GL_Drawer::draw()
+ {
+ // Draw to the GL buffer
+ if (dmnsn_gl_write_canvas(m_canvas->dmnsn()) != 0) {
+ // The drawing operation failed
+ throw Dimension_Error("Drawing canvas to GL failed.");
+ }
+
+ m_drawn = true; // Don't draw again in destructor
+ }
+
+ // Read a canvas from a GL buffer
+ Canvas
+ GL_Reader::read(unsigned int x0, unsigned int y0,
+ unsigned int width, unsigned int height)
+ {
+ // Read the canvas from the GL buffer
+ dmnsn_canvas* canvas = dmnsn_gl_read_canvas(x0, y0, width, height);
+ if (!canvas) {
+ // The read operation failed
+ throw Dimension_Error("Reading canvas from GL failed.");
+ }
+
+ return Canvas(canvas);
+ }
+}
diff --git a/libdimensionxx/png.cpp b/libdimensionxx/png.cpp
index 1f61e72..5ca8e02 100644
--- a/libdimensionxx/png.cpp
+++ b/libdimensionxx/png.cpp
@@ -58,7 +58,7 @@ namespace Dimension
FILE_Cookie cookie(*m_ostr);
// Write the PNG file
- if (dmnsn_png_write_canvas(m_canvas->dmnsn(), cookie.file())) {
+ if (dmnsn_png_write_canvas(m_canvas->dmnsn(), cookie.file()) != 0) {
// The actual write operation failed, for some reason
throw Dimension_Error("Writing canvas to PNG failed.");
}