1
0
mirror of https://github.com/pdf2htmlEX/pdf2htmlEX.git synced 2024-07-05 17:48:38 +00:00

fix some states depends on draw_scale that are not updated correctly

This commit is contained in:
Lu Wang 2012-09-04 12:27:06 +08:00
parent 35809470af
commit 0cfd146173
2 changed files with 25 additions and 12 deletions

View File

@ -13,6 +13,11 @@ pkg_check_modules(FONTFORGE REQUIRED fontforge)
include_directories(${FONTFORGE_INCLUDE_DIRS}) include_directories(${FONTFORGE_INCLUDE_DIRS})
link_directories ( ${FONTFORGE_LIBRARY_DIRS} ) link_directories ( ${FONTFORGE_LIBRARY_DIRS} )
message("*************")
message("fontforge may not be preparing fontforge.pc correctly")
message("consider adding -lfontforge -lpython2.7 if you see lots of linking error")
message("*************")
set(PDF2HTMLEX_VERSION "0.2") set(PDF2HTMLEX_VERSION "0.2")
set(ARCHIVE_NAME pdf2htmlex-${PDF2HTMLEX_VERSION}) set(ARCHIVE_NAME pdf2htmlex-${PDF2HTMLEX_VERSION})
add_custom_target(dist add_custom_target(dist
@ -21,13 +26,13 @@ add_custom_target(dist
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}) WORKING_DIRECTORY ${CMAKE_SOURCE_DIR})
set(CMAKE_C_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wunused-function") set(CMAKE_C_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wunused-function")
#set(CMAKE_C_FLAGS "${CMAKE_CXX_FLAGS} -O2") set(CMAKE_C_FLAGS "${CMAKE_CXX_FLAGS} -O2")
set(CMAKE_C_FLAGS "${CMAKE_CXX_FLAGS} -ggdb") #set(CMAKE_C_FLAGS "${CMAKE_CXX_FLAGS} -ggdb")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wunused-function") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wunused-function")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++0x") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++0x")
#set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -O2") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -O2")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ggdb") #set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ggdb")
configure_file (${CMAKE_SOURCE_DIR}/src/config.h.in ${CMAKE_SOURCE_DIR}/src/config.h) configure_file (${CMAKE_SOURCE_DIR}/src/config.h.in ${CMAKE_SOURCE_DIR}/src/config.h)

View File

@ -82,6 +82,7 @@ void HTMLRenderer::check_state_change(GfxState * state)
bool need_recheck_position = false; bool need_recheck_position = false;
bool need_rescale_font = false; bool need_rescale_font = false;
bool draw_scale_changed = false;
// text position // text position
// we've been tracking the text position positively in the update*** functions // we've been tracking the text position positively in the update*** functions
@ -145,18 +146,24 @@ void HTMLRenderer::check_state_change(GfxState * state)
double new_draw_ctm[6]; double new_draw_ctm[6];
memcpy(new_draw_ctm, cur_ctm, sizeof(new_draw_ctm)); memcpy(new_draw_ctm, cur_ctm, sizeof(new_draw_ctm));
draw_scale = (param->font_size_multiplier) * sqrt(new_draw_ctm[2] * new_draw_ctm[2] + new_draw_ctm[3] * new_draw_ctm[3]); double new_draw_scale = (param->font_size_multiplier) * sqrt(new_draw_ctm[2] * new_draw_ctm[2] + new_draw_ctm[3] * new_draw_ctm[3]);
double new_draw_font_size = cur_font_size; double new_draw_font_size = cur_font_size;
if(_is_positive(draw_scale)) if(_is_positive(new_draw_scale))
{ {
new_draw_font_size *= draw_scale; new_draw_font_size *= new_draw_scale;
for(int i = 0; i < 4; ++i) for(int i = 0; i < 4; ++i)
new_draw_ctm[i] /= draw_scale; new_draw_ctm[i] /= new_draw_scale;
} }
else else
{ {
draw_scale = 1.0; new_draw_scale = 1.0;
}
if(!(_equal(new_draw_scale, draw_scale)))
{
draw_scale_changed = true;
draw_scale = new_draw_scale;
} }
if(!(_equal(new_draw_font_size, draw_font_size))) if(!(_equal(new_draw_font_size, draw_font_size)))
@ -235,7 +242,7 @@ void HTMLRenderer::check_state_change(GfxState * state)
// letter space // letter space
// depends: draw_scale // depends: draw_scale
if(all_changed || letter_space_changed) if(all_changed || letter_space_changed || draw_scale_changed)
{ {
double new_letter_space = state->getCharSpace(); double new_letter_space = state->getCharSpace();
if(!_equal(cur_letter_space, new_letter_space)) if(!_equal(cur_letter_space, new_letter_space))
@ -248,7 +255,7 @@ void HTMLRenderer::check_state_change(GfxState * state)
// word space // word space
// depends draw_scale // depends draw_scale
if(all_changed || word_space_changed) if(all_changed || word_space_changed || draw_scale_changed)
{ {
double new_word_space = state->getWordSpace(); double new_word_space = state->getWordSpace();
if(!_equal(cur_word_space, new_word_space)) if(!_equal(cur_word_space, new_word_space))
@ -273,7 +280,8 @@ void HTMLRenderer::check_state_change(GfxState * state)
} }
// rise // rise
if(all_changed || rise_changed) // depends draw_scale
if(all_changed || rise_changed || draw_scale_changed)
{ {
double new_rise = state->getRise(); double new_rise = state->getRise();
if(!_equal(cur_rise, new_rise)) if(!_equal(cur_rise, new_rise))