--- /dev/null
+/**
+ * MltGeometry.cpp - MLT Wrapper
+ * Copyright (C) 2004-2005 Charles Yates
+ * Author: Charles Yates <charles.yates@pandora.be>
+ *
+ * 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 of the License, or
+ * (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 General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ */
+
+#include <stdlib.h>
+#include "MltGeometry.h"
+using namespace Mlt;
+
+Geometry::Geometry( char *data, int length, int nw, int nh )
+{
+ geometry = mlt_geometry_init( );
+ parse( data, length, nw, nh );
+}
+
+Geometry::~Geometry( )
+{
+ mlt_geometry_close( geometry );
+}
+
+int Geometry::parse( char *data, int length, int nw, int nh )
+{
+ return mlt_geometry_parse( geometry, data, length, nw, nh );
+}
+
+// Fetch a geometry item for an absolute position
+int Geometry::fetch( GeometryItem &item, float position )
+{
+ return mlt_geometry_fetch( geometry, item.get_item( ), position );
+}
+
+int Geometry::fetch( GeometryItem *item, float position )
+{
+ return mlt_geometry_fetch( geometry, item->get_item( ), position );
+}
+
+// Specify a geometry item at an absolute position
+int Geometry::insert( GeometryItem &item )
+{
+ return mlt_geometry_insert( geometry, item.get_item( ) );
+}
+
+int Geometry::insert( GeometryItem *item )
+{
+ return mlt_geometry_insert( geometry, item->get_item( ) );
+}
+
+// Remove the key at the specified position
+int Geometry::remove( int position )
+{
+ return mlt_geometry_remove( geometry, position );
+}
+
+// Get the key at the position or the next following
+int Geometry::key( GeometryItem &item, int position )
+{
+ return mlt_geometry_key( geometry, item.get_item( ), position );
+}
+
+int Geometry::key( GeometryItem *item, int position )
+{
+ return mlt_geometry_key( geometry, item->get_item( ), position );
+}
+
+// Serialise the current geometry
+char *Geometry::serialise( int in, int out )
+{
+ return mlt_geometry_serialise_cut( geometry, in, out );
+}
+
+char *Geometry::serialise( )
+{
+ return mlt_geometry_serialise( geometry );
+}
+
--- /dev/null
+/**
+ * MltGeometry.h - MLT Wrapper
+ * Copyright (C) 2004-2005 Charles Yates
+ * Author: Charles Yates <charles.yates@pandora.be>
+ *
+ * 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 of the License, or
+ * (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 General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ */
+
+#ifndef _MLTPP_GEOMETRY_H
+#define _MLTPP_GEOMETRY_H
+
+#include <framework/mlt.h>
+
+namespace Mlt
+{
+ // Just for consistent naming purposes
+ class GeometryItem
+ {
+ private:
+ struct mlt_geometry_item_s item;
+ public:
+ mlt_geometry_item get_item( ) { return &item; }
+ bool key( ) { return item.key; }
+ int frame( ) { return item.frame; }
+ void frame( int value ) { item.frame = value; }
+ float x( ) { return item.x; }
+ void x( float value ) { item.x = value; }
+ float y( ) { return item.y; }
+ void y( float value ) { item.y = value; }
+ float w( ) { return item.w; }
+ void w( float value ) { item.w = value; }
+ float h( ) { return item.h; }
+ void h( float value ) { item.h = value; }
+ float mix( ) { return item.mix; }
+ void mix( float value ) { item.mix = value; }
+ };
+
+ class Geometry
+ {
+ private:
+ mlt_geometry geometry;
+ public:
+ Geometry( char *data = NULL, int length = 0, int nw = -1, int nh = -1 );
+ ~Geometry( );
+ int parse( char *data, int length, int nw = -1, int nh = -1 );
+ // Fetch a geometry item for an absolute position
+ int fetch( GeometryItem &item, float position );
+ int fetch( GeometryItem *item, float position );
+ // Specify a geometry item at an absolute position
+ int insert( GeometryItem &item );
+ int insert( GeometryItem *item );
+ // Remove the key at the specified position
+ int remove( int position );
+ // Get the key at the position or the next following
+ int key( GeometryItem &item, int position );
+ int key( GeometryItem *item, int position );
+ // Serialise the current geometry
+ char *serialise( int in, int out );
+ char *serialise( );
+ };
+}
+
+#endif
+