123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- #include "sys-defines.h"
- #include "extern.h"
- bool
- _pl_c_end_page (S___(Plotter *_plotter))
- {
- int i, fullstrength, red, green, blue;
-
- {
- plCGMCustomLineType *line_type_ptr = (plCGMCustomLineType *)_plotter->data->page->extra;
- int num_line_types = 0;
- bool violates_profile = false;
- while (line_type_ptr != (plCGMCustomLineType *)NULL)
- {
- if (line_type_ptr->dash_array_len > CGM_PL_MAX_DASH_ARRAY_LENGTH)
- violates_profile = true;
- line_type_ptr = line_type_ptr->next;
- num_line_types++;
- }
- if (num_line_types > CGM_MAX_CUSTOM_LINE_TYPES)
- violates_profile = true;
- if (violates_profile)
- _plotter->cgm_page_profile =
- IMAX(_plotter->cgm_page_profile, CGM_PROFILE_NONE);
- }
-
- if (_plotter->cgm_max_version >= 3)
- {
- for (i = 0; i < PL_NUM_PS_FONTS; i++)
- {
- if (_plotter->data->page->ps_font_used[i] == true)
- {
- _plotter->cgm_page_version = IMAX(_plotter->cgm_page_version, 3);
- break;
- }
- }
- }
-
-
- _plotter->cgm_version =
- IMAX(_plotter->cgm_version, _plotter->cgm_page_version);
- _plotter->cgm_profile =
- IMAX(_plotter->cgm_profile, _plotter->cgm_page_profile);
-
- red = _plotter->cgm_bgcolor.red;
- green = _plotter->cgm_bgcolor.green;
- blue = _plotter->cgm_bgcolor.blue;
- fullstrength = (1 << (8 * CGM_BINARY_BYTES_PER_COLOR_COMPONENT)) - 1;
- if ((red != 0 || green != 0 || blue != 0)
- && (red != fullstrength || green != fullstrength || blue != fullstrength))
- _plotter->cgm_page_need_color = true;
-
- if (_plotter->cgm_page_need_color)
- _plotter->cgm_need_color = true;
-
- _plotter->data->page->bg_color = _plotter->cgm_bgcolor;
- _plotter->data->page->bg_color_suppressed =
- _plotter->cgm_bgcolor_suppressed;
- return true;
- }
|