diff options
author | Bastien Montagne <montagne29@wanadoo.fr> | 2015-09-13 15:51:50 +0300 |
---|---|---|
committer | Bastien Montagne <montagne29@wanadoo.fr> | 2015-09-13 15:51:50 +0300 |
commit | 7900d697f0ade0be21dbb3757d59f1a07268b242 (patch) | |
tree | c12617990fd3d712ea0ef2b47c3e74e01f8871cf /source/blender/blenkernel/intern/seqeffects.c | |
parent | 45a875fec4c00ccf87c5605d85f004f6dd4be8a0 (diff) |
Fix T46089: Text from Effect Strip is invisible in VSE Preview.
Deviding two ints together never yields a float... Also, logic of various proxies size corrections was quite broken.
Now we should always get the same (relative) size of text whatever proxy setting/render scale is chosen.
Diffstat (limited to 'source/blender/blenkernel/intern/seqeffects.c')
-rw-r--r-- | source/blender/blenkernel/intern/seqeffects.c | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/source/blender/blenkernel/intern/seqeffects.c b/source/blender/blenkernel/intern/seqeffects.c index 1333d28960c..c65ed527568 100644 --- a/source/blender/blenkernel/intern/seqeffects.c +++ b/source/blender/blenkernel/intern/seqeffects.c @@ -2927,8 +2927,10 @@ static ImBuf *do_text_effect(const SeqRenderData *context, Sequence *seq, float display = IMB_colormanagement_display_get_named(display_device); /* Compensate text size for preview render size. */ - if (context->preview_render_size == SEQ_PROXY_RENDER_SIZE_100) { - /* Should be rendered at 100%, but context->preview_render_size = 99 right now. */ + if (ELEM(context->preview_render_size, SEQ_PROXY_RENDER_SIZE_SCENE, SEQ_PROXY_RENDER_SIZE_FULL)) { + proxy_size_comp = context->scene->r.size / 100.0f; + } + else if (context->preview_render_size == SEQ_PROXY_RENDER_SIZE_100) { proxy_size_comp = 1.0f; } else { @@ -2936,7 +2938,7 @@ static ImBuf *do_text_effect(const SeqRenderData *context, Sequence *seq, float } /* set before return */ - BLF_size(mono, proxy_size_comp * (context->scene->r.size / 100) * data->text_size, 72); + BLF_size(mono, proxy_size_comp * data->text_size, 72); BLF_buffer(mono, out->rect_float, (unsigned char *)out->rect, width, height, out->channels, display); @@ -2964,12 +2966,12 @@ static ImBuf *do_text_effect(const SeqRenderData *context, Sequence *seq, float int fontx, fonty; fontx = BLF_width_max(mono); fonty = BLF_height_max(mono); - BLF_position(mono, x + max_ii(fontx / 25, 1), y + max_ii(fonty / 25, 1), 0.0); - BLF_buffer_col(mono, 0.0f, 0.0f, 0.0f, 1.0); + BLF_position(mono, x + max_ii(fontx / 25, 1), y + max_ii(fonty / 25, 1), 0.0f); + BLF_buffer_col(mono, 0.0f, 0.0f, 0.0f, 1.0f); BLF_draw_buffer(mono, data->text); } - BLF_position(mono, x, y, 0.0); - BLF_buffer_col(mono, 1.0f, 1.0f, 1.0f, 1.0); + BLF_position(mono, x, y, 0.0f); + BLF_buffer_col(mono, 1.0f, 1.0f, 1.0f, 1.0f); BLF_draw_buffer(mono, data->text); BLF_buffer(mono, NULL, NULL, 0, 0, 0, NULL); |