Merge branch 'master' into blender2.8
[blender.git] / source / blender / editors / include / ED_image.h
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * The Original Code is Copyright (C) 2008 Blender Foundation.
19  * All rights reserved.
20  *
21  * Contributor(s): Blender Foundation
22  *
23  * ***** END GPL LICENSE BLOCK *****
24  */
25
26 /** \file ED_image.h
27  *  \ingroup editors
28  */
29
30 #ifndef __ED_IMAGE_H__
31 #define __ED_IMAGE_H__
32
33 struct SpaceImage;
34 struct bContext;
35 struct Image;
36 struct ImageUser;
37 struct ImBuf;
38 struct ToolSettings;
39 struct wmWindowManager;
40 struct ARegion;
41 struct Scene;
42 struct ViewLayer;
43
44 /* image_edit.c, exported for transform */
45 struct Image *ED_space_image(struct SpaceImage *sima);
46 void          ED_space_image_set(struct SpaceImage *sima, struct Scene *scene, struct Object *obedit, struct Image *ima);
47 struct Mask  *ED_space_image_get_mask(struct SpaceImage *sima);
48 void          ED_space_image_set_mask(struct bContext *C, struct SpaceImage *sima, struct Mask *mask);
49
50 bool ED_space_image_color_sample(struct SpaceImage *sima, struct ARegion *ar, int mval[2], float r_col[3]);
51 struct ImBuf *ED_space_image_acquire_buffer(struct SpaceImage *sima, void **r_lock);
52 void ED_space_image_release_buffer(struct SpaceImage *sima, struct ImBuf *ibuf, void *lock);
53 bool ED_space_image_has_buffer(struct SpaceImage *sima);
54
55 void ED_space_image_get_size(struct SpaceImage *sima, int *width, int *height);
56 void ED_space_image_get_size_fl(struct SpaceImage *sima, float size[2]);
57 void ED_space_image_get_aspect(struct SpaceImage *sima, float *aspx, float *aspy);
58 void ED_space_image_get_zoom(struct SpaceImage *sima, struct ARegion *ar, float *zoomx, float *zoomy);
59 void ED_space_image_get_uv_aspect(struct SpaceImage *sima, float *aspx, float *aspy);
60
61 void ED_space_image_scopes_update(const struct bContext *C, struct SpaceImage *sima, struct ImBuf *ibuf, bool use_view_settings);
62
63 void ED_space_image_paint_update(struct Main *bmain, struct wmWindowManager *wm, struct Scene *scene);
64 void ED_space_image_uv_sculpt_update(struct Main *bmain, struct wmWindowManager *wm, struct Scene *scene);
65
66 void ED_image_get_uv_aspect(struct Image *ima, struct ImageUser *iuser, float *aspx, float *aspy);
67 void ED_image_mouse_pos(struct SpaceImage *sima, struct ARegion *ar, const int mval[2], float co[2]);
68 void ED_image_point_pos(struct SpaceImage *sima, struct ARegion *ar, float x, float y, float *xr, float *yr);
69 void ED_image_point_pos__reverse(struct SpaceImage *sima, struct ARegion *ar, const float co[2], float r_co[2]);
70 bool ED_image_slot_cycle(struct Image *image, int direction);
71
72 bool ED_space_image_show_render(struct SpaceImage *sima);
73 bool ED_space_image_show_paint(struct SpaceImage *sima);
74 bool ED_space_image_show_uvedit(struct SpaceImage *sima, struct Object *obedit);
75
76 bool ED_space_image_paint_curve(const struct bContext *C);
77
78 bool ED_space_image_check_show_maskedit(struct SpaceImage *sima, struct ViewLayer *view_layer);
79 int ED_space_image_maskedit_poll(struct bContext *C);
80 int ED_space_image_maskedit_mask_poll(struct bContext *C);
81
82 void ED_image_draw_info(struct Scene *scene, struct ARegion *ar, bool color_manage, bool use_default_view, int channels, int x, int y,
83                         const unsigned char cp[4], const float fp[4], const float linearcol[4], int *zp, float *zpf);
84
85 bool ED_space_image_show_cache(struct SpaceImage *sima);
86
87 #endif /* __ED_IMAGE_H__ */
88