Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'source/blender/draw/modes/edit_text_mode.c')
-rw-r--r--source/blender/draw/modes/edit_text_mode.c543
1 files changed, 272 insertions, 271 deletions
diff --git a/source/blender/draw/modes/edit_text_mode.c b/source/blender/draw/modes/edit_text_mode.c
index caebc94f3ce..5f44a74b24e 100644
--- a/source/blender/draw/modes/edit_text_mode.c
+++ b/source/blender/draw/modes/edit_text_mode.c
@@ -43,67 +43,67 @@
* for EDIT_TEXT_PassList */
typedef struct EDIT_TEXT_PassList {
- /* Declare all passes here and init them in
- * EDIT_TEXT_cache_init().
- * Only contains (DRWPass *) */
- struct DRWPass *wire_pass;
- struct DRWPass *overlay_select_pass;
- struct DRWPass *overlay_cursor_pass;
- struct DRWPass *text_box_pass;
+ /* Declare all passes here and init them in
+ * EDIT_TEXT_cache_init().
+ * Only contains (DRWPass *) */
+ struct DRWPass *wire_pass;
+ struct DRWPass *overlay_select_pass;
+ struct DRWPass *overlay_cursor_pass;
+ struct DRWPass *text_box_pass;
} EDIT_TEXT_PassList;
typedef struct EDIT_TEXT_FramebufferList {
- /* Contains all framebuffer objects needed by this engine.
- * Only contains (GPUFrameBuffer *) */
- struct GPUFrameBuffer *fb;
+ /* Contains all framebuffer objects needed by this engine.
+ * Only contains (GPUFrameBuffer *) */
+ struct GPUFrameBuffer *fb;
} EDIT_TEXT_FramebufferList;
typedef struct EDIT_TEXT_TextureList {
- /* Contains all framebuffer textures / utility textures
- * needed by this engine. Only viewport specific textures
- * (not per object). Only contains (GPUTexture *) */
- struct GPUTexture *texture;
+ /* Contains all framebuffer textures / utility textures
+ * needed by this engine. Only viewport specific textures
+ * (not per object). Only contains (GPUTexture *) */
+ struct GPUTexture *texture;
} EDIT_TEXT_TextureList;
typedef struct EDIT_TEXT_StorageList {
- /* Contains any other memory block that the engine needs.
- * Only directly MEM_(m/c)allocN'ed blocks because they are
- * free with MEM_freeN() when viewport is freed.
- * (not per object) */
- struct CustomStruct *block;
- struct EDIT_TEXT_PrivateData *g_data;
+ /* Contains any other memory block that the engine needs.
+ * Only directly MEM_(m/c)allocN'ed blocks because they are
+ * free with MEM_freeN() when viewport is freed.
+ * (not per object) */
+ struct CustomStruct *block;
+ struct EDIT_TEXT_PrivateData *g_data;
} EDIT_TEXT_StorageList;
typedef struct EDIT_TEXT_Data {
- /* Struct returned by DRW_viewport_engine_data_ensure.
- * If you don't use one of these, just make it a (void *) */
- // void *fbl;
- void *engine_type; /* Required */
- EDIT_TEXT_FramebufferList *fbl;
- EDIT_TEXT_TextureList *txl;
- EDIT_TEXT_PassList *psl;
- EDIT_TEXT_StorageList *stl;
+ /* Struct returned by DRW_viewport_engine_data_ensure.
+ * If you don't use one of these, just make it a (void *) */
+ // void *fbl;
+ void *engine_type; /* Required */
+ EDIT_TEXT_FramebufferList *fbl;
+ EDIT_TEXT_TextureList *txl;
+ EDIT_TEXT_PassList *psl;
+ EDIT_TEXT_StorageList *stl;
} EDIT_TEXT_Data;
/* *********** STATIC *********** */
static struct {
- /* Custom shaders :
- * Add sources to source/blender/draw/modes/shaders
- * init in EDIT_TEXT_engine_init();
- * free in EDIT_TEXT_engine_free(); */
- GPUShader *wire_sh;
- GPUShader *overlay_select_sh;
- GPUShader *overlay_cursor_sh;
+ /* Custom shaders :
+ * Add sources to source/blender/draw/modes/shaders
+ * init in EDIT_TEXT_engine_init();
+ * free in EDIT_TEXT_engine_free(); */
+ GPUShader *wire_sh;
+ GPUShader *overlay_select_sh;
+ GPUShader *overlay_cursor_sh;
} e_data = {NULL}; /* Engine data */
typedef struct EDIT_TEXT_PrivateData {
- /* resulting curve as 'wire' for fast editmode drawing */
- DRWShadingGroup *wire_shgrp;
- DRWShadingGroup *overlay_select_shgrp;
- DRWShadingGroup *overlay_cursor_shgrp;
- DRWShadingGroup *box_shgrp;
- DRWShadingGroup *box_active_shgrp;
+ /* resulting curve as 'wire' for fast editmode drawing */
+ DRWShadingGroup *wire_shgrp;
+ DRWShadingGroup *overlay_select_shgrp;
+ DRWShadingGroup *overlay_cursor_shgrp;
+ DRWShadingGroup *box_shgrp;
+ DRWShadingGroup *box_active_shgrp;
} EDIT_TEXT_PrivateData; /* Transient data */
/* *********** FUNCTIONS *********** */
@@ -113,285 +113,285 @@ typedef struct EDIT_TEXT_PrivateData {
* (Optional) */
static void EDIT_TEXT_engine_init(void *vedata)
{
- EDIT_TEXT_TextureList *txl = ((EDIT_TEXT_Data *)vedata)->txl;
- EDIT_TEXT_FramebufferList *fbl = ((EDIT_TEXT_Data *)vedata)->fbl;
- EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
-
- UNUSED_VARS(txl, fbl, stl);
-
- /* Init Framebuffers like this: order is attachment order (for color texs) */
- /*
- * DRWFboTexture tex[2] = {{&txl->depth, GPU_DEPTH_COMPONENT24, 0},
- * {&txl->color, GPU_RGBA8, DRW_TEX_FILTER}};
- */
-
- /* DRW_framebuffer_init takes care of checking if
- * the framebuffer is valid and has the right size*/
- /*
- * float *viewport_size = DRW_viewport_size_get();
- * DRW_framebuffer_init(&fbl->occlude_wire_fb,
- * (int)viewport_size[0], (int)viewport_size[1],
- * tex, 2);
- */
-
- if (!e_data.wire_sh) {
- e_data.wire_sh = GPU_shader_get_builtin_shader(GPU_SHADER_3D_UNIFORM_COLOR);
- }
-
- if (!e_data.overlay_select_sh) {
- e_data.overlay_select_sh = GPU_shader_get_builtin_shader(GPU_SHADER_3D_UNIFORM_COLOR);
- }
-
- if (!e_data.overlay_cursor_sh) {
- e_data.overlay_cursor_sh = GPU_shader_get_builtin_shader(GPU_SHADER_3D_UNIFORM_COLOR);
- }
+ EDIT_TEXT_TextureList *txl = ((EDIT_TEXT_Data *)vedata)->txl;
+ EDIT_TEXT_FramebufferList *fbl = ((EDIT_TEXT_Data *)vedata)->fbl;
+ EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
+
+ UNUSED_VARS(txl, fbl, stl);
+
+ /* Init Framebuffers like this: order is attachment order (for color texs) */
+ /*
+ * DRWFboTexture tex[2] = {{&txl->depth, GPU_DEPTH_COMPONENT24, 0},
+ * {&txl->color, GPU_RGBA8, DRW_TEX_FILTER}};
+ */
+
+ /* DRW_framebuffer_init takes care of checking if
+ * the framebuffer is valid and has the right size*/
+ /*
+ * float *viewport_size = DRW_viewport_size_get();
+ * DRW_framebuffer_init(&fbl->occlude_wire_fb,
+ * (int)viewport_size[0], (int)viewport_size[1],
+ * tex, 2);
+ */
+
+ if (!e_data.wire_sh) {
+ e_data.wire_sh = GPU_shader_get_builtin_shader(GPU_SHADER_3D_UNIFORM_COLOR);
+ }
+
+ if (!e_data.overlay_select_sh) {
+ e_data.overlay_select_sh = GPU_shader_get_builtin_shader(GPU_SHADER_3D_UNIFORM_COLOR);
+ }
+
+ if (!e_data.overlay_cursor_sh) {
+ e_data.overlay_cursor_sh = GPU_shader_get_builtin_shader(GPU_SHADER_3D_UNIFORM_COLOR);
+ }
}
/* Here init all passes and shading groups
* Assume that all Passes are NULL */
static void EDIT_TEXT_cache_init(void *vedata)
{
- const DRWContextState *draw_ctx = DRW_context_state_get();
- EDIT_TEXT_PassList *psl = ((EDIT_TEXT_Data *)vedata)->psl;
- EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
-
-
- if (!stl->g_data) {
- /* Alloc transient pointers */
- stl->g_data = MEM_mallocN(sizeof(*stl->g_data), __func__);
- }
-
- {
- /* Text outline (fast drawing!) */
- psl->wire_pass = DRW_pass_create(
- "Font Wire",
- DRW_STATE_WRITE_COLOR | DRW_STATE_WRITE_DEPTH | DRW_STATE_DEPTH_LESS_EQUAL | DRW_STATE_WIRE);
- stl->g_data->wire_shgrp = DRW_shgroup_create(e_data.wire_sh, psl->wire_pass);
-
- psl->overlay_select_pass = DRW_pass_create(
- "Font Select",
- DRW_STATE_WRITE_COLOR | DRW_STATE_WRITE_DEPTH);
- stl->g_data->overlay_select_shgrp = DRW_shgroup_create(e_data.overlay_select_sh, psl->overlay_select_pass);
-
- psl->overlay_cursor_pass = DRW_pass_create(
- "Font Cursor",
- DRW_STATE_WRITE_COLOR | DRW_STATE_WRITE_DEPTH);
- stl->g_data->overlay_cursor_shgrp = DRW_shgroup_create(e_data.overlay_cursor_sh, psl->overlay_cursor_pass);
-
- psl->text_box_pass = DRW_pass_create(
- "Font Text Boxes",
- DRW_STATE_WRITE_COLOR | DRW_STATE_WRITE_DEPTH);
- stl->g_data->box_shgrp = shgroup_dynlines_dashed_uniform_color(psl->text_box_pass, G_draw.block.colorWire, draw_ctx->sh_cfg);
- stl->g_data->box_active_shgrp = shgroup_dynlines_dashed_uniform_color(psl->text_box_pass, G_draw.block.colorActive, draw_ctx->sh_cfg);
- }
+ const DRWContextState *draw_ctx = DRW_context_state_get();
+ EDIT_TEXT_PassList *psl = ((EDIT_TEXT_Data *)vedata)->psl;
+ EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
+
+ if (!stl->g_data) {
+ /* Alloc transient pointers */
+ stl->g_data = MEM_mallocN(sizeof(*stl->g_data), __func__);
+ }
+
+ {
+ /* Text outline (fast drawing!) */
+ psl->wire_pass = DRW_pass_create("Font Wire",
+ DRW_STATE_WRITE_COLOR | DRW_STATE_WRITE_DEPTH |
+ DRW_STATE_DEPTH_LESS_EQUAL | DRW_STATE_WIRE);
+ stl->g_data->wire_shgrp = DRW_shgroup_create(e_data.wire_sh, psl->wire_pass);
+
+ psl->overlay_select_pass = DRW_pass_create("Font Select",
+ DRW_STATE_WRITE_COLOR | DRW_STATE_WRITE_DEPTH);
+ stl->g_data->overlay_select_shgrp = DRW_shgroup_create(e_data.overlay_select_sh,
+ psl->overlay_select_pass);
+
+ psl->overlay_cursor_pass = DRW_pass_create("Font Cursor",
+ DRW_STATE_WRITE_COLOR | DRW_STATE_WRITE_DEPTH);
+ stl->g_data->overlay_cursor_shgrp = DRW_shgroup_create(e_data.overlay_cursor_sh,
+ psl->overlay_cursor_pass);
+
+ psl->text_box_pass = DRW_pass_create("Font Text Boxes",
+ DRW_STATE_WRITE_COLOR | DRW_STATE_WRITE_DEPTH);
+ stl->g_data->box_shgrp = shgroup_dynlines_dashed_uniform_color(
+ psl->text_box_pass, G_draw.block.colorWire, draw_ctx->sh_cfg);
+ stl->g_data->box_active_shgrp = shgroup_dynlines_dashed_uniform_color(
+ psl->text_box_pass, G_draw.block.colorActive, draw_ctx->sh_cfg);
+ }
}
/* Use 2D quad corners to create a matrix that set
* a [-1..1] quad at the right position. */
static void v2_quad_corners_to_mat4(float corners[4][2], float r_mat[4][4])
{
- unit_m4(r_mat);
- sub_v2_v2v2(r_mat[0], corners[1], corners[0]);
- sub_v2_v2v2(r_mat[1], corners[3], corners[0]);
- mul_v2_fl(r_mat[0], 0.5f);
- mul_v2_fl(r_mat[1], 0.5f);
- copy_v2_v2(r_mat[3], corners[0]);
- add_v2_v2(r_mat[3], r_mat[0]);
- add_v2_v2(r_mat[3], r_mat[1]);
+ unit_m4(r_mat);
+ sub_v2_v2v2(r_mat[0], corners[1], corners[0]);
+ sub_v2_v2v2(r_mat[1], corners[3], corners[0]);
+ mul_v2_fl(r_mat[0], 0.5f);
+ mul_v2_fl(r_mat[1], 0.5f);
+ copy_v2_v2(r_mat[3], corners[0]);
+ add_v2_v2(r_mat[3], r_mat[0]);
+ add_v2_v2(r_mat[3], r_mat[1]);
}
static void edit_text_cache_populate_select(void *vedata, Object *ob)
{
- EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
- const Curve *cu = ob->data;
- EditFont *ef = cu->editfont;
- float final_mat[4][4], box[4][2];
- struct GPUBatch *geom = DRW_cache_quad_get();
-
- for (int i = 0; i < ef->selboxes_len; i++) {
- EditFontSelBox *sb = &ef->selboxes[i];
-
- float selboxw;
- if (i + 1 != ef->selboxes_len) {
- if (ef->selboxes[i + 1].y == sb->y) {
- selboxw = ef->selboxes[i + 1].x - sb->x;
- }
- else {
- selboxw = sb->w;
- }
- }
- else {
- selboxw = sb->w;
- }
- /* NOTE: v2_quad_corners_to_mat4 don't need the 3rd corner. */
- if (sb->rot == 0.0f) {
- copy_v2_fl2(box[0], sb->x, sb->y);
- copy_v2_fl2(box[1], sb->x + selboxw, sb->y);
- copy_v2_fl2(box[3], sb->x, sb->y + sb->h);
- }
- else {
- float mat[2][2];
- angle_to_mat2(mat, sb->rot);
- copy_v2_fl2(box[0], sb->x, sb->y);
- mul_v2_v2fl(box[1], mat[0], selboxw);
- add_v2_v2(box[1], &sb->x);
- mul_v2_v2fl(box[3], mat[1], sb->h);
- add_v2_v2(box[3], &sb->x);
- }
- v2_quad_corners_to_mat4(box, final_mat);
- mul_m4_m4m4(final_mat, ob->obmat, final_mat);
-
- DRW_shgroup_call_add(stl->g_data->overlay_select_shgrp, geom, final_mat);
- }
+ EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
+ const Curve *cu = ob->data;
+ EditFont *ef = cu->editfont;
+ float final_mat[4][4], box[4][2];
+ struct GPUBatch *geom = DRW_cache_quad_get();
+
+ for (int i = 0; i < ef->selboxes_len; i++) {
+ EditFontSelBox *sb = &ef->selboxes[i];
+
+ float selboxw;
+ if (i + 1 != ef->selboxes_len) {
+ if (ef->selboxes[i + 1].y == sb->y) {
+ selboxw = ef->selboxes[i + 1].x - sb->x;
+ }
+ else {
+ selboxw = sb->w;
+ }
+ }
+ else {
+ selboxw = sb->w;
+ }
+ /* NOTE: v2_quad_corners_to_mat4 don't need the 3rd corner. */
+ if (sb->rot == 0.0f) {
+ copy_v2_fl2(box[0], sb->x, sb->y);
+ copy_v2_fl2(box[1], sb->x + selboxw, sb->y);
+ copy_v2_fl2(box[3], sb->x, sb->y + sb->h);
+ }
+ else {
+ float mat[2][2];
+ angle_to_mat2(mat, sb->rot);
+ copy_v2_fl2(box[0], sb->x, sb->y);
+ mul_v2_v2fl(box[1], mat[0], selboxw);
+ add_v2_v2(box[1], &sb->x);
+ mul_v2_v2fl(box[3], mat[1], sb->h);
+ add_v2_v2(box[3], &sb->x);
+ }
+ v2_quad_corners_to_mat4(box, final_mat);
+ mul_m4_m4m4(final_mat, ob->obmat, final_mat);
+
+ DRW_shgroup_call_add(stl->g_data->overlay_select_shgrp, geom, final_mat);
+ }
}
static void edit_text_cache_populate_cursor(void *vedata, Object *ob)
{
- EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
- const Curve *cu = ob->data;
- EditFont *edit_font = cu->editfont;
- float (*cursor)[2] = edit_font->textcurs;
- float mat[4][4];
+ EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
+ const Curve *cu = ob->data;
+ EditFont *edit_font = cu->editfont;
+ float(*cursor)[2] = edit_font->textcurs;
+ float mat[4][4];
- v2_quad_corners_to_mat4(cursor, mat);
- mul_m4_m4m4(mat, ob->obmat, mat);
+ v2_quad_corners_to_mat4(cursor, mat);
+ mul_m4_m4m4(mat, ob->obmat, mat);
- struct GPUBatch *geom = DRW_cache_quad_get();
- DRW_shgroup_call_add(stl->g_data->overlay_cursor_shgrp, geom, mat);
+ struct GPUBatch *geom = DRW_cache_quad_get();
+ DRW_shgroup_call_add(stl->g_data->overlay_cursor_shgrp, geom, mat);
}
static void edit_text_cache_populate_boxes(void *vedata, Object *ob)
{
- EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
- const Curve *cu = ob->data;
+ EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
+ const Curve *cu = ob->data;
- DRWShadingGroup *shading_groups[] = {
- stl->g_data->box_active_shgrp,
- stl->g_data->box_shgrp,
- };
+ DRWShadingGroup *shading_groups[] = {
+ stl->g_data->box_active_shgrp,
+ stl->g_data->box_shgrp,
+ };
- float vec[3], vec1[3], vec2[3];
- for (int i = 0; i < cu->totbox; i++) {
- TextBox *tb = &cu->tb[i];
+ float vec[3], vec1[3], vec2[3];
+ for (int i = 0; i < cu->totbox; i++) {
+ TextBox *tb = &cu->tb[i];
- if ((tb->w == 0.0f) && (tb->h == 0.0f)) {
- continue;
- }
+ if ((tb->w == 0.0f) && (tb->h == 0.0f)) {
+ continue;
+ }
- const bool is_active = i == (cu->actbox - 1);
- DRWShadingGroup *shading_group = shading_groups[is_active ? 0 : 1];
+ const bool is_active = i == (cu->actbox - 1);
+ DRWShadingGroup *shading_group = shading_groups[is_active ? 0 : 1];
- vec[0] = cu->xof + tb->x;
- vec[1] = cu->yof + tb->y + cu->fsize_realtime;
- vec[2] = 0.001;
+ vec[0] = cu->xof + tb->x;
+ vec[1] = cu->yof + tb->y + cu->fsize_realtime;
+ vec[2] = 0.001;
- mul_v3_m4v3(vec1, ob->obmat, vec);
- vec[0] += tb->w;
- mul_v3_m4v3(vec2, ob->obmat, vec);
+ mul_v3_m4v3(vec1, ob->obmat, vec);
+ vec[0] += tb->w;
+ mul_v3_m4v3(vec2, ob->obmat, vec);
- DRW_shgroup_call_dynamic_add(shading_group, vec1);
- DRW_shgroup_call_dynamic_add(shading_group, vec2);
+ DRW_shgroup_call_dynamic_add(shading_group, vec1);
+ DRW_shgroup_call_dynamic_add(shading_group, vec2);
- vec[1] -= tb->h;
- copy_v3_v3(vec1, vec2);
- mul_v3_m4v3(vec2, ob->obmat, vec);
+ vec[1] -= tb->h;
+ copy_v3_v3(vec1, vec2);
+ mul_v3_m4v3(vec2, ob->obmat, vec);
- DRW_shgroup_call_dynamic_add(shading_group, vec1);
- DRW_shgroup_call_dynamic_add(shading_group, vec2);
+ DRW_shgroup_call_dynamic_add(shading_group, vec1);
+ DRW_shgroup_call_dynamic_add(shading_group, vec2);
- vec[0] -= tb->w;
- copy_v3_v3(vec1, vec2);
- mul_v3_m4v3(vec2, ob->obmat, vec);
+ vec[0] -= tb->w;
+ copy_v3_v3(vec1, vec2);
+ mul_v3_m4v3(vec2, ob->obmat, vec);
- DRW_shgroup_call_dynamic_add(shading_group, vec1);
- DRW_shgroup_call_dynamic_add(shading_group, vec2);
+ DRW_shgroup_call_dynamic_add(shading_group, vec1);
+ DRW_shgroup_call_dynamic_add(shading_group, vec2);
- vec[1] += tb->h;
- copy_v3_v3(vec1, vec2);
- mul_v3_m4v3(vec2, ob->obmat, vec);
+ vec[1] += tb->h;
+ copy_v3_v3(vec1, vec2);
+ mul_v3_m4v3(vec2, ob->obmat, vec);
- DRW_shgroup_call_dynamic_add(shading_group, vec1);
- DRW_shgroup_call_dynamic_add(shading_group, vec2);
- }
+ DRW_shgroup_call_dynamic_add(shading_group, vec1);
+ DRW_shgroup_call_dynamic_add(shading_group, vec2);
+ }
}
/* Add geometry to shadingGroups. Execute for each objects */
static void EDIT_TEXT_cache_populate(void *vedata, Object *ob)
{
- EDIT_TEXT_PassList *psl = ((EDIT_TEXT_Data *)vedata)->psl;
- EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
- const DRWContextState *draw_ctx = DRW_context_state_get();
-
- UNUSED_VARS(psl, stl);
-
- if (ob->type == OB_FONT) {
- if (ob == draw_ctx->object_edit) {
- const Curve *cu = ob->data;
- /* Get geometry cache */
- struct GPUBatch *geom;
-
- bool has_surface = (cu->flag & (CU_FRONT | CU_BACK)) || cu->ext1 != 0.0f || cu->ext2 != 0.0f;
- if ((cu->flag & CU_FAST) || !has_surface) {
- geom = DRW_cache_text_edge_wire_get(ob);
- if (geom) {
- DRW_shgroup_call_add(stl->g_data->wire_shgrp, geom, ob->obmat);
- }
- }
- else {
- /* object mode draws */
- }
-
- edit_text_cache_populate_select(vedata, ob);
- edit_text_cache_populate_cursor(vedata, ob);
- edit_text_cache_populate_boxes(vedata, ob);
- }
- }
+ EDIT_TEXT_PassList *psl = ((EDIT_TEXT_Data *)vedata)->psl;
+ EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
+ const DRWContextState *draw_ctx = DRW_context_state_get();
+
+ UNUSED_VARS(psl, stl);
+
+ if (ob->type == OB_FONT) {
+ if (ob == draw_ctx->object_edit) {
+ const Curve *cu = ob->data;
+ /* Get geometry cache */
+ struct GPUBatch *geom;
+
+ bool has_surface = (cu->flag & (CU_FRONT | CU_BACK)) || cu->ext1 != 0.0f || cu->ext2 != 0.0f;
+ if ((cu->flag & CU_FAST) || !has_surface) {
+ geom = DRW_cache_text_edge_wire_get(ob);
+ if (geom) {
+ DRW_shgroup_call_add(stl->g_data->wire_shgrp, geom, ob->obmat);
+ }
+ }
+ else {
+ /* object mode draws */
+ }
+
+ edit_text_cache_populate_select(vedata, ob);
+ edit_text_cache_populate_cursor(vedata, ob);
+ edit_text_cache_populate_boxes(vedata, ob);
+ }
+ }
}
/* Optional: Post-cache_populate callback */
static void EDIT_TEXT_cache_finish(void *vedata)
{
- EDIT_TEXT_PassList *psl = ((EDIT_TEXT_Data *)vedata)->psl;
- EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
+ EDIT_TEXT_PassList *psl = ((EDIT_TEXT_Data *)vedata)->psl;
+ EDIT_TEXT_StorageList *stl = ((EDIT_TEXT_Data *)vedata)->stl;
- /* Do something here! dependent on the objects gathered */
- UNUSED_VARS(psl, stl);
+ /* Do something here! dependent on the objects gathered */
+ UNUSED_VARS(psl, stl);
}
/* Draw time ! Control rendering pipeline from here */
static void EDIT_TEXT_draw_scene(void *vedata)
{
- EDIT_TEXT_PassList *psl = ((EDIT_TEXT_Data *)vedata)->psl;
- EDIT_TEXT_FramebufferList *fbl = ((EDIT_TEXT_Data *)vedata)->fbl;
+ EDIT_TEXT_PassList *psl = ((EDIT_TEXT_Data *)vedata)->psl;
+ EDIT_TEXT_FramebufferList *fbl = ((EDIT_TEXT_Data *)vedata)->fbl;
- /* Default framebuffer and texture */
- DefaultFramebufferList *dfbl = DRW_viewport_framebuffer_list_get();
- DefaultTextureList *dtxl = DRW_viewport_texture_list_get();
+ /* Default framebuffer and texture */
+ DefaultFramebufferList *dfbl = DRW_viewport_framebuffer_list_get();
+ DefaultTextureList *dtxl = DRW_viewport_texture_list_get();
- UNUSED_VARS(fbl, dfbl, dtxl);
+ UNUSED_VARS(fbl, dfbl, dtxl);
- /* Show / hide entire passes, swap framebuffers ... whatever you fancy */
- /*
- * DRW_framebuffer_texture_detach(dtxl->depth);
- * DRW_framebuffer_bind(fbl->custom_fb);
- * DRW_draw_pass(psl->pass);
- * DRW_framebuffer_texture_attach(dfbl->default_fb, dtxl->depth, 0, 0);
- * DRW_framebuffer_bind(dfbl->default_fb);
- */
+ /* Show / hide entire passes, swap framebuffers ... whatever you fancy */
+ /*
+ * DRW_framebuffer_texture_detach(dtxl->depth);
+ * DRW_framebuffer_bind(fbl->custom_fb);
+ * DRW_draw_pass(psl->pass);
+ * DRW_framebuffer_texture_attach(dfbl->default_fb, dtxl->depth, 0, 0);
+ * DRW_framebuffer_bind(dfbl->default_fb);
+ */
- DRW_draw_pass(psl->wire_pass);
+ DRW_draw_pass(psl->wire_pass);
- if (!DRW_pass_is_empty(psl->text_box_pass)) {
- DRW_draw_pass(psl->text_box_pass);
- }
+ if (!DRW_pass_is_empty(psl->text_box_pass)) {
+ DRW_draw_pass(psl->text_box_pass);
+ }
- set_inverted_drawing(1);
- DRW_draw_pass(psl->overlay_select_pass);
- DRW_draw_pass(psl->overlay_cursor_pass);
- set_inverted_drawing(0);
+ set_inverted_drawing(1);
+ DRW_draw_pass(psl->overlay_select_pass);
+ DRW_draw_pass(psl->overlay_cursor_pass);
+ set_inverted_drawing(0);
- /* If you changed framebuffer, double check you rebind
- * the default one with its textures attached before finishing */
+ /* If you changed framebuffer, double check you rebind
+ * the default one with its textures attached before finishing */
}
/* Cleanup when destroying the engine.
@@ -399,22 +399,23 @@ static void EDIT_TEXT_draw_scene(void *vedata)
* Mostly used for freeing shaders */
static void EDIT_TEXT_engine_free(void)
{
- // DRW_SHADER_FREE_SAFE(custom_shader);
+ // DRW_SHADER_FREE_SAFE(custom_shader);
}
static const DrawEngineDataSize EDIT_TEXT_data_size = DRW_VIEWPORT_DATA_SIZE(EDIT_TEXT_Data);
DrawEngineType draw_engine_edit_text_type = {
- NULL, NULL,
- N_("EditTextMode"),
- &EDIT_TEXT_data_size,
- &EDIT_TEXT_engine_init,
- &EDIT_TEXT_engine_free,
- &EDIT_TEXT_cache_init,
- &EDIT_TEXT_cache_populate,
- &EDIT_TEXT_cache_finish,
- NULL, /* draw_background but not needed by mode engines */
- &EDIT_TEXT_draw_scene,
- NULL,
- NULL,
+ NULL,
+ NULL,
+ N_("EditTextMode"),
+ &EDIT_TEXT_data_size,
+ &EDIT_TEXT_engine_init,
+ &EDIT_TEXT_engine_free,
+ &EDIT_TEXT_cache_init,
+ &EDIT_TEXT_cache_populate,
+ &EDIT_TEXT_cache_finish,
+ NULL, /* draw_background but not needed by mode engines */
+ &EDIT_TEXT_draw_scene,
+ NULL,
+ NULL,
};