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
6 changed files with 79 additions and 38 deletions
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-rectangle-map.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/driver/gl/cogl-texture-gl-private.h"
|
||||
|
||||
|
|
|
@ -31,7 +31,7 @@
|
|||
|
||||
#include "config.h"
|
||||
|
||||
#include "cogl/cogl-atlas.h"
|
||||
#include "cogl/cogl-atlas-private.h"
|
||||
#include "cogl/cogl-rectangle-map.h"
|
||||
#include "cogl/cogl-context-private.h"
|
||||
#include "cogl/cogl-texture-private.h"
|
||||
|
|
|
@ -28,7 +28,6 @@
|
|||
|
||||
#pragma once
|
||||
|
||||
#include "cogl/cogl-rectangle-map.h"
|
||||
#include "cogl/cogl-texture.h"
|
||||
|
||||
typedef void
|
||||
|
@ -53,23 +52,10 @@ G_DECLARE_FINAL_TYPE (CoglAtlas,
|
|||
ATLAS,
|
||||
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_atlas_new (CoglContext *context,
|
||||
CoglPixelFormat texture_format,
|
||||
|
@ -82,26 +68,11 @@ cogl_atlas_reserve_space (CoglAtlas *atlas,
|
|||
unsigned int height,
|
||||
void *user_data);
|
||||
|
||||
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);
|
||||
|
||||
/**
|
||||
* cogl_atlas_add_reorganize_callback: (skip)
|
||||
*/
|
||||
COGL_EXPORT void
|
||||
cogl_atlas_add_reorganize_callback (CoglAtlas *atlas,
|
||||
GHookFunc pre_callback,
|
||||
GHookFunc post_callback,
|
||||
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-sliced.h"
|
||||
#include "cogl/cogl-sub-texture.h"
|
||||
#include "cogl/cogl-atlas.h"
|
||||
#include "cogl/cogl-atlas-texture.h"
|
||||
#include "cogl/cogl-meta-texture.h"
|
||||
#include "cogl/cogl-enum-types.h"
|
||||
|
|
|
@ -20,6 +20,7 @@ cogl_deprecated_headers = [
|
|||
|
||||
cogl_headers = [
|
||||
'cogl.h',
|
||||
'cogl-atlas.h',
|
||||
'cogl-atlas-texture.h',
|
||||
'cogl-attribute-buffer.h',
|
||||
'cogl-attribute.h',
|
||||
|
@ -142,7 +143,7 @@ cogl_sources = [
|
|||
'cogl-atlas-texture-private.h',
|
||||
'cogl-atlas-texture.c',
|
||||
'cogl-atlas.c',
|
||||
'cogl-atlas.h',
|
||||
'cogl-atlas-private.h',
|
||||
'cogl-attribute-buffer-private.h',
|
||||
'cogl-attribute-buffer.c',
|
||||
'cogl-attribute-private.h',
|
||||
|
|
Loading…
Reference in a new issue