123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411 |
- #include "sys-defines.h"
- #include "extern.h"
- #include "g_her_metr.h"
- #define MAP_HERSHEY_UNITS_TO_USER_UNITS(size, drawstate) \
- ((size)*(drawstate->true_font_size)/(HERSHEY_EM))
- static bool _match_hershey_font (plDrawState *drawstate);
- static bool _match_ps_font (plDrawState *drawstate);
- static bool _match_pcl_font (plDrawState *drawstate);
- static bool _match_stick_font (plDrawState *drawstate, bool have_extra_stick_fonts);
- void
- _pl_g_set_font (S___(Plotter *_plotter))
- {
- plDrawState *drawstate = _plotter->drawstate;
- plPlotterData *data = _plotter->data;
- const char *default_font_name;
- bool matched;
-
- if (_match_hershey_font (drawstate))
-
- return;
- matched = false;
-
- if (data->pcl_before_ps)
- {
-
- if ((data->have_pcl_fonts
- && _match_pcl_font (drawstate))
- ||
- (data->have_ps_fonts
- && _match_ps_font (drawstate)))
- matched = true;
- }
- else
- {
-
- if ((data->have_ps_fonts
- && _match_ps_font (drawstate))
- ||
- (data->have_pcl_fonts
- && _match_pcl_font (drawstate)))
- matched = true;
- }
-
- if (matched == false && data->have_stick_fonts
- && _match_stick_font (drawstate,
- data->have_extra_stick_fonts ? true : false))
- matched = true;
- if (matched == false)
-
- {
- free ((char *)drawstate->true_font_name);
- drawstate->true_font_name =
- (const char *)_pl_xmalloc (strlen (drawstate->font_name) + 1);
- strcpy ((char *)drawstate->true_font_name, drawstate->font_name);
- drawstate->true_font_size = drawstate->font_size;
- drawstate->font_type = PL_F_OTHER;
- drawstate->typeface_index = 0;
- drawstate->font_index = 1;
-
- }
-
- if (matched || (!matched && data->have_other_fonts))
-
- {
- if (_plotter->retrieve_font (S___(_plotter)))
-
- return;
- }
-
-
- switch (data->default_font_type)
- {
- case PL_F_POSTSCRIPT:
- default_font_name = PL_DEFAULT_POSTSCRIPT_FONT;
- break;
- case PL_F_PCL:
- default_font_name = PL_DEFAULT_PCL_FONT;
- break;
- case PL_F_STICK:
- default_font_name = PL_DEFAULT_STICK_FONT;
- break;
- case PL_F_HERSHEY:
- default:
- default_font_name = PL_DEFAULT_HERSHEY_FONT;
- break;
-
- }
- if (strcmp (drawstate->font_name, default_font_name) == 0
- || strcmp (drawstate->true_font_name, default_font_name) == 0)
-
- default_font_name = PL_DEFAULT_HERSHEY_FONT;
-
-
- {
- const char *saved_font_name;
- bool saved_font_warning_issued;
- saved_font_name = drawstate->font_name;
- drawstate->font_name = default_font_name;
- saved_font_warning_issued = _plotter->data->font_warning_issued;
- _plotter->data->font_warning_issued = true;
- _pl_g_set_font (S___(_plotter));
- _plotter->data->font_warning_issued = saved_font_warning_issued;
- drawstate->font_name = saved_font_name;
- }
- if (data->issue_font_warning && !_plotter->data->font_warning_issued)
-
- {
- char *buf;
-
- buf = (char *)_pl_xmalloc (strlen (drawstate->font_name) + strlen (drawstate->true_font_name) + 100);
- sprintf (buf, "cannot retrieve font \"%s\", using default \"%s\"",
- drawstate->font_name, drawstate->true_font_name);
- _plotter->warning (R___(_plotter) buf);
- free (buf);
- _plotter->data->font_warning_issued = true;
- }
- }
- static bool
- _match_hershey_font (plDrawState *drawstate)
- {
- int i;
-
- i = -1;
- while (_pl_g_hershey_font_info[++i].name)
- {
- if (_pl_g_hershey_font_info[i].visible)
- if (strcasecmp (_pl_g_hershey_font_info[i].name,
- drawstate->font_name) == 0
- || (_pl_g_hershey_font_info[i].othername
- && strcasecmp (_pl_g_hershey_font_info[i].othername,
- drawstate->font_name) == 0))
-
- {
- free ((char *)drawstate->true_font_name);
- drawstate->true_font_name =
- (const char *)_pl_xmalloc (strlen (_pl_g_hershey_font_info[i].name) + 1);
- strcpy ((char *)drawstate->true_font_name, _pl_g_hershey_font_info[i].name);
- drawstate->true_font_size = drawstate->font_size;
- drawstate->font_type = PL_F_HERSHEY;
- drawstate->typeface_index = _pl_g_hershey_font_info[i].typeface_index;
- drawstate->font_index = _pl_g_hershey_font_info[i].font_index;
- drawstate->font_is_iso8859_1 = _pl_g_hershey_font_info[i].iso8859_1;
-
- drawstate->font_cap_height =
- MAP_HERSHEY_UNITS_TO_USER_UNITS(HERSHEY_CAPHEIGHT, drawstate);
- drawstate->font_ascent =
- MAP_HERSHEY_UNITS_TO_USER_UNITS(HERSHEY_ASCENT, drawstate);
- drawstate->font_descent =
- MAP_HERSHEY_UNITS_TO_USER_UNITS(HERSHEY_DESCENT, drawstate);
-
- return true;
- }
- }
- return false;
- }
- static bool
- _match_pcl_font (plDrawState *drawstate)
- {
- int i = -1;
-
- while (_pl_g_pcl_font_info[++i].ps_name)
- {
- if (strcasecmp (_pl_g_pcl_font_info[i].ps_name,
- drawstate->font_name) == 0
-
- || (_pl_g_pcl_font_info[i].ps_name_alt != NULL
- && strcasecmp (_pl_g_pcl_font_info[i].ps_name_alt,
- drawstate->font_name) == 0)
-
- || strcasecmp (_pl_g_pcl_font_info[i].x_name,
- drawstate->font_name) == 0)
- {
- free ((char *)drawstate->true_font_name);
- drawstate->true_font_name =
- (const char *)_pl_xmalloc (strlen (_pl_g_pcl_font_info[i].ps_name) + 1);
- strcpy ((char *)drawstate->true_font_name, _pl_g_pcl_font_info[i].ps_name);
- drawstate->true_font_size = drawstate->font_size;
- drawstate->font_type = PL_F_PCL;
- drawstate->typeface_index = _pl_g_pcl_font_info[i].typeface_index;
- drawstate->font_index = _pl_g_pcl_font_info[i].font_index;
- drawstate->font_is_iso8859_1 = _pl_g_pcl_font_info[i].iso8859_1;
- drawstate->font_ascent
- = drawstate->true_font_size
- * (double)(_pl_g_pcl_font_info[i].font_ascent)/1000.0;
- drawstate->font_descent
- = drawstate->true_font_size
- * (double)(_pl_g_pcl_font_info[i].font_descent)/1000.0;
- drawstate->font_cap_height
- = drawstate->true_font_size
- * (double)(_pl_g_pcl_font_info[i].font_cap_height)/1000.0;
- return true;
- }
- }
- return false;
- }
- static bool
- _match_ps_font (plDrawState *drawstate)
- {
- int i = -1;
-
- while (_pl_g_ps_font_info[++i].ps_name)
- {
- if (strcasecmp (_pl_g_ps_font_info[i].ps_name,
- drawstate->font_name) == 0
-
- || (_pl_g_ps_font_info[i].ps_name_alt != NULL
- && strcasecmp (_pl_g_ps_font_info[i].ps_name_alt,
- drawstate->font_name) == 0)
-
- || (_pl_g_ps_font_info[i].ps_name_alt2 != NULL
- && strcasecmp (_pl_g_ps_font_info[i].ps_name_alt2,
- drawstate->font_name) == 0)
-
- || strcasecmp (_pl_g_ps_font_info[i].x_name,
- drawstate->font_name) == 0
-
- || (_pl_g_ps_font_info[i].x_name_alt != NULL
- && strcasecmp (_pl_g_ps_font_info[i].x_name_alt,
- drawstate->font_name) == 0))
- {
- free ((char *)drawstate->true_font_name);
- drawstate->true_font_name =
- (const char *)_pl_xmalloc (strlen (_pl_g_ps_font_info[i].ps_name) + 1);
- strcpy ((char *)drawstate->true_font_name, _pl_g_ps_font_info[i].ps_name);
- drawstate->true_font_size = drawstate->font_size;
- drawstate->font_type = PL_F_POSTSCRIPT;
- drawstate->typeface_index = _pl_g_ps_font_info[i].typeface_index;
- drawstate->font_index = _pl_g_ps_font_info[i].font_index;
- drawstate->font_is_iso8859_1 = _pl_g_ps_font_info[i].iso8859_1;
- drawstate->font_ascent
- = drawstate->true_font_size
- * (double)(_pl_g_ps_font_info[i].font_ascent)/1000.0;
- drawstate->font_descent
- = drawstate->true_font_size
- * (double)(_pl_g_ps_font_info[i].font_descent)/1000.0;
- drawstate->font_cap_height
- = drawstate->true_font_size
- * (double)(_pl_g_ps_font_info[i].font_cap_height)/1000.0;
- return true;
- }
- }
- return false;
- }
- static bool
- _match_stick_font (plDrawState *drawstate, bool have_extra_stick_fonts)
- {
- int i = -1;
-
- while (_pl_g_stick_font_info[++i].ps_name)
- {
- if (_pl_g_stick_font_info[i].basic == false
- && !have_extra_stick_fonts)
-
- continue;
-
- if (strcasecmp (_pl_g_stick_font_info[i].ps_name,
- drawstate->font_name) == 0)
-
- {
- free ((char *)drawstate->true_font_name);
- drawstate->true_font_name =
- (const char *)_pl_xmalloc (strlen (_pl_g_stick_font_info[i].ps_name) + 1);
- strcpy ((char *)drawstate->true_font_name, _pl_g_stick_font_info[i].ps_name);
- drawstate->true_font_size = drawstate->font_size;
- drawstate->true_font_size = drawstate->font_size;
- drawstate->true_font_size = drawstate->font_size;
- drawstate->font_type = PL_F_STICK;
- drawstate->typeface_index = _pl_g_stick_font_info[i].typeface_index;
- drawstate->font_index = _pl_g_stick_font_info[i].font_index;
- drawstate->font_is_iso8859_1 = _pl_g_stick_font_info[i].iso8859_1;
- drawstate->font_ascent
- = drawstate->true_font_size
- * (double)(_pl_g_stick_font_info[i].font_ascent)/1000.0;
- drawstate->font_descent
- = drawstate->true_font_size
- * (double)(_pl_g_stick_font_info[i].font_descent)/1000.0;
- drawstate->font_cap_height
-
- = 0.7 * drawstate->true_font_size;
-
- return true;
- }
- }
- return false;
- }
- bool
- _pl_g_retrieve_font (S___(Plotter *_plotter))
- {
- return true;
- }
|