/* * Cogl * * A Low Level GPU Graphics and Utilities API * * Copyright (C) 2010 Intel Corporation. * * Permission is hereby granted, free of charge, to any person * obtaining a copy of this software and associated documentation * files (the "Software"), to deal in the Software without * restriction, including without limitation the rights to use, copy, * modify, merge, publish, distribute, sublicense, and/or sell copies * of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be * included in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. * * * * Authors: * Robert Bragg */ #if !defined(__COGL_H_INSIDE__) && !defined(COGL_COMPILATION) #error "Only can be included directly." #endif #ifndef __COGL_ATTRIBUTE_H__ #define __COGL_ATTRIBUTE_H__ /* We forward declare the CoglAttribute type here to avoid some circular * dependency issues with the following headers. */ typedef struct _CoglAttribute CoglAttribute; #include #include #include G_BEGIN_DECLS /** * SECTION:cogl-attribute * @short_description: Functions for declaring and drawing vertex * attributes * * FIXME */ /** * cogl_attribute_get_gtype: * * Returns: a #GType that can be used with the GLib type system. */ COGL_EXPORT GType cogl_attribute_get_gtype (void); /** * cogl_attribute_new: (constructor) * @attribute_buffer: The #CoglAttributeBuffer containing the actual * attribute data * @name: The name of the attribute (used to reference it from GLSL) * @stride: The number of bytes to jump to get to the next attribute * value for the next vertex. (Usually * sizeof (MyVertex)) * @offset: The byte offset from the start of @attribute_buffer for * the first attribute value. (Usually * offsetof (MyVertex, component0) * @components: The number of components (e.g. 4 for an rgba color or * 3 for and (x,y,z) position) * @type: FIXME * * Describes the layout for a list of vertex attribute values (For * example, a list of texture coordinates or colors). * * The @name is used to access the attribute inside a GLSL vertex * shader and there are some special names you should use if they are * applicable: * * "cogl_position_in" (used for vertex positions) * "cogl_color_in" (used for vertex colors) * "cogl_tex_coord0_in", "cogl_tex_coord1", ... * (used for vertex texture coordinates) * "cogl_normal_in" (used for vertex normals) * "cogl_point_size_in" (used to set the size of points * per-vertex. Note this can only be used if * %COGL_FEATURE_ID_POINT_SIZE_ATTRIBUTE is advertised and * cogl_pipeline_set_per_vertex_point_size() is called on the pipeline. * * * * The attribute values corresponding to different vertices can either * be tightly packed or interleaved with other attribute values. For * example it's common to define a structure for a single vertex like: * |[ * typedef struct * { * float x, y, z; /* position attribute */ * float s, t; /* texture coordinate attribute */ * } MyVertex; * ]| * * And then create an array of vertex data something like: * |[ * MyVertex vertices[100] = { .... } * ]| * * In this case, to describe either the position or texture coordinate * attribute you have to move sizeof (MyVertex) bytes to * move from one vertex to the next. This is called the attribute * @stride. If you weren't interleving attributes and you instead had * a packed array of float x, y pairs then the attribute stride would * be (2 * sizeof (float)). So the @stride is the number of * bytes to move to find the attribute value of the next vertex. * * Normally a list of attributes starts at the beginning of an array. * So for the MyVertex example above the @offset is the * offset inside the MyVertex structure to the first * component of the attribute. For the texture coordinate attribute * the offset would be offsetof (MyVertex, s) or instead of * using the offsetof macro you could use sizeof (float) * * 3. If you've divided your @array into blocks of non-interleved * attributes then you will need to calculate the @offset as the number of * bytes in blocks preceding the attribute you're describing. * * An attribute often has more than one component. For example a color * is often comprised of 4 red, green, blue and alpha @components, and a * position may be comprised of 2 x and y @components. You should aim * to keep the number of components to a minimum as more components * means more data needs to be mapped into the GPU which can be a * bottleneck when dealing with a large number of vertices. * * Finally you need to specify the component data type. Here you * should aim to use the smallest type that meets your precision * requirements. Again the larger the type then more data needs to be * mapped into the GPU which can be a bottleneck when dealing with * a large number of vertices. * * Return value: (transfer full): A newly allocated #CoglAttribute * describing the layout for a list of attribute values * stored in @array. */ /* XXX: look for a precedent to see if the stride/offset args should * have a different order. */ COGL_EXPORT CoglAttribute * cogl_attribute_new (CoglAttributeBuffer *attribute_buffer, const char *name, size_t stride, size_t offset, int components, CoglAttributeType type); /** * cogl_attribute_new_const_1f: * @context: A #CoglContext * @name: The name of the attribute (used to reference it from GLSL) * @value: The constant value for the attribute * * Creates a new, single component, attribute whose value remains * constant across all the vertices of a primitive without needing to * duplicate the value for each vertex. * * The constant @value is a single precision floating point scalar * which should have a corresponding declaration in GLSL code like: * * [| * attribute float name; * |] * * Return value: (transfer full): A newly allocated #CoglAttribute * representing the given constant @value. */ COGL_EXPORT CoglAttribute * cogl_attribute_new_const_1f (CoglContext *context, const char *name, float value); /** * cogl_attribute_new_const_2f: * @context: A #CoglContext * @name: The name of the attribute (used to reference it from GLSL) * @component0: The first component of a 2 component vector * @component1: The second component of a 2 component vector * * Creates a new, 2 component, attribute whose value remains * constant across all the vertices of a primitive without needing to * duplicate the value for each vertex. * * The constants (@component0, @component1) represent a 2 component * float vector which should have a corresponding declaration in GLSL * code like: * * [| * attribute vec2 name; * |] * * Return value: (transfer full): A newly allocated #CoglAttribute * representing the given constant vector. */ COGL_EXPORT CoglAttribute * cogl_attribute_new_const_2f (CoglContext *context, const char *name, float component0, float component1); /** * cogl_attribute_new_const_3f: * @context: A #CoglContext * @name: The name of the attribute (used to reference it from GLSL) * @component0: The first component of a 3 component vector * @component1: The second component of a 3 component vector * @component2: The third component of a 3 component vector * * Creates a new, 3 component, attribute whose value remains * constant across all the vertices of a primitive without needing to * duplicate the value for each vertex. * * The constants (@component0, @component1, @component2) represent a 3 * component float vector which should have a corresponding * declaration in GLSL code like: * * [| * attribute vec3 name; * |] * * unless the built in name "cogl_normal_in" is being used where no * explicit GLSL declaration need be made. * * Return value: (transfer full): A newly allocated #CoglAttribute * representing the given constant vector. */ COGL_EXPORT CoglAttribute * cogl_attribute_new_const_3f (CoglContext *context, const char *name, float component0, float component1, float component2); /** * cogl_attribute_new_const_4f: * @context: A #CoglContext * @name: The name of the attribute (used to reference it from GLSL) * @component0: The first component of a 4 component vector * @component1: The second component of a 4 component vector * @component2: The third component of a 4 component vector * @component3: The fourth component of a 4 component vector * * Creates a new, 4 component, attribute whose value remains * constant across all the vertices of a primitive without needing to * duplicate the value for each vertex. * * The constants (@component0, @component1, @component2, @constant3) * represent a 4 component float vector which should have a * corresponding declaration in GLSL code like: * * [| * attribute vec4 name; * |] * * unless one of the built in names "cogl_color_in", * "cogl_tex_coord0_in or "cogl_tex_coord1_in" etc is being used where * no explicit GLSL declaration need be made. * * Return value: (transfer full): A newly allocated #CoglAttribute * representing the given constant vector. */ COGL_EXPORT CoglAttribute * cogl_attribute_new_const_4f (CoglContext *context, const char *name, float component0, float component1, float component2, float component3); /** * cogl_attribute_new_const_2fv: * @context: A #CoglContext * @name: The name of the attribute (used to reference it from GLSL) * @value: A pointer to a 2 component float vector * * Creates a new, 2 component, attribute whose value remains * constant across all the vertices of a primitive without needing to * duplicate the value for each vertex. * * The constants (value[0], value[1]) represent a 2 component float * vector which should have a corresponding declaration in GLSL code * like: * * [| * attribute vec2 name; * |] * * Return value: (transfer full): A newly allocated #CoglAttribute * representing the given constant vector. */ COGL_EXPORT CoglAttribute * cogl_attribute_new_const_2fv (CoglContext *context, const char *name, const float *value); /** * cogl_attribute_new_const_3fv: * @context: A #CoglContext * @name: The name of the attribute (used to reference it from GLSL) * @value: A pointer to a 3 component float vector * * Creates a new, 3 component, attribute whose value remains * constant across all the vertices of a primitive without needing to * duplicate the value for each vertex. * * The constants (value[0], value[1], value[2]) represent a 3 * component float vector which should have a corresponding * declaration in GLSL code like: * * [| * attribute vec3 name; * |] * * unless the built in name "cogl_normal_in" is being used where no * explicit GLSL declaration need be made. * * Return value: (transfer full): A newly allocated #CoglAttribute * representing the given constant vector. */ COGL_EXPORT CoglAttribute * cogl_attribute_new_const_3fv (CoglContext *context, const char *name, const float *value); /** * cogl_attribute_new_const_4fv: * @context: A #CoglContext * @name: The name of the attribute (used to reference it from GLSL) * @value: A pointer to a 4 component float vector * * Creates a new, 4 component, attribute whose value remains * constant across all the vertices of a primitive without needing to * duplicate the value for each vertex. * * The constants (value[0], value[1], value[2], value[3]) represent a * 4 component float vector which should have a corresponding * declaration in GLSL code like: * * [| * attribute vec4 name; * |] * * unless one of the built in names "cogl_color_in", * "cogl_tex_coord0_in or "cogl_tex_coord1_in" etc is being used where * no explicit GLSL declaration need be made. * * Return value: (transfer full): A newly allocated #CoglAttribute * representing the given constant vector. */ COGL_EXPORT CoglAttribute * cogl_attribute_new_const_4fv (CoglContext *context, const char *name, const float *value); /** * cogl_attribute_new_const_2x2fv: * @context: A #CoglContext * @name: The name of the attribute (used to reference it from GLSL) * @matrix2x2: A pointer to a 2 by 2 matrix * @transpose: Whether the matrix should be transposed on upload or * not * * Creates a new matrix attribute whose value remains constant * across all the vertices of a primitive without needing to duplicate * the value for each vertex. * * @matrix2x2 represent a square 2 by 2 matrix specified in * column-major order (each pair of consecutive numbers represents a * column) which should have a corresponding declaration in GLSL code * like: * * [| * attribute mat2 name; * |] * * If @transpose is %TRUE then all matrix components are rotated * around the diagonal of the matrix such that the first column * becomes the first row and the second column becomes the second row. * * Return value: (transfer full): A newly allocated #CoglAttribute * representing the given constant matrix. */ COGL_EXPORT CoglAttribute * cogl_attribute_new_const_2x2fv (CoglContext *context, const char *name, const float *matrix2x2, gboolean transpose); /** * cogl_attribute_new_const_3x3fv: * @context: A #CoglContext * @name: The name of the attribute (used to reference it from GLSL) * @matrix3x3: A pointer to a 3 by 3 matrix * @transpose: Whether the matrix should be transposed on upload or * not * * Creates a new matrix attribute whose value remains constant * across all the vertices of a primitive without needing to duplicate * the value for each vertex. * * @matrix3x3 represent a square 3 by 3 matrix specified in * column-major order (each triple of consecutive numbers represents a * column) which should have a corresponding declaration in GLSL code * like: * * [| * attribute mat3 name; * |] * * If @transpose is %TRUE then all matrix components are rotated * around the diagonal of the matrix such that the first column * becomes the first row and the second column becomes the second row * etc. * * Return value: (transfer full): A newly allocated #CoglAttribute * representing the given constant matrix. */ COGL_EXPORT CoglAttribute * cogl_attribute_new_const_3x3fv (CoglContext *context, const char *name, const float *matrix3x3, gboolean transpose); /** * cogl_attribute_new_const_4x4fv: * @context: A #CoglContext * @name: The name of the attribute (used to reference it from GLSL) * @matrix4x4: A pointer to a 4 by 4 matrix * @transpose: Whether the matrix should be transposed on upload or * not * * Creates a new matrix attribute whose value remains constant * across all the vertices of a primitive without needing to duplicate * the value for each vertex. * * @matrix4x4 represent a square 4 by 4 matrix specified in * column-major order (each 4-tuple of consecutive numbers represents a * column) which should have a corresponding declaration in GLSL code * like: * * [| * attribute mat4 name; * |] * * If @transpose is %TRUE then all matrix components are rotated * around the diagonal of the matrix such that the first column * becomes the first row and the second column becomes the second row * etc. * * Return value: (transfer full): A newly allocated #CoglAttribute * representing the given constant matrix. */ COGL_EXPORT CoglAttribute * cogl_attribute_new_const_4x4fv (CoglContext *context, const char *name, const float *matrix4x4, gboolean transpose); /** * cogl_attribute_set_normalized: * @attribute: A #CoglAttribute * @normalized: The new value for the normalized property. * * Sets whether fixed point attribute types are mapped to the range * 0→1. For example when this property is TRUE and a * %COGL_ATTRIBUTE_TYPE_UNSIGNED_BYTE type is used then the value 255 * will be mapped to 1.0. * * The default value of this property depends on the name of the * attribute. For the builtin properties cogl_color_in and * cogl_normal_in it will default to TRUE and for all other names it * will default to FALSE. */ COGL_EXPORT void cogl_attribute_set_normalized (CoglAttribute *attribute, gboolean normalized); /** * cogl_attribute_get_normalized: * @attribute: A #CoglAttribute * * Return value: the value of the normalized property set with * cogl_attribute_set_normalized(). */ COGL_EXPORT gboolean cogl_attribute_get_normalized (CoglAttribute *attribute); /** * cogl_attribute_get_buffer: * @attribute: A #CoglAttribute * * Return value: (transfer none): the #CoglAttributeBuffer that was * set with cogl_attribute_set_buffer() or cogl_attribute_new(). */ COGL_EXPORT CoglAttributeBuffer * cogl_attribute_get_buffer (CoglAttribute *attribute); /** * cogl_attribute_set_buffer: * @attribute: A #CoglAttribute * @attribute_buffer: A #CoglAttributeBuffer * * Sets a new #CoglAttributeBuffer for the attribute. */ COGL_EXPORT void cogl_attribute_set_buffer (CoglAttribute *attribute, CoglAttributeBuffer *attribute_buffer); /** * cogl_is_attribute: * @object: A #CoglObject * * Gets whether the given object references a #CoglAttribute. * * Return value: %TRUE if the @object references a #CoglAttribute, * %FALSE otherwise */ COGL_EXPORT gboolean cogl_is_attribute (void *object); G_END_DECLS #endif /* __COGL_ATTRIBUTE_H__ */