diff options
Diffstat (limited to 'pdf')
-rw-r--r-- | pdf/pdf_font.c | 3 | ||||
-rw-r--r-- | pdf/pdf_form.c | 47 |
2 files changed, 44 insertions, 6 deletions
diff --git a/pdf/pdf_font.c b/pdf/pdf_font.c index f61f355d..3c1a3205 100644 --- a/pdf/pdf_font.c +++ b/pdf/pdf_font.c @@ -1202,7 +1202,8 @@ float pdf_text_stride(fz_context *ctx, pdf_font_desc *fontdesc, float fontsize, x -= h.w * fontsize / 1000.0; } - *count = i; + if (count) + *count = i; return x; }
\ No newline at end of file diff --git a/pdf/pdf_form.c b/pdf/pdf_form.c index 68db8327..3120cf10 100644 --- a/pdf/pdf_form.c +++ b/pdf/pdf_form.c @@ -6,11 +6,16 @@ enum { Ff_Multiline = 1 << (13-1), + Ff_Password = 1 << (14-1), Ff_NoToggleToOff = 1 << (15-1), - Ff_Radio = 1 << (16-1), - Ff_Pushbutton = 1 << (17-1), - Ff_RadioInUnison = 1 << (26-1), - Ff_Combo = 1 << (18-1) + Ff_Radio = 1 << (16-1), + Ff_Pushbutton = 1 << (17-1), + Ff_Combo = 1 << (18-1), + Ff_FileSelect = 1 << (21-1), + Ff_DoNotSpellCheck = 1 << (23-1), + Ff_DoNotScroll = 1 << (24-1), + Ff_Comb = 1 << (25-1), + Ff_RadioInUnison = 1 << (26-1) }; enum @@ -62,6 +67,8 @@ typedef struct text_widget_info_s font_info font_rec; int q; int multiline; + int comb; + int max_len; } text_widget_info; static const char *fmt_re = "%f %f %f %f re\n"; @@ -374,10 +381,19 @@ static void font_info_fin(fz_context *ctx, font_info *font_rec) static void get_text_widget_info(pdf_document *doc, pdf_obj *widget, text_widget_info *info) { char *da = pdf_to_str_buf(get_inheritable(doc, widget, "DA")); + int ff = get_field_flags(doc, widget); + pdf_obj *ml = get_inheritable(doc, widget, "MaxLen"); info->dr = get_inheritable(doc, widget, "DR"); info->q = pdf_to_int(get_inheritable(doc, widget, "Q")); - info->multiline = (get_field_flags(doc, widget) & Ff_Multiline) != 0; + info->multiline = (ff & Ff_Multiline) != 0; + info->comb = (ff & (Ff_Multiline|Ff_Password|Ff_FileSelect|Ff_Comb)) == Ff_Comb; + + if (ml == NULL) + info->comb = 0; + else + info->max_len = pdf_to_int(ml); + get_font_info(doc, info->dr, da, &info->font_rec); } @@ -679,6 +695,7 @@ static void fzbuf_print_text_end(fz_context *ctx, fz_buffer *fzbuf) { fz_buffer_printf(ctx, fzbuf, fmt_ET); fz_buffer_printf(ctx, fzbuf, fmt_Q); + fz_buffer_printf(ctx, fzbuf, fmt_EMC); } static void fzbuf_print_text_word(fz_context *ctx, fz_buffer *fzbuf, float x, float y, char *text, int count) @@ -793,6 +810,26 @@ static fz_buffer *create_text_appearance(pdf_document *doc, fz_rect *bbox, fz_ma fzbuf_print_text_end(ctx, fzbuf); } + else if (info->comb) + { + int i, n = min((int)strlen(text), info->max_len); + float comb_width = width/info->max_len; + float char_width = pdf_text_stride(ctx, info->font_rec.font, fontsize, (unsigned char *)"M", 1, FLT_MAX, NULL); + float init_skip = (comb_width - char_width)/2.0; + + tm = fz_identity; + tm.e = rect.x0; + tm.f = rect.y1 - (height+(ascent-descent)*fontsize)/2.0; + + fzbuf = fz_new_buffer(ctx, 0); + + fzbuf_print_text_start(ctx, fzbuf, &rect, &info->font_rec, &tm); + + for (i = 0; i < n; i++) + fzbuf_print_text_word(ctx, fzbuf, i == 0 ? init_skip : comb_width, 0.0, text+i, 1); + + fzbuf_print_text_end(ctx, fzbuf); + } else { if (oldtm) |