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:
authorBastien Montagne <montagne29@wanadoo.fr>2015-09-13 15:51:50 +0300
committerBastien Montagne <montagne29@wanadoo.fr>2015-09-13 15:51:50 +0300
commit7900d697f0ade0be21dbb3757d59f1a07268b242 (patch)
treec12617990fd3d712ea0ef2b47c3e74e01f8871cf /source/blender/blenkernel/intern/seqeffects.c
parent45a875fec4c00ccf87c5605d85f004f6dd4be8a0 (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.c16
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);