⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 out_util.c

📁 unix vnc 协议源码. VNC是一款远程控制工具软件.
💻 C
字号:
/* $XConsortium: out_util.c,v 1.2 91/05/11 09:53:35 rws Exp $ *//*Copyright 1989-1991, Bitstream Inc., Cambridge, MA.You are hereby granted permission under all Bitstream propriety rights touse, copy, modify, sublicense, sell, and redistribute the Bitstream Speedosoftware and the Bitstream Charter outline font for any purpose and withoutrestrictions; provided, that this notice is left intact on all copies of suchsoftware or font and that Bitstream's trademark is acknowledged as shown belowon all unmodified copies of such font.BITSTREAM CHARTER is a registered trademark of Bitstream Inc.BITSTREAM INC. DISCLAIMS ANY AND ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDINGWITHOUT LIMITATION THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR APARTICULAR PURPOSE.  BITSTREAM SHALL NOT BE LIABLE FOR ANY DIRECT OR INDIRECTDAMAGES, INCLUDING BUT NOT LIMITED TO LOST PROFITS, LOST DATA, OR ANY OTHERINCIDENTAL OR CONSEQUENTIAL DAMAGES, ARISING OUT OF OR IN ANY WAY CONNECTEDWITH THE SPEEDO SOFTWARE OR THE BITSTREAM CHARTER OUTLINE FONT.*/#define	DEBUG	0/*************************** O U T _ U T I L . C ***************************** *                                                                           * * This is a utility module share by all bitmap output modules               * *                                                                           * *****************************************************************************/#include "spdo_prv.h"               /* General definitions for Speedo   *//* absolute value function */#define   ABS(X)     ( (X < 0) ? -X : X)#if INCL_BLACK || INCL_2D || INCL_SCREENFUNCTION  void init_char_out(Psw,Pmin,Pmax)GDECLpoint_t Psw, Pmin, Pmax;{sp_globals.set_width.x = (fix31)Psw.x << sp_globals.poshift;sp_globals.set_width.y = (fix31)Psw.y << sp_globals.poshift;set_first_band_out(Pmin, Pmax);init_intercepts_out();if (sp_globals.normal)    {    sp_globals.bmap_xmin = Pmin.x;    sp_globals.bmap_xmax = Pmax.x;    sp_globals.bmap_ymin = Pmin.y;    sp_globals.bmap_ymax = Pmax.y;    sp_globals.extents_running = FALSE;    }else    {    sp_globals.bmap_xmin = 32000;    sp_globals.bmap_xmax = -32000;    sp_globals.bmap_ymin = 32000;    sp_globals.bmap_ymax = -32000;    sp_globals.extents_running = TRUE;    }sp_globals.first_pass = TRUE;}FUNCTION void begin_sub_char_out(Psw, Pmin, Pmax)GDECLpoint_t Psw;                   point_t Pmin;                   point_t Pmax;                   /* Called at the start of each sub-character in a composite character */{#if DEBUGprintf("BEGIN_SUB_CHAR_out(%3.1f, %3.1f, %3.1f, %3.1f, %3.1f, %3.1f\n",                     (real)Psw.x / (real)sp_globals.onepix, (real)Psw.y / (real)sp_globals.onepix,                    (real)Pmin.x / (real)sp_globals.onepix, (real)Pmin.y / (real)sp_globals.onepix,                    (real)Pmax.x / (real)sp_globals.onepix, (real)Pmax.y / (real)sp_globals.onepix);#endifrestart_intercepts_out();if (!sp_globals.extents_running)	{    sp_globals.bmap_xmin = 32000;    sp_globals.bmap_xmax = -32000;    sp_globals.bmap_ymin = 32000;    sp_globals.bmap_ymax = -32000;    sp_globals.extents_running = TRUE;	}}FUNCTION void curve_out(P1, P2, P3,depth)GDECLpoint_t P1, P2, P3;                   fix15 depth;/* Called for each curve in the transformed character if curves out enabled */{#if DEBUGprintf("CURVE_OUT(%3.1f, %3.1f, %3.1f, %3.1f, %3.1f, %3.1f)\n",     (real)P1.x / (real)sp_globals.onepix, (real)P1.y / (real)sp_globals.onepix,    (real)P2.x / (real)sp_globals.onepix, (real)P2.y / (real)sp_globals.onepix,    (real)P3.x / (real)sp_globals.onepix, (real)P3.y / (real)sp_globals.onepix);#endif}FUNCTION void end_contour_out()GDECL/* Called after the last vector in each contour */{#if DEBUGprintf("END_CONTOUR_OUT()\n");#endif}FUNCTION void end_sub_char_out()GDECL/* Called after the last contour in each sub-character in a compound character */{#if DEBUGprintf("END_SUB_CHAR_OUT()\n");#endif}FUNCTION void init_intercepts_out()GDECL/*  Called to initialize intercept storage data structure */{fix15 i;fix15 no_lists;#if DEBUGprintf("    Init intercepts (Y band from %d to %d)\n", sp_globals.y_band.band_min, sp_globals.y_band.band_max);if (sp_globals.x_scan_active)    printf("                    (X band from %d to %d)\n", sp_globals.x_band.band_min, sp_globals.x_band.band_max);#endif sp_globals.intercept_oflo = FALSE;sp_globals.no_y_lists = sp_globals.y_band.band_max - sp_globals.y_band.band_min + 1;#if INCL_2Dif (sp_globals.output_mode == MODE_2D)	{	sp_globals.no_x_lists = sp_globals.x_scan_active ? 		sp_globals.x_band.band_max - sp_globals.x_band.band_min + 1 : 0;	no_lists = sp_globals.no_y_lists + sp_globals.no_x_lists;	} else#endif	no_lists = sp_globals.no_y_lists;#if INCL_2Dsp_globals.y_band.band_floor = 0;sp_globals.y_band.band_ceiling = sp_globals.no_y_lists;#endif                                        if (no_lists >= MAX_INTERCEPTS)  /* Not enough room for list table? */    {    no_lists = sp_globals.no_y_lists = MAX_INTERCEPTS;    sp_globals.intercept_oflo = TRUE;	sp_globals.y_band.band_min = sp_globals.y_band.band_max - sp_globals.no_y_lists + 1;#if INCL_2D    sp_globals.y_band.band_array_offset = sp_globals.y_band.band_min;    sp_globals.y_band.band_ceiling = sp_globals.no_y_lists;    sp_globals.no_x_lists = 0;    sp_globals.x_scan_active = FALSE;#endif    }for (i = 0; i < no_lists; i++)   /* For each active value... */    {#if INCL_SCREEN	if (sp_globals.output_mode == MODE_SCREEN)		sp_intercepts.inttype[i]=0;#endif    sp_intercepts.cdr[i] = 0;                    /* Mark each intercept list empty */    }sp_globals.first_offset = sp_globals.next_offset = no_lists;#if INCL_2Dsp_globals.y_band.band_array_offset = sp_globals.y_band.band_min;sp_globals.x_band.band_array_offset = sp_globals.x_band.band_min - sp_globals.no_y_lists;sp_globals.x_band.band_floor = sp_globals.no_y_lists;sp_globals.x_band.band_ceiling = no_lists;#endif#if INCL_SCREENsp_intercepts.inttype[sp_globals.no_y_lists-1] = END_INT;#endif}FUNCTION void restart_intercepts_out()GDECL/*  Called by sp_make_char when a new sub character is started *  Freezes current sorted lists */{#if DEBUGprintf("    Restart intercepts:\n");#endifsp_globals.first_offset = sp_globals.next_offset;}FUNCTION void set_first_band_out(Pmin, Pmax)GDECLpoint_t Pmin;point_t Pmax;{sp_globals.ymin = Pmin.y;sp_globals.ymax = Pmax.y;sp_globals.ymin = (sp_globals.ymin - sp_globals.onepix + 1) >> sp_globals.pixshift;sp_globals.ymax = (sp_globals.ymax + sp_globals.onepix - 1) >> sp_globals.pixshift;#if INCL_CLIPPING    switch(sp_globals.tcb0.xtype)       {       case 1: /* 180 degree rotation */	    if (sp_globals.specs.flags & CLIP_TOP)               {               sp_globals.clip_ymin = (fix31)((fix31)EM_TOP * sp_globals.tcb0.yppo + ((1<<sp_globals.multshift)/2));               sp_globals.clip_ymin = sp_globals.clip_ymin >> sp_globals.multshift;	       sp_globals.clip_ymin = -1* sp_globals.clip_ymin;	       if (sp_globals.ymin < sp_globals.clip_ymin)		    sp_globals.ymin = sp_globals.clip_ymin;	       }            if (sp_globals.specs.flags & CLIP_BOTTOM)	       {               sp_globals.clip_ymax = (fix31)((fix31)(-1 * EM_BOT) * sp_globals.tcb0.yppo + ((1<<sp_globals.multshift)/2));               sp_globals.clip_ymax = sp_globals.clip_ymax >> sp_globals.multshift;	       if (sp_globals.ymax > sp_globals.clip_ymax)		    sp_globals.ymax = sp_globals.clip_ymax;               }               break;       case 2: /* 90 degree rotation */            sp_globals.clip_ymax = 0;            if ((sp_globals.specs.flags & CLIP_TOP) &&                (sp_globals.ymax > sp_globals.clip_ymax))                 sp_globals.ymax = sp_globals.clip_ymax;            sp_globals.clip_ymin = ((sp_globals.set_width.y+32768L) >> 16);            if ((sp_globals.specs.flags & CLIP_BOTTOM) &&                (sp_globals.ymin < sp_globals.clip_ymin))                 sp_globals.ymin = sp_globals.clip_ymin;            break;       case 3: /* 270 degree rotation */               sp_globals.clip_ymax = ((sp_globals.set_width.y+32768L) >> 16);               if ((sp_globals.specs.flags & CLIP_TOP) &&                   (sp_globals.ymax > sp_globals.clip_ymax))                    sp_globals.ymax = sp_globals.clip_ymax;               sp_globals.clip_ymin = 0;               if ((sp_globals.specs.flags & CLIP_BOTTOM) &&                   (sp_globals.ymin < sp_globals.clip_ymin))                    sp_globals.ymin = sp_globals.clip_ymin;               break;       default: /* this is for zero degree rotation and arbitrary rotation */	    if (sp_globals.specs.flags & CLIP_TOP)               {	       sp_globals.clip_ymax = (fix31)((fix31)EM_TOP * sp_globals.tcb0.yppo +  ((1<<sp_globals.multshift)/2));               sp_globals.clip_ymax = sp_globals.clip_ymax >> sp_globals.multshift;	       if (sp_globals.ymax > sp_globals.clip_ymax)		    sp_globals.ymax = sp_globals.clip_ymax;	       }            if (sp_globals.specs.flags & CLIP_BOTTOM)	       {	       sp_globals.clip_ymin = (fix31)((fix31)(-1 * EM_BOT) * sp_globals.tcb0.yppo +  ((1<<sp_globals.multshift)/2));               sp_globals.clip_ymin = sp_globals.clip_ymin >> sp_globals.multshift;	       sp_globals.clip_ymin = - sp_globals.clip_ymin;	       if (sp_globals.ymin < sp_globals.clip_ymin)		    sp_globals.ymin = sp_globals.clip_ymin;               }               break;       }#endifsp_globals.y_band.band_min = sp_globals.ymin;sp_globals.y_band.band_max = sp_globals.ymax - 1; sp_globals.xmin = (Pmin.x + sp_globals.pixrnd) >> sp_globals.pixshift;sp_globals.xmax = (Pmax.x + sp_globals.pixrnd) >> sp_globals.pixshift;#if INCL_2Dsp_globals.x_band.band_min = sp_globals.xmin - 1; /* subtract one pixel of "safety margin" */sp_globals.x_band.band_max = sp_globals.xmax /* - 1 + 1 */; /* Add one pixel of "safety margin" */#endif}                                  FUNCTION void reduce_band_size_out()GDECL{sp_globals.y_band.band_min = sp_globals.y_band.band_max - ((sp_globals.y_band.band_max - sp_globals.y_band.band_min) >> 1);#if INCL_2Dsp_globals.y_band.band_array_offset = sp_globals.y_band.band_min;#endif}FUNCTION boolean next_band_out()GDECL{fix15  tmpfix15;if (sp_globals.y_band.band_min <= sp_globals.ymin)    return FALSE;tmpfix15 = sp_globals.y_band.band_max - sp_globals.y_band.band_min;sp_globals.y_band.band_max = sp_globals.y_band.band_min - 1;sp_globals.y_band.band_min = sp_globals.y_band.band_max - tmpfix15;if (sp_globals.y_band.band_min < sp_globals.ymin)    sp_globals.y_band.band_min = sp_globals.ymin;#if INCL_2Dsp_globals.y_band.band_array_offset = sp_globals.y_band.band_min;#endifreturn TRUE;}#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -