diff options
Diffstat (limited to 'source/blender/blenkernel/BKE_icons.h')
-rw-r--r-- | source/blender/blenkernel/BKE_icons.h | 38 |
1 files changed, 33 insertions, 5 deletions
diff --git a/source/blender/blenkernel/BKE_icons.h b/source/blender/blenkernel/BKE_icons.h index 9af0d96884a..763a3874d4e 100644 --- a/source/blender/blenkernel/BKE_icons.h +++ b/source/blender/blenkernel/BKE_icons.h @@ -48,10 +48,14 @@ typedef struct Icon Icon; struct PreviewImage; struct ID; +enum eIconSizes; + void BKE_icons_init(int first_dyn_id); /* return icon id for library object or create new icon if not found */ -int BKE_icon_getid(struct ID *id); +int BKE_icon_id_ensure(struct ID *id); + +int BKE_icon_preview_ensure(struct PreviewImage *preview); /* retrieve icon for id */ struct Icon *BKE_icon_get(int icon_id); @@ -60,8 +64,10 @@ struct Icon *BKE_icon_get(int icon_id); /* used for inserting the internal icons */ void BKE_icon_set(int icon_id, struct Icon *icon); -/* remove icon and free date if library object becomes invalid */ -void BKE_icon_delete(struct ID *id); +/* remove icon and free data if library object becomes invalid */ +void BKE_icon_id_delete(struct ID *id); + +void BKE_icon_delete(int icon_id); /* report changes - icon needs to be recalculated */ void BKE_icon_changed(int icon_id); @@ -75,8 +81,17 @@ void BKE_previewimg_freefunc(void *link); /* free the preview image */ void BKE_previewimg_free(struct PreviewImage **prv); +/* clear the preview image or icon, but does not free it */ +void BKE_previewimg_clear(struct PreviewImage *prv); + +/* clear the preview image or icon at a specific size */ +void BKE_previewimg_clear_single(struct PreviewImage *prv, enum eIconSizes size); + +/* get the preview from any pointer */ +struct PreviewImage **BKE_previewimg_id_get_p(struct ID *id); + /* free the preview image belonging to the id */ -void BKE_previewimg_free_id(struct ID *id); +void BKE_previewimg_id_free(struct ID *id); /* create a new preview image */ struct PreviewImage *BKE_previewimg_create(void); @@ -85,6 +100,19 @@ struct PreviewImage *BKE_previewimg_create(void); struct PreviewImage *BKE_previewimg_copy(struct PreviewImage *prv); /* retrieve existing or create new preview image */ -struct PreviewImage *BKE_previewimg_get(struct ID *id); +struct PreviewImage *BKE_previewimg_id_ensure(struct ID *id); + +void BKE_previewimg_ensure(struct PreviewImage *prv, const int size); + +struct PreviewImage *BKE_previewimg_cached_get(const char *name); + +struct PreviewImage *BKE_previewimg_cached_ensure(const char *name); + +struct PreviewImage *BKE_previewimg_cached_thumbnail_read( + const char *name, const char *path, const int source, bool force_update); + +void BKE_previewimg_cached_release(const char *name); + +#define ICON_RENDER_DEFAULT_HEIGHT 32 #endif /* __BKE_ICONS_H__ */ |