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

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

?? midash.c

?? linux下電話本所依賴的一些圖形庫
?? C
字號:
/***********************************************************Copyright 1987, 1998  The Open GroupAll Rights Reserved.The above copyright notice and this permission notice shall be included inall copies or substantial portions of the Software.THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS ORIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THEOPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER INAN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR INCONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.Except as contained in this notice, the name of The Open Group shall not beused in advertising or otherwise to promote the sale, use or other dealingsin this Software without prior written authorization from The Open Group.Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts.                        All Rights ReservedPermission to use, copy, modify, and distribute this software and its documentation for any purpose and without fee is hereby granted, provided that the above copyright notice appear in all copies and thatboth that copyright notice and this permission notice appear in supporting documentation, and that the name of Digital not beused in advertising or publicity pertaining to distribution of thesoftware without specific, written prior permission.  DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDINGALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALLDIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES ORANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THISSOFTWARE.******************************************************************//* $TOG: midash.c /main/14 1998/02/09 14:46:34 kaleb $ */#include <config.h>#include "mi.h"static miDashPtrCheckDashStorage(miDashPtr *ppseg, int nseg, int *pnsegMax);/* return a list of DashRec.  there will be an extraentry at the end holding the last point of the polyline.   this means that the code that actually draws dashes canget a pair of points for every dash.  only the point in the lastdash record is useful; the other fields are not used.   nseg is the number of segments, not the number of points.example:   dash1.start   dash2.start   dash3.start   last-pointdefines a list of segments   (dash1.pt, dash2.pt)   (dash2.pt, dash3.pt)   (dash3.pt, last-point)and nseg == 3.NOTE:    EVEN_DASH == ~ODD_DASHNOTE ALSO:    miDashLines may return 0 segments, going from pt[0] to pt[0] with one dash.*/enum { EVEN_DASH=0, ODD_DASH=1 };#define sign(x) ((x)>0)?1:( ((x)<0)?-1:0 )miDashPtrmiDashLine(int npt, GdkPoint *ppt, unsigned int nDash,           unsigned char *pDash, unsigned int offset, int *pnseg){    GdkPoint pt1, pt2;    int lenCur;		/* npt used from this dash */    int lenMax;		/* npt in this dash */    int iDash = 0;	/* index of current dash */    int which;		/* EVEN_DASH or ODD_DASH */    miDashPtr pseg;	/* list of dash segments */    miDashPtr psegBase;	/* start of list */    int nseg = 0;	/* number of dashes so far */    int nsegMax = 0;	/* num segs we can fit in this list */    int x, y, len;    int adx, ady, signdx, signdy;    int du, dv, e1, e2, e, base_e = 0;    lenCur = offset;    which = EVEN_DASH;    while(lenCur >= pDash[iDash])    {	lenCur -= pDash[iDash];	iDash++;	if (iDash >= nDash)	    iDash = 0;	which = ~which;    }    lenMax = pDash[iDash];    psegBase = (miDashPtr)NULL;    pt2 = ppt[0];		/* just in case there is only one point */    while(--npt)    {	if (PtEqual(ppt[0], ppt[1]))	{	    ppt++;	    continue;		/* no duplicated points in polyline */	}	pt1 = *ppt++;	pt2 = *ppt;	adx = pt2.x - pt1.x;	ady = pt2.y - pt1.y;	signdx = sign(adx);	signdy = sign(ady);	adx = abs(adx);	ady = abs(ady);	if (adx > ady)	{	    du = adx;	    dv = ady;	    len = adx;	}	else	{	    du = ady;	    dv = adx;	    len = ady;	}	e1 = dv * 2;	e2 = e1 - 2*du;	e = e1 - du;	x = pt1.x;	y = pt1.y;	nseg++;	pseg = CheckDashStorage(&psegBase, nseg, &nsegMax);	if (!pseg)	    return (miDashPtr)NULL;	pseg->pt = pt1;	pseg->e1 = e1;	pseg->e2 = e2;	base_e = pseg->e = e;	pseg->which = which;	pseg->newLine = 1;	while (len--)	{	    if (adx > ady)	    {		/* X_AXIS */		if (((signdx > 0) && (e < 0)) ||		    ((signdx <=0) && (e <=0))		   )		{		    e += e1;		}		else		{		    y += signdy;		    e += e2;		}		x += signdx;	    }	    else	    {		/* Y_AXIS */		if (((signdx > 0) && (e < 0)) ||		    ((signdx <=0) && (e <=0))		   )		{		    e +=e1;		}		else		{		    x += signdx;		    e += e2;		}		y += signdy;	    }	    lenCur++;	    if (lenCur >= lenMax && (len || npt <= 1))	    {		nseg++;		pseg = CheckDashStorage(&psegBase, nseg, &nsegMax);		if (!pseg)		    return (miDashPtr)NULL;		pseg->pt.x = x;		pseg->pt.y = y;		pseg->e1 = e1;		pseg->e2 = e2;		pseg->e = e;		which = ~which;		pseg->which = which;		pseg->newLine = 0;		/* move on to next dash */		iDash++;		if (iDash >= nDash)		    iDash = 0;		lenMax = pDash[iDash];		lenCur = 0;	    }	} /* while len-- */    } /* while --npt */    if (lenCur == 0 && nseg != 0)    {	nseg--;	which = ~which;    }    *pnseg = nseg;    pseg = CheckDashStorage(&psegBase, nseg+1, &nsegMax);    if (!pseg)	return (miDashPtr)NULL;    pseg->pt = pt2;    pseg->e = base_e;    pseg->which = which;    pseg->newLine = 0;    return psegBase;} #define NSEGDELTA 16/* returns a pointer to the pseg[nseg-1], growing the storage asnecessary.  this interface seems unnecessarily cumbersome.*/static miDashPtrCheckDashStorage(miDashPtr *ppseg, int nseg, int *pnsegMax)#if 0miDashPtr *ppseg;		/* base pointer */int nseg;			/* number of segment we want to write to */int *pnsegMax;			/* size (in segments) of list so far */#endif{    if (nseg > *pnsegMax)    {	miDashPtr newppseg;	*pnsegMax += NSEGDELTA;	newppseg = (miDashPtr)g_realloc(*ppseg,				       (*pnsegMax)*sizeof(miDashRec));	if (!newppseg)	{	    g_free(*ppseg);	    return (miDashPtr)NULL;	}	*ppseg = newppseg;    }    return(*ppseg+(nseg-1));}voidmiStepDash (int dist, int *pDashIndex, unsigned char *pDash,            int numInDashList, int *pDashOffset)#if 0    int dist;			/* distance to step */    int *pDashIndex;		/* current dash */    unsigned char *pDash;	/* dash list */    int numInDashList;		/* total length of dash list */    int *pDashOffset;		/* offset into current dash */#endif{    int	dashIndex, dashOffset;    int totallen;    int	i;        dashIndex = *pDashIndex;    dashOffset = *pDashOffset;    if (dist < pDash[dashIndex] - dashOffset)    {	*pDashOffset = dashOffset + dist;	return;    }    dist -= pDash[dashIndex] - dashOffset;    if (++dashIndex == numInDashList)	dashIndex = 0;    totallen = 0;    for (i = 0; i < numInDashList; i++)	totallen += pDash[i];    if (totallen <= dist)	dist = dist % totallen;    while (dist >= pDash[dashIndex])    {	dist -= pDash[dashIndex];	if (++dashIndex == numInDashList)	    dashIndex = 0;    }    *pDashIndex = dashIndex;    *pDashOffset = dist;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
av动漫一区二区| 国产高清不卡一区二区| 夜夜操天天操亚洲| 一区二区三区日韩欧美| 综合在线观看色| 国产精品久久二区二区| 亚洲天堂网中文字| 亚洲一区二区综合| 日韩二区在线观看| 韩国av一区二区三区在线观看| 日韩精品欧美精品| 国产91丝袜在线18| 在线视频国内一区二区| 久久综合色8888| 亚洲欧洲国产日韩| 蜜桃传媒麻豆第一区在线观看| 国产自产高清不卡| 91精品办公室少妇高潮对白| 日韩一级在线观看| 中文字幕一区av| 国产一区二区三区免费播放| 99久久综合国产精品| 91精品国产一区二区人妖| 国产欧美日韩亚州综合| 欧美一级二级三级乱码| 久久久久免费观看| 日本不卡不码高清免费观看| 色噜噜夜夜夜综合网| 久久久久9999亚洲精品| 日本aⅴ亚洲精品中文乱码| 色伊人久久综合中文字幕| 久久亚洲二区三区| 精品一区二区三区免费播放| 欧美喷潮久久久xxxxx| 日韩伦理免费电影| 欧美欧美午夜aⅴ在线观看| 国产亚洲婷婷免费| 经典三级在线一区| 精品少妇一区二区三区在线播放| 亚洲一区二区三区在线播放| 99在线热播精品免费| 中文字幕亚洲一区二区va在线| 懂色av一区二区三区免费看| 久久一留热品黄| 国产成人免费视| 日韩一区欧美一区| 欧美日韩午夜在线视频| 午夜久久久久久久久| 91精品国产欧美日韩| 理论电影国产精品| 亚洲国产岛国毛片在线| 99精品1区2区| 日本亚洲一区二区| 久久亚洲精精品中文字幕早川悠里| 久久国产精品99久久久久久老狼| 欧美精品一区二区三区蜜臀| 国产成人精品免费| 悠悠色在线精品| 777xxx欧美| 国产精品一区二区91| 一区二区三区精密机械公司| 欧美精品精品一区| proumb性欧美在线观看| 日本欧美一区二区在线观看| 日韩精品中午字幕| 在线观看日韩高清av| 久久se精品一区二区| 亚洲国产欧美日韩另类综合| 精品国产免费久久| 欧美视频三区在线播放| 蜜臀国产一区二区三区在线播放 | 亚洲国产sm捆绑调教视频| 91社区在线播放| 日韩高清国产一区在线| 中文字幕高清一区| 日韩精品专区在线影院观看| 成人一级片在线观看| 午夜精品视频在线观看| 日韩精品在线一区二区| 欧美在线一二三| 岛国精品在线观看| 黑人巨大精品欧美黑白配亚洲| 亚洲欧洲精品一区二区三区 | 免费成人小视频| 国产精品网站一区| 日韩视频免费观看高清完整版 | 欧美日韩精品免费| 99在线精品一区二区三区| 美女视频一区在线观看| 亚洲综合视频在线观看| 中文字幕乱码一区二区免费| www久久精品| 亚洲精品一区在线观看| 日韩一区二区免费在线观看| 91福利在线导航| 日本久久精品电影| 色婷婷综合久久久中文一区二区| 国产精品综合一区二区| 污片在线观看一区二区| 无码av中文一区二区三区桃花岛| 国产精品素人视频| 亚洲国产精品成人综合| 国产日产欧美精品一区二区三区| 欧美日韩精品一区二区天天拍小说| 91在线视频播放| 欧美色图免费看| 欧美精品在线观看播放| 精品少妇一区二区三区免费观看| 91麻豆精品国产91久久久久久| 99re这里只有精品首页| 91美女片黄在线观看91美女| 在线看国产一区| 91麻豆精品国产91久久久久| 久久免费的精品国产v∧| 中文字幕不卡的av| 香蕉乱码成人久久天堂爱免费| 亚洲国产日产av| 国产一区视频在线看| 99re这里只有精品6| 欧美一区二区三区婷婷月色| 久久久美女艺术照精彩视频福利播放| 久久亚洲一级片| 日韩1区2区日韩1区2区| 成人在线一区二区三区| 欧美色老头old∨ideo| 国产欧美一区在线| 精品中文av资源站在线观看| 99热在这里有精品免费| 久久久亚洲精品石原莉奈| 一区二区三区在线播| 国产乱子轮精品视频| 在线观看91av| 亚洲gay无套男同| 色婷婷综合在线| 一区视频在线播放| 久久成人18免费观看| 欧美日韩一区三区四区| 中文字幕一区二区三区精华液| 国产精品66部| 精品国产1区二区| 国产一区欧美日韩| 日韩精品一区二区三区在线 | 中文字幕av免费专区久久| 国内成人免费视频| 久久中文娱乐网| 国产在线精品一区二区三区不卡 | 国产亲近乱来精品视频| 国产精品一区二区男女羞羞无遮挡| 欧美不卡一区二区三区四区| 日韩avvvv在线播放| 欧美一区二区三区视频| 麻豆传媒一区二区三区| 精品国产3级a| 成人18视频在线播放| 亚洲精品久久久蜜桃| 91视频免费看| 日本一不卡视频| 欧美军同video69gay| 久久成人18免费观看| 中文字幕亚洲在| 日韩精品资源二区在线| 99久久免费精品高清特色大片| 亚洲一区精品在线| 欧美不卡123| av亚洲精华国产精华精| 视频一区在线播放| 国产精品国产自产拍在线| 欧美三级在线看| 韩国欧美一区二区| 日韩国产在线观看一区| 中文字幕制服丝袜一区二区三区| 欧美日韩高清一区二区| 99综合电影在线视频| 一二三区精品视频| 国产嫩草影院久久久久| 日韩精品一区二区三区视频播放 | 性感美女久久精品| 国产欧美日韩三级| 久久影院午夜片一区| 欧美午夜影院一区| 色综合久久综合| av电影在线观看完整版一区二区| 国产一区高清在线| 麻豆成人免费电影| 九九视频精品免费| 日本欧美一区二区三区乱码| 亚洲精选一二三| 亚洲美女在线国产| 亚洲一卡二卡三卡四卡 | 日韩毛片视频在线看| 国产精品美女久久久久久久久 | 精品国产精品一区二区夜夜嗨| 欧美三级电影在线观看| 欧美三级中文字幕在线观看| 91蜜桃视频在线| 欧美三级在线看| 26uuu国产电影一区二区| 欧美国产欧美亚州国产日韩mv天天看完整| 日韩欧美视频一区| 国产精品你懂的在线|