mirror of
https://github.com/brl/mutter.git
synced 2025-01-16 06:32:45 +00:00
863163cc6e
- Make Texture a parent GObject class and move the vtable funcs as vfuncs instead of an interface as we would like to have dispose free the TextureLoader. - Make the various texture sub-types inherit from it. - Make all the sub-types constructors return a CoglTexture instead of their respective specific type. As most of the times, the used functions accept a CoglTexture, like all the GTK widgets constructors returning GtkWidget. - Fix up the basics of gi-docgen for all these types. - Remove CoglPrimitiveTexture as it is useless: It is just a texture underhood. - Remove CoglMetaTexture: for the exact same reason as above. - Switch various memory management functions to use g_ variant instead of the cogl_ one Note we would still want to get rid of the _cogl_texture_init which is something for the next commit Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3193>
172 lines
5.6 KiB
C
172 lines
5.6 KiB
C
/*
|
|
* Clutter.
|
|
*
|
|
* An OpenGL based 'interactive image' library.
|
|
*
|
|
* Copyright (C) 2012 Intel Corporation.
|
|
* Copyright (C) 2021 Robert Mader.
|
|
*
|
|
* This 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 2 of the License, or (at your option) any later version.
|
|
*
|
|
* This 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 library. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* Author:
|
|
* Emmanuele Bassi <ebassi@linux.intel.com>
|
|
* Robert Mader <robert.mader@posteo.de>
|
|
*/
|
|
|
|
#include "clutter/clutter-build-config.h"
|
|
|
|
#include "clutter/clutter-texture-content.h"
|
|
|
|
#include "clutter/clutter-actor-private.h"
|
|
#include "clutter/clutter-content-private.h"
|
|
#include "clutter/clutter-paint-node.h"
|
|
|
|
struct _ClutterTextureContent
|
|
{
|
|
GObject parent_instance;
|
|
|
|
CoglTexture *texture;
|
|
};
|
|
|
|
static void clutter_content_iface_init (ClutterContentInterface *iface);
|
|
|
|
G_DEFINE_TYPE_WITH_CODE (ClutterTextureContent, clutter_texture_content,
|
|
G_TYPE_OBJECT,
|
|
G_IMPLEMENT_INTERFACE (CLUTTER_TYPE_CONTENT,
|
|
clutter_content_iface_init))
|
|
|
|
static void
|
|
clutter_texture_content_finalize (GObject *gobject)
|
|
{
|
|
ClutterTextureContent *texture_content = CLUTTER_TEXTURE_CONTENT (gobject);
|
|
|
|
g_clear_object (&texture_content->texture);
|
|
|
|
G_OBJECT_CLASS (clutter_texture_content_parent_class)->finalize (gobject);
|
|
}
|
|
|
|
static void
|
|
clutter_texture_content_class_init (ClutterTextureContentClass *klass)
|
|
{
|
|
G_OBJECT_CLASS (klass)->finalize = clutter_texture_content_finalize;
|
|
}
|
|
|
|
static void
|
|
clutter_texture_content_init (ClutterTextureContent *texture_content)
|
|
{
|
|
}
|
|
|
|
static void
|
|
clutter_texture_content_paint_content (ClutterContent *content,
|
|
ClutterActor *actor,
|
|
ClutterPaintNode *root,
|
|
ClutterPaintContext *paint_context)
|
|
{
|
|
ClutterTextureContent *texture_content = CLUTTER_TEXTURE_CONTENT (content);
|
|
ClutterPaintNode *node;
|
|
|
|
node = clutter_actor_create_texture_paint_node (actor,
|
|
texture_content->texture);
|
|
clutter_paint_node_set_static_name (node, "Texture Content");
|
|
clutter_paint_node_add_child (root, node);
|
|
clutter_paint_node_unref (node);
|
|
}
|
|
|
|
static gboolean
|
|
clutter_texture_content_get_preferred_size (ClutterContent *content,
|
|
float *width,
|
|
float *height)
|
|
{
|
|
ClutterTextureContent *texture_content = CLUTTER_TEXTURE_CONTENT (content);
|
|
|
|
if (width != NULL)
|
|
*width = cogl_texture_get_width (texture_content->texture);
|
|
|
|
if (height != NULL)
|
|
*height = cogl_texture_get_height (texture_content->texture);
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
static void
|
|
clutter_content_iface_init (ClutterContentInterface *iface)
|
|
{
|
|
iface->get_preferred_size = clutter_texture_content_get_preferred_size;
|
|
iface->paint_content = clutter_texture_content_paint_content;
|
|
}
|
|
|
|
/**
|
|
* clutter_texture_content_new_from_texture:
|
|
* @texture: a #CoglTexture
|
|
* @clip: (nullable): A clipping rectangle
|
|
*
|
|
* Creates a new [class@TextureContent] instance for @texture, taking an
|
|
* internal reference to @texture.
|
|
*
|
|
* If you change the contents of the [class@Cogl.Texture] you will need
|
|
* to manually invalidate the @texture_content with [method@Content.invalidate]
|
|
* in order to update the actors using @texture_content as their content.
|
|
*
|
|
* Return value: (transfer full): the newly created #ClutterTextureContent instance.
|
|
* Use [method@GObject.Object.unref] when done.
|
|
*/
|
|
ClutterContent *
|
|
clutter_texture_content_new_from_texture (CoglTexture *texture,
|
|
MtkRectangle *clip)
|
|
{
|
|
ClutterTextureContent *texture_content;
|
|
CoglContext *cogl_context =
|
|
clutter_backend_get_cogl_context (clutter_get_default_backend ());
|
|
|
|
g_return_val_if_fail (texture != NULL, NULL);
|
|
|
|
texture_content = g_object_new (CLUTTER_TYPE_TEXTURE_CONTENT, NULL);
|
|
|
|
if (clip)
|
|
{
|
|
texture_content->texture = cogl_sub_texture_new (cogl_context,
|
|
texture,
|
|
clip->x,
|
|
clip->y,
|
|
clip->width,
|
|
clip->height);
|
|
}
|
|
else
|
|
{
|
|
texture_content->texture = g_object_ref (texture);
|
|
}
|
|
|
|
return CLUTTER_CONTENT (texture_content);
|
|
}
|
|
|
|
/**
|
|
* clutter_texture_content_get_texture:
|
|
* @texture_content: a #ClutterTextureContent
|
|
*
|
|
* Retrieves a pointer to the [class@Cogl.Texture] used by @texture_content.
|
|
*
|
|
* If you change the contents of the returned [class@Cogl.Texture] you will need
|
|
* to manually invalidate the @texture_content with [method@Content.invalidate]
|
|
* in order to update the actors using @texture_content as their content.
|
|
*
|
|
* Return value: (transfer none): a pointer to the [class@Cogl.Texture]
|
|
*/
|
|
CoglTexture *
|
|
clutter_texture_content_get_texture (ClutterTextureContent *texture_content)
|
|
{
|
|
g_return_val_if_fail (CLUTTER_IS_TEXTURE_CONTENT (texture_content), NULL);
|
|
|
|
return texture_content->texture;
|
|
}
|