cogl: Expose Atlas API
Needed to build cogl-pango out of tree Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3909>
This commit is contained in:
parent
b035350ffd
commit
69d66eb82f
68
cogl/cogl/cogl-atlas-private.h
Normal file
68
cogl/cogl/cogl-atlas-private.h
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
/*
|
||||||
|
* Cogl
|
||||||
|
*
|
||||||
|
* A Low Level GPU Graphics and Utilities API
|
||||||
|
*
|
||||||
|
* Copyright (C) 2010,2011 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "cogl/cogl-atlas.h"
|
||||||
|
#include "cogl/cogl-rectangle-map.h"
|
||||||
|
|
||||||
|
struct _CoglAtlas
|
||||||
|
{
|
||||||
|
GObject parent_instance;
|
||||||
|
|
||||||
|
CoglRectangleMap *map;
|
||||||
|
CoglContext *context;
|
||||||
|
|
||||||
|
CoglTexture *texture;
|
||||||
|
CoglPixelFormat texture_format;
|
||||||
|
CoglAtlasFlags flags;
|
||||||
|
|
||||||
|
CoglAtlasUpdatePositionCallback update_position_cb;
|
||||||
|
|
||||||
|
GHookList pre_reorganize_callbacks;
|
||||||
|
GHookList post_reorganize_callbacks;
|
||||||
|
};
|
||||||
|
|
||||||
|
void
|
||||||
|
_cogl_atlas_remove (CoglAtlas *atlas,
|
||||||
|
const MtkRectangle *rectangle);
|
||||||
|
|
||||||
|
CoglTexture *
|
||||||
|
_cogl_atlas_copy_rectangle (CoglAtlas *atlas,
|
||||||
|
int x,
|
||||||
|
int y,
|
||||||
|
int width,
|
||||||
|
int height,
|
||||||
|
CoglPixelFormat format);
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
_cogl_atlas_remove_reorganize_callback (CoglAtlas *atlas,
|
||||||
|
GHookFunc pre_callback,
|
||||||
|
GHookFunc post_callback,
|
||||||
|
void *user_data);
|
@ -43,7 +43,7 @@
|
|||||||
#include "cogl/cogl-texture-driver.h"
|
#include "cogl/cogl-texture-driver.h"
|
||||||
#include "cogl/cogl-rectangle-map.h"
|
#include "cogl/cogl-rectangle-map.h"
|
||||||
#include "cogl/cogl-journal-private.h"
|
#include "cogl/cogl-journal-private.h"
|
||||||
#include "cogl/cogl-atlas.h"
|
#include "cogl/cogl-atlas-private.h"
|
||||||
#include "cogl/cogl-sub-texture.h"
|
#include "cogl/cogl-sub-texture.h"
|
||||||
#include "cogl/driver/gl/cogl-texture-gl-private.h"
|
#include "cogl/driver/gl/cogl-texture-gl-private.h"
|
||||||
|
|
||||||
|
@ -31,7 +31,7 @@
|
|||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
#include "cogl/cogl-atlas.h"
|
#include "cogl/cogl-atlas-private.h"
|
||||||
#include "cogl/cogl-rectangle-map.h"
|
#include "cogl/cogl-rectangle-map.h"
|
||||||
#include "cogl/cogl-context-private.h"
|
#include "cogl/cogl-context-private.h"
|
||||||
#include "cogl/cogl-texture-private.h"
|
#include "cogl/cogl-texture-private.h"
|
||||||
|
@ -28,7 +28,6 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "cogl/cogl-rectangle-map.h"
|
|
||||||
#include "cogl/cogl-texture.h"
|
#include "cogl/cogl-texture.h"
|
||||||
|
|
||||||
typedef void
|
typedef void
|
||||||
@ -53,23 +52,10 @@ G_DECLARE_FINAL_TYPE (CoglAtlas,
|
|||||||
ATLAS,
|
ATLAS,
|
||||||
GObject)
|
GObject)
|
||||||
|
|
||||||
struct _CoglAtlas
|
|
||||||
{
|
|
||||||
GObject parent_instance;
|
|
||||||
|
|
||||||
CoglRectangleMap *map;
|
|
||||||
CoglContext *context;
|
|
||||||
|
|
||||||
CoglTexture *texture;
|
|
||||||
CoglPixelFormat texture_format;
|
|
||||||
CoglAtlasFlags flags;
|
|
||||||
|
|
||||||
CoglAtlasUpdatePositionCallback update_position_cb;
|
|
||||||
|
|
||||||
GHookList pre_reorganize_callbacks;
|
|
||||||
GHookList post_reorganize_callbacks;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* cogl_atlas_new: (skip)
|
||||||
|
*/
|
||||||
COGL_EXPORT CoglAtlas *
|
COGL_EXPORT CoglAtlas *
|
||||||
cogl_atlas_new (CoglContext *context,
|
cogl_atlas_new (CoglContext *context,
|
||||||
CoglPixelFormat texture_format,
|
CoglPixelFormat texture_format,
|
||||||
@ -82,26 +68,11 @@ cogl_atlas_reserve_space (CoglAtlas *atlas,
|
|||||||
unsigned int height,
|
unsigned int height,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
void
|
/**
|
||||||
_cogl_atlas_remove (CoglAtlas *atlas,
|
* cogl_atlas_add_reorganize_callback: (skip)
|
||||||
const MtkRectangle *rectangle);
|
*/
|
||||||
|
|
||||||
CoglTexture *
|
|
||||||
_cogl_atlas_copy_rectangle (CoglAtlas *atlas,
|
|
||||||
int x,
|
|
||||||
int y,
|
|
||||||
int width,
|
|
||||||
int height,
|
|
||||||
CoglPixelFormat format);
|
|
||||||
|
|
||||||
COGL_EXPORT void
|
COGL_EXPORT void
|
||||||
cogl_atlas_add_reorganize_callback (CoglAtlas *atlas,
|
cogl_atlas_add_reorganize_callback (CoglAtlas *atlas,
|
||||||
GHookFunc pre_callback,
|
GHookFunc pre_callback,
|
||||||
GHookFunc post_callback,
|
GHookFunc post_callback,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
void
|
|
||||||
_cogl_atlas_remove_reorganize_callback (CoglAtlas *atlas,
|
|
||||||
GHookFunc pre_callback,
|
|
||||||
GHookFunc post_callback,
|
|
||||||
void *user_data);
|
|
||||||
|
@ -69,6 +69,7 @@
|
|||||||
#include "cogl/cogl-texture-2d.h"
|
#include "cogl/cogl-texture-2d.h"
|
||||||
#include "cogl/cogl-texture-2d-sliced.h"
|
#include "cogl/cogl-texture-2d-sliced.h"
|
||||||
#include "cogl/cogl-sub-texture.h"
|
#include "cogl/cogl-sub-texture.h"
|
||||||
|
#include "cogl/cogl-atlas.h"
|
||||||
#include "cogl/cogl-atlas-texture.h"
|
#include "cogl/cogl-atlas-texture.h"
|
||||||
#include "cogl/cogl-meta-texture.h"
|
#include "cogl/cogl-meta-texture.h"
|
||||||
#include "cogl/cogl-enum-types.h"
|
#include "cogl/cogl-enum-types.h"
|
||||||
|
@ -20,6 +20,7 @@ cogl_deprecated_headers = [
|
|||||||
|
|
||||||
cogl_headers = [
|
cogl_headers = [
|
||||||
'cogl.h',
|
'cogl.h',
|
||||||
|
'cogl-atlas.h',
|
||||||
'cogl-atlas-texture.h',
|
'cogl-atlas-texture.h',
|
||||||
'cogl-attribute-buffer.h',
|
'cogl-attribute-buffer.h',
|
||||||
'cogl-attribute.h',
|
'cogl-attribute.h',
|
||||||
@ -142,7 +143,7 @@ cogl_sources = [
|
|||||||
'cogl-atlas-texture-private.h',
|
'cogl-atlas-texture-private.h',
|
||||||
'cogl-atlas-texture.c',
|
'cogl-atlas-texture.c',
|
||||||
'cogl-atlas.c',
|
'cogl-atlas.c',
|
||||||
'cogl-atlas.h',
|
'cogl-atlas-private.h',
|
||||||
'cogl-attribute-buffer-private.h',
|
'cogl-attribute-buffer-private.h',
|
||||||
'cogl-attribute-buffer.c',
|
'cogl-attribute-buffer.c',
|
||||||
'cogl-attribute-private.h',
|
'cogl-attribute-private.h',
|
||||||
|
Loading…
x
Reference in New Issue
Block a user