forked from AuroraMiddleware/gtk
abef8d4860
Now that the autotools build folded the GDK/GSK bits into the main GTK+
DLL, there are some updates that need to be done for this. We need to:
-Fold the DllMain() of GDK-Win32 into the main GTK+ DllMain(), as we need
the HINSTANCE to register the window. We can't have two DllMain()'s in a
single DLL.
-Remove the GDK rc(.in) files, as that is not used anymore. Make the GTK+
.rc(.in) file load the gtk.ico GTK+ logo file instead so that we still
get the GTK+ logo for the application icon by default. Update the
autotools build files as well.
-Revert commit b9f9980
as LRN pointed out in comment 25 in bug 773299, as
GTK+ is now a monolithic DLL, and we ought not to export this private
function.
https://bugzilla.gnome.org/show_bug.cgi?id=773299
108 lines
2.8 KiB
C
108 lines
2.8 KiB
C
#ifndef __GSK_RENDER_NODE_PRIVATE_H__
|
|
#define __GSK_RENDER_NODE_PRIVATE_H__
|
|
|
|
#include "gskrendernode.h"
|
|
#include <cairo.h>
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
#define GSK_RENDER_NODE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GSK_TYPE_RENDER_NODE, GskRenderNodeClass))
|
|
#define GSK_IS_RENDER_NODE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GSK_TYPE_RENDER_NODE))
|
|
#define GSK_RENDER_NODE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GSK_TYPE_RENDER_NODE, GskRenderNodeClass))
|
|
|
|
struct _GskRenderNode
|
|
{
|
|
GTypeInstance parent_instance;
|
|
|
|
volatile int ref_count;
|
|
|
|
/* The graph */
|
|
GskRenderNode *parent;
|
|
GskRenderNode *first_child;
|
|
GskRenderNode *last_child;
|
|
GskRenderNode *prev_sibling;
|
|
GskRenderNode *next_sibling;
|
|
|
|
int n_children;
|
|
|
|
/* Use for debugging */
|
|
char *name;
|
|
|
|
/* Tag updated when adding/removing children */
|
|
gint64 age;
|
|
|
|
/* The contents of the node as a Cairo surface */
|
|
cairo_surface_t *surface;
|
|
|
|
/* The contents of the node as a GL surface */
|
|
int texture_id;
|
|
|
|
/* Paint opacity */
|
|
double opacity;
|
|
|
|
/* Blend mode */
|
|
GskBlendMode blend_mode;
|
|
|
|
/* Scaling filters */
|
|
GskScalingFilter min_filter;
|
|
GskScalingFilter mag_filter;
|
|
|
|
/* Clip rectangle */
|
|
graphene_rect_t bounds;
|
|
|
|
/* Transformations relative to the root of the scene */
|
|
graphene_matrix_t world_matrix;
|
|
|
|
/* Transformations applied to the node */
|
|
graphene_matrix_t transform;
|
|
|
|
graphene_point3d_t anchor_point;
|
|
|
|
/* Bit fields; leave at the end */
|
|
gboolean is_mutable : 1;
|
|
gboolean hidden : 1;
|
|
gboolean opaque : 1;
|
|
gboolean transform_set : 1;
|
|
gboolean needs_world_matrix_update : 1;
|
|
};
|
|
|
|
struct _GskRenderNodeClass
|
|
{
|
|
GTypeClass parent_class;
|
|
|
|
void (* finalize) (GskRenderNode *node);
|
|
};
|
|
|
|
GskRenderNode *gsk_render_node_new (void);
|
|
|
|
void gsk_render_node_make_immutable (GskRenderNode *node);
|
|
|
|
void gsk_render_node_get_bounds (GskRenderNode *node,
|
|
graphene_rect_t *frame);
|
|
void gsk_render_node_get_transform (GskRenderNode *node,
|
|
graphene_matrix_t *mv);
|
|
double gsk_render_node_get_opacity (GskRenderNode *node);
|
|
|
|
cairo_surface_t *gsk_render_node_get_surface (GskRenderNode *node);
|
|
|
|
int gsk_render_node_get_texture (GskRenderNode *node);
|
|
|
|
gboolean gsk_render_node_has_surface (GskRenderNode *node);
|
|
gboolean gsk_render_node_has_texture (GskRenderNode *node);
|
|
|
|
GskBlendMode gsk_render_node_get_blend_mode (GskRenderNode *node);
|
|
|
|
GskRenderNode *gsk_render_node_get_toplevel (GskRenderNode *node);
|
|
|
|
void gsk_render_node_update_world_matrix (GskRenderNode *node,
|
|
gboolean force);
|
|
|
|
void gsk_render_node_get_world_matrix (GskRenderNode *node,
|
|
graphene_matrix_t *mv);
|
|
|
|
int gsk_render_node_get_size (GskRenderNode *root);
|
|
|
|
G_END_DECLS
|
|
|
|
#endif /* __GSK_RENDER_NODE_PRIVATE_H__ */
|