亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? bitscale.c

?? 遠程桌面連接工具
?? C
?? 第 1 頁 / 共 4 頁
字號:
		    best_unscaled_rescale_x = rescale_x;		}	    }	}    }    if (best_unscaled)    {	*best = best_unscaled->vals;	*fpep = best_unscaled_fpe;	*dxp = 1.0;	*dyp = 1.0;	*sdxp = best_unscaled_sdx;	*sdyp = best_unscaled_sdy;	rescale_x = best_unscaled_rescale_x;	result = best_unscaled->bitmap;    }    else if (best_scaled)    {	*best = best_scaled->vals;	*fpep = best_fpe;	*dxp = best_dx;	*dyp = best_dy;	*sdxp = best_sdx;	*sdyp = best_sdy;	rescale_x = best_rescale_x;	result = best_scaled->bitmap;    }    else	result = NULL;    if (bitmap != NULL && (result == NULL || *dxp != 1.0 || *dyp != 1.0))    {	*fpep = bitmap_fpe;	FontParseXLFDName (bitmap->name.name, best, FONT_XLFD_REPLACE_NONE);	if (ComputeScaleFactors(best, best, dxp, dyp, sdxp, sdyp, &rescale_x))	    result = bitmap;	else	    result = NULL;    }    if (result && rescale_x != 1.0)    {	/* We have rescaled horizontally due to an XLFD width field.  Change	   the matrix appropriately */	vals->pixel_matrix[0] *= rescale_x;	vals->pixel_matrix[1] *= rescale_x;#ifdef NOTDEF	/* This would force the pointsize and pixelsize fields in the	   FONT property to display as matrices to more accurately	   report the font being supplied.  It might also break existing	   applications that expect a single number in that field. */	vals->values_supplied =	    vals->values_supplied & ~(PIXELSIZE_MASK | POINTSIZE_MASK) |	    PIXELSIZE_ARRAY;#else /* NOTDEF */	vals->values_supplied = vals->values_supplied & ~POINTSIZE_MASK;#endif /* NOTDEF */	/* Recompute and reround the FontScalablePtr values after	   rescaling for the new width. */	FontFileCompleteXLFD(vals, vals);    }    return result;}static FontEntryPtrFindPmfToScale(fpe, entry, vals, best, dxp, dyp, sdxp, sdyp, fpep)    FontPathElementPtr	fpe;    FontEntryPtr	entry;    FontScalablePtr	vals,			best;    double		*dxp, *sdxp,			*dyp, *sdyp;    FontPathElementPtr	*fpep;{    FontEntryPtr    result = NULL;    FontScaledPtr   scaled;    FontScalableExtraPtr   extra;    int i;    extra = entry->u.scalable.extra;    for (i = 0; i < extra->numScaled; i++)    {	double rescale_x;	scaled = &extra->scaled[i];	if (!scaled->bitmap)	    continue;	if (!ComputeScaleFactors(&scaled->vals, vals, dxp, dyp, sdxp, sdyp,				 &rescale_x))	    continue;	*best = scaled->vals;	*fpep = fpe;	result = scaled->bitmap;	if (rescale_x != 1.0)	{	    /* We have rescaled horizontally due to an XLFD width field.  Change	       the matrix appropriately */	    vals->pixel_matrix[0] *= rescale_x;	    vals->pixel_matrix[1] *= rescale_x;#ifdef NOTDEF	    /* This would force the pointsize and pixelsize fields in the	       FONT property to display as matrices to more accurately	       report the font being supplied.  It might also break existing	       applications that expect a single number in that field. */	    vals->values_supplied =		vals->values_supplied & ~(PIXELSIZE_MASK | POINTSIZE_MASK) |		PIXELSIZE_ARRAY;#else /* NOTDEF */	    vals->values_supplied = vals->values_supplied & ~POINTSIZE_MASK;#endif /* NOTDEF */	    /* Recompute and reround the FontScalablePtr values after	       rescaling for the new width. */	    FontFileCompleteXLFD(vals, vals);	}	break;    }    return result;}static longdoround(x)double x;{    return (x >= 0) ? (long)(x + .5) : (long)(x - .5);}static intcomputeProps(pf, wasStringProp, npf, isStringProp, nprops, xfactor, yfactor,	     sXfactor, sYfactor)    FontPropPtr pf;    char	*wasStringProp;    FontPropPtr npf;    char	*isStringProp;    unsigned int nprops;    double      xfactor, sXfactor,                yfactor, sYfactor;{    int         n;    int         count;    fontProp   *t;    double      rawfactor;    for (count = 0; nprops > 0; nprops--, pf++, wasStringProp++) {	n = sizeof(fontPropTable) / sizeof(fontProp);	for (t = fontPropTable; n && (t->atom != pf->name); n--, t++);	if (!n)	    continue;	switch (t->type) {	case scaledX:	    npf->value = doround(xfactor * (double)pf->value);	    rawfactor = sXfactor;	    break;	case scaledY:	    npf->value = doround(yfactor * (double)pf->value);	    rawfactor = sYfactor;	    break;	case unscaled:	    npf->value = pf->value;	    npf->name = pf->name;	    npf++;	    count++;	    *isStringProp++ = *wasStringProp;	    break;	}	if (t->type != unscaled)	{	    npf->name = pf->name;	    npf++;	    count++;	    npf->value = doround(rawfactor * (double)pf->value);	    npf->name = rawFontPropTable[t - fontPropTable].atom;	    npf++;	    count++;	    *isStringProp++ = *wasStringProp;	    *isStringProp++ = *wasStringProp;	}    }    return count;}static intComputeScaledProperties(sourceFontInfo, name, vals, dx, dy, sdx, sdy,			sWidth, pProps, pIsStringProp)    FontInfoPtr     sourceFontInfo;	/* the font to be scaled */    char	    *name;		/* name of resulting font */    FontScalablePtr vals;    double	    dx, sdx,		    dy, sdy;	/* scale factors in x and y directions */    long	    sWidth;	/* 1000-pixel average width */    FontPropPtr	    *pProps;	/* returns properties; preallocated */    char	    **pIsStringProp;  /* return booleans; preallocated */{    int         n;    char       *ptr1,               *ptr2;    char       *ptr3;    FontPropPtr fp;    fontProp   *fpt;    extern int  serverGeneration;    char	*isStringProp;    int		nProps;    if (fontGeneration != serverGeneration) {	initFontPropTable();	fontGeneration = serverGeneration;    }    nProps = NPROPS + 1 + sizeof(fontPropTable) / sizeof(fontProp) +			  sizeof(rawFontPropTable) / sizeof(fontProp);    fp = (FontPropPtr) xalloc(sizeof(FontPropRec) * nProps);    *pProps = fp;    if (!fp)	return 1;    isStringProp = (char *) xalloc (nProps);    *pIsStringProp = isStringProp;    if (!isStringProp)    {	xfree (fp);	return 1;    }    ptr2 = name;    for (fpt = fontNamePropTable, n = NPROPS;	 n; 	 fp++, fpt++, n--, isStringProp++)    {	if (*ptr2)	{	    ptr1 = ptr2 + 1;	    if (!(ptr2 = strchr(ptr1, '-'))) ptr2 = strchr(ptr1, '\0');	}	*isStringProp = 0;	switch (fpt->type) {	case atom:	    fp->value = MakeAtom(ptr1, ptr2 - ptr1, TRUE);	    *isStringProp = 1;	    break;	case truncate_atom:	    for (ptr3 = ptr1; *ptr3; ptr3++)		if (*ptr3 == '[')		    break;	    if (!*ptr3) ptr3 = ptr2;	    fp->value = MakeAtom(ptr1, ptr3 - ptr1, TRUE);	    *isStringProp = 1;	    break;	case pixel_size:	    fp->value = doround(vals->pixel_matrix[3]);	    break;	case point_size:	    fp->value = doround(vals->point_matrix[3] * 10.0);	    break;	case resolution_x:	    fp->value = vals->x;	    break;	case resolution_y:	    fp->value = vals->y;	    break;	case average_width:	    fp->value = vals->width;	    break;	case fontname:	    fp->value = MakeAtom(name, strlen(name), TRUE);	    *isStringProp = 1;	    break;	case raw_ascent:	    fp->value = sourceFontInfo->fontAscent * sdy;	    break;	case raw_descent:	    fp->value = sourceFontInfo->fontDescent * sdy;	    break;	case raw_pointsize:	    fp->value = (long)(72270.0 / (double)vals->y + .5);	    break;	case raw_pixelsize:	    fp->value = 1000;	    break;	case raw_average_width:	    fp->value = sWidth;	    break;	}	fp->name = fpt->atom;    }    n = NPROPS;    n += computeProps(sourceFontInfo->props, sourceFontInfo->isStringProp,		      fp, isStringProp, sourceFontInfo->nprops, dx, dy,		      sdx, sdy);    return n;}static void ScaleBitmap();static intcompute_xform_matrix(vals, dx, dy, xform, inv_xform, xmult, ymult)    FontScalablePtr	vals;    double		dx, dy, *inv_xform, *xmult, *ymult;    register double	*xform;{    double det, sintheta, costheta, tanphi;    double pixel = get_matrix_vertical_component(vals->pixel_matrix);    double pixelset = get_matrix_horizontal_component(vals->pixel_matrix);    if (pixel < EPS || pixelset < EPS) return 0;    /* Initialize the transformation matrix to the scaling factors */    xform[0] = dx / pixelset;    xform[1] = xform[2] = 0.0;    xform[3] = dy / pixel;/* Inline matrix multiply -- somewhat ugly to minimize register usage */#define MULTIPLY_XFORM(a,b,c,d) \{ \  register double aa = (a), bb = (b), cc = (c), dd = (d); \  register double temp; \  temp =     aa * xform[0] + cc * xform[1]; \  aa =       aa * xform[2] + cc * xform[3]; \  xform[1] = bb * xform[0] + dd * xform[1]; \  xform[3] = bb * xform[2] + dd * xform[3]; \  xform[0] = temp; \  xform[2] = aa; \}    /* Rescale the transformation matrix for size of source font */    MULTIPLY_XFORM(vals->pixel_matrix[0],		   vals->pixel_matrix[1],		   vals->pixel_matrix[2],		   vals->pixel_matrix[3]);    *xmult = xform[0];    *ymult = xform[3];    if (inv_xform == NULL) return 1;    /* Compute the determinant for use in inverting the matrix. */    det = xform[0] * xform[3] - xform[1] * xform[2];    /* If the determinant is tiny or zero, give up */    if (fabs(det) < EPS) return 0;    /* Compute the inverse */    inv_xform[0] = xform[3] / det;    inv_xform[1] = -xform[1] / det;    inv_xform[2] = -xform[2] / det;    inv_xform[3] = xform[0] / det;    return 1;}/* *  ScaleFont *  returns a pointer to the new scaled font, or NULL (due to AllocError). */static FontPtrScaleFont(opf, widthMult, heightMult, sWidthMult, sHeightMult, vals,	  newWidthMult, newHeightMult, sWidth)    FontPtr     opf;		/* originating font */    double      widthMult;	/* glyphs width scale factor */    double      heightMult;	/* glyphs height scale factor */    double      sWidthMult;	/* scalable glyphs width scale factor */    double      sHeightMult;	/* scalable glyphs height scale factor */    FontScalablePtr	vals;    double      *newWidthMult;	/* return: X component of glyphs width				   scale factor */    double      *newHeightMult;	/* return: Y component of glyphs height				   scale factor */    long	*sWidth;	/* return: average 1000-pixel width */{    FontPtr     pf;    FontInfoPtr pfi,                opfi;    BitmapFontPtr  bitmapFont,                obitmapFont;    CharInfoPtr pci,                opci;    int         nchars;		/* how many characters in the font */    int        *scratch;    int         i;    int         glyph;    int		firstCol, lastCol, firstRow, lastRow;    double	xform[4], inv_xform[4];    double	xmult, ymult;    int		totalwidth = 0, totalchars = 0;    int		inkindex1, inkindex2;#define OLDINDEX(i) (((i)/(lastCol - firstCol + 1) + \		      firstRow - opf->info.firstRow) * \		     (opf->info.lastCol - opf->info.firstCol + 1) + \		     (i)%(lastCol - firstCol + 1) + \		     firstCol - opf->info.firstCol)    extern int  bitmapGetBitmaps();    extern int  bitmapGetExtents();    extern int  bitmapGetGlyphs();    extern int  bitmapGetMetrics();    *sWidth = 0;    opfi = &opf->info;    glyph = opf->glyph;    obitmapFont = (BitmapFontPtr) opf->fontPrivate;    bitmapFont = 0;    pf = (FontPtr) xalloc(sizeof(FontRec));    if (!pf)	goto bail;    pf->refcnt = 0;    pf->maxPrivate = -1;    pf->devPrivates = (pointer *) 0;    pf->bit = opf->bit;    pf->byte = opf->byte;    pf->glyph = opf->glyph;    pf->scan = opf->scan;    pf->get_glyphs = bitmapGetGlyphs;    pf->get_metrics = bitmapGetMetrics;    pf->unload_font = bitmapUnloadScalable;    pf->unload_glyphs = NULL;    pfi = &pf->info;    *pfi = *opfi;    /* If charset subsetting specified in vals, determine what our range       needs to be for the output font */    if (vals->nranges)    {	int i;	pfi->allExist = 0;	firstCol = 255;	lastCol = 0;	firstRow = 255;	lastRow = 0;	for (i = 0; i < vals->nranges; i++)	{	    if (vals->ranges[i].min_char_high != vals->ranges[i].max_char_high)	    {		firstCol = opfi->firstCol;		lastCol = opfi->lastCol;	    }	    if (firstCol > vals->ranges[i].min_char_low)		firstCol = vals->ranges[i].min_char_low;	    if (lastCol < vals->ranges[i].max_char_low)		lastCol = vals->ranges[i].max_char_low;	    if (firstRow > vals->ranges[i].min_char_high)		firstRow = vals->ranges[i].min_char_high;	    if (lastRow < vals->ranges[i].max_char_high)		lastRow = vals->ranges[i].max_char_high;	}	if (firstCol > lastCol || firstRow > lastRow)	    goto bail;	if (firstCol < opfi->firstCol)	    firstCol = opfi->firstCol;	if (lastCol > opfi->lastCol)	    lastCol = opfi->lastCol;	if (firstRow < opfi->firstRow)	    firstRow = opfi->firstRow;	if (lastRow > opfi->lastRow)	    lastRow = opfi->lastRow;    }    else    {	firstCol = opfi->firstCol;	lastCol = opfi->lastCol;	firstRow = opfi->firstRow;	lastRow = opfi->lastRow;    }    bitmapFont = (BitmapFontPtr) xalloc(sizeof(BitmapFontRec));    if (!bitmapFont)	goto bail;    nchars = (lastRow - firstRow + 1) * (lastCol - firstCol + 1);    pfi->firstRow = firstRow;    pfi->lastRow = lastRow;    pfi->firstCol = firstCol;    pfi->lastCol = lastCol;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产视频一区| 亚洲图片欧美综合| 中文字幕一区二区5566日韩| 日韩欧美中文字幕制服| 欧美人伦禁忌dvd放荡欲情| 99精品一区二区三区| 福利一区在线观看| 99久久久国产精品免费蜜臀| 99久久精品一区| 成人黄色a**站在线观看| 成人av第一页| 成人激情动漫在线观看| 91蝌蚪porny九色| 色天天综合久久久久综合片| 欧美日韩免费观看一区二区三区| 欧美性感一区二区三区| 欧美一级淫片007| 久久婷婷色综合| 中文字幕欧美三区| 免费精品99久久国产综合精品| 久久人人爽人人爽| 色婷婷一区二区| 日本韩国视频一区二区| 在线欧美日韩国产| 777xxx欧美| 亚洲国产精品99久久久久久久久| 国产精品欧美极品| 亚洲伦在线观看| 久久国产精品区| 91麻豆视频网站| 精品少妇一区二区三区免费观看 | 欧美精品三级日韩久久| 6080yy午夜一二三区久久| 日韩精品一区二区三区在线 | 蜜臀av一区二区| 91精品国产91久久综合桃花| 欧美亚洲综合另类| 亚洲成人午夜电影| 久久久久久电影| 一区二区三区小说| 美女www一区二区| 色老头久久综合| 久久久精品综合| 亚洲动漫第一页| 懂色av一区二区在线播放| 欧美日韩免费一区二区三区视频| 99久久婷婷国产综合精品电影 | 精品三级在线看| 91精品国产综合久久精品麻豆 | 久久久久国色av免费看影院| 亚洲天堂免费看| 麻豆免费精品视频| 在线观看国产一区二区| 精品久久人人做人人爰| 亚洲成人免费影院| 成人黄色片在线观看| 日韩精品一区二区三区视频在线观看 | 精品国产乱码久久久久久影片| 亚洲美女在线一区| 久88久久88久久久| 欧美日韩高清一区二区不卡| 综合色天天鬼久久鬼色| 成人晚上爱看视频| 久久香蕉国产线看观看99| 亚洲一区二区三区在线| 国产一区福利在线| 国模冰冰炮一区二区| 欧美一区二区女人| 天天综合日日夜夜精品| 欧美日本精品一区二区三区| 亚洲第一搞黄网站| 欧美日韩精品综合在线| 亚洲一区二区三区在线| 欧美日韩专区在线| 肉丝袜脚交视频一区二区| 欧美高清一级片在线| 日韩在线一区二区三区| 欧美一级日韩免费不卡| 一区二区三区四区中文字幕| 欧美日韩精品综合在线| 日韩avvvv在线播放| 精品国产乱码久久久久久老虎| 麻豆91精品视频| 久久精品男人的天堂| 国产91精品一区二区麻豆亚洲| 国产欧美一区二区三区在线看蜜臀| 国产精品一色哟哟哟| 国产精品国产三级国产普通话三级| 国产麻豆欧美日韩一区| 国产亚洲综合性久久久影院| 成人h精品动漫一区二区三区| 国产精品二三区| 欧美亚洲高清一区| 麻豆传媒一区二区三区| 中文字幕高清一区| 91国内精品野花午夜精品| 偷拍一区二区三区| 久久天天做天天爱综合色| 94-欧美-setu| 亚洲国产视频在线| 欧美电视剧在线观看完整版| 激情五月激情综合网| 日韩欧美一区二区在线视频| 懂色av一区二区三区蜜臀| 亚洲综合久久久| 精品国产乱码久久久久久影片| 成人免费的视频| 亚洲成人精品一区| 亚洲国产精品ⅴa在线观看| 欧美性大战久久久久久久| 精品一区二区成人精品| 自拍偷自拍亚洲精品播放| 欧美精品乱人伦久久久久久| 成人黄色av网站在线| 日韩avvvv在线播放| 成人免费在线观看入口| 日韩欧美亚洲另类制服综合在线| av成人老司机| 久久99精品久久只有精品| 一区二区三区产品免费精品久久75| 日韩一级高清毛片| 日本高清不卡在线观看| 国产在线视频一区二区三区| 亚洲综合偷拍欧美一区色| 亚洲国产精品精华液ab| 精品国产电影一区二区| 欧美日韩在线不卡| 91热门视频在线观看| 国产精品一区二区在线观看网站| 同产精品九九九| 亚洲夂夂婷婷色拍ww47| 欧美国产日本韩| 精品三级在线观看| 欧美精品少妇一区二区三区| 在线精品亚洲一区二区不卡| 成人性生交大片| 国产福利不卡视频| 黄一区二区三区| 乱一区二区av| 免费在线观看精品| 婷婷夜色潮精品综合在线| 一区二区三区日本| 国产精品伦一区二区三级视频| 久久男人中文字幕资源站| 欧美一区二区久久| 欧美精品色一区二区三区| 欧美日韩国产a| 777a∨成人精品桃花网| 91精品国产综合久久精品图片 | 午夜av电影一区| 亚洲成人福利片| 亚洲国产视频直播| 亚洲欧美日韩一区二区| 国产精品私人影院| 国产精品三级av在线播放| 亚洲欧美一区二区视频| 国产精品色在线观看| 中文字幕在线不卡一区 | 亚洲小说欧美激情另类| 亚洲成人免费视频| 男男gaygay亚洲| 激情五月婷婷综合| 国产成人免费视频精品含羞草妖精| 国产一区二三区| 国产91在线|亚洲| 成人高清免费在线播放| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 无码av免费一区二区三区试看| 中文字幕制服丝袜一区二区三区| 国产精品天天摸av网| 国产精品色一区二区三区| 国产精品理论片在线观看| 亚洲免费视频中文字幕| 亚洲成人av在线电影| 九九九精品视频| 成人久久18免费网站麻豆 | 国产精品中文字幕日韩精品| 精品夜夜嗨av一区二区三区| 精品亚洲欧美一区| 99久久久久久| 日韩一区二区三区在线视频| 国产欧美一区二区精品久导航 | 久久久久久久久久久电影| 中文字幕一区二区三区精华液| 五月综合激情网| 成人激情黄色小说| 欧美精品在欧美一区二区少妇| 亚洲精品一区二区三区精华液| 亚洲欧美日韩中文播放| 久久精品国产亚洲高清剧情介绍| 懂色av一区二区三区蜜臀| 欧美久久久久久蜜桃| 中文字幕巨乱亚洲| 免费国产亚洲视频| 色噜噜狠狠一区二区三区果冻| 欧美白人最猛性xxxxx69交| 亚洲日本青草视频在线怡红院| 另类中文字幕网| 精品视频资源站| 亚洲视频香蕉人妖|