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

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

?? liangbarsk.cpp

?? 良友棟裁減算法裁減多邊形
?? CPP
字號:
#include<GL/glut.h>
#include<math.h>

const int nVerts=6;//多邊形頂點數(shù)
const int maxVerts=10;//裁剪后最大頂點個數(shù)
int countVerts=0;//頂點計數(shù)
bool flag=true;

class wcPt2D
{
private:
	GLfloat x,y;
public:
	wcPt2D()
	{
		x=y=0.0;
	}
	void setCoords(GLfloat xCoord,GLfloat yCoord)
	{
		x=xCoord;
		y=yCoord;
	}
	GLfloat getx()const
	{
		return x;
	}
	GLfloat gety()const
	{
		return y;
	}
};

wcPt2D Pverts[nVerts];//原多邊形
wcPt2D CPverts[maxVerts];//裁剪后多邊形
wcPt2D winMin,winMax;//定義裁剪窗口

GLint clipTest(GLfloat p,GLfloat q,GLfloat &u1,GLfloat &u2)
{
	GLfloat r;
	GLint returnValue=true;
	if(p<0.0)
	{
		r=q/p;
		if(r>u2)
			returnValue=false;
		else
			if(r>u1)
				u1=r;
	}
	else
		if(p>0.0)
		{
			r=q/p;
			if(r<u1)
				returnValue=false;
			else if(r<u2)
				u2=r;
		}
		else
			if(q<0.0)
				returnValue=false;
	return (returnValue);
}

void isAddVerts(wcPt2D p1,wcPt2D p2)//逆時針添加可能的裁剪窗口頂點
{
	if(p1.getx()==winMax.getx())//p1在右邊界
	{
		if(p1.gety()!=winMax.gety())
		{
			if(p2.getx()!=winMax.getx())
			{
				CPverts[countVerts].setCoords(winMax.getx(),winMax.gety());
				countVerts++;
				if(p2.gety()!=winMax.gety())
				{
					CPverts[countVerts].setCoords(winMin.getx(),winMax.gety());
					countVerts++;
					if(p2.getx()!=winMin.getx())
					{
						CPverts[countVerts].setCoords(winMin.getx(),winMin.gety());
						countVerts++;
					}
				}
			}
		}
		else
		{
			if(p2.gety()!=winMax.gety())
			{
				CPverts[countVerts].setCoords(winMin.getx(),winMax.gety());
				countVerts++;
				if(p2.getx()!=winMin.getx())
				{
					CPverts[countVerts].setCoords(winMin.getx(),winMin.gety());
					countVerts++;
				}
			}
		}
		
	}

	else if(p1.gety()==winMax.gety())//p1在上邊界
	{
		if(p1.getx()!=winMin.getx())
		{
			if(p2.gety()!=winMax.gety())
			{
				CPverts[countVerts].setCoords(winMin.getx(),winMax.gety());
				countVerts++;
				if(p2.getx()!=winMin.getx())
				{
					CPverts[countVerts].setCoords(winMin.getx(),winMin.gety());
					countVerts++;
					if(p2.gety()!=winMin.gety())
					{
						CPverts[countVerts].setCoords(winMax.getx(),winMin.gety());
						countVerts++;
					}
				}
			}
		}
		else
		{
			if(p2.getx()!=winMin.getx())
			{
				CPverts[countVerts].setCoords(winMin.getx(),winMin.gety());
				countVerts++;
				if(p2.gety()!=winMin.gety())
				{
					CPverts[countVerts].setCoords(winMax.getx(),winMin.gety());
					countVerts++;
				}
			}
		}
		
	}
	
	else if(p1.getx()==winMin.getx())//p1在左邊界
	{
		if(p1.gety()!=winMin.gety())
		{
			if(p2.getx()!=winMin.getx())
			{
				CPverts[countVerts].setCoords(winMin.getx(),winMin.gety());
				countVerts++;
				if(p2.gety()!=winMin.gety())
				{
					CPverts[countVerts].setCoords(winMax.getx(),winMin.gety());
					countVerts++;
					if(p2.getx()!=winMax.getx())
					{
						CPverts[countVerts].setCoords(winMax.getx(),winMax.gety());
						countVerts++;
					}
				}
			}
		}
		else
		{
			if(p2.gety()!=winMin.gety())
			{
				CPverts[countVerts].setCoords(winMax.getx(),winMin.gety());
				countVerts++;
				if(p2.getx()!=winMax.getx())
				{
					CPverts[countVerts].setCoords(winMax.getx(),winMax.gety());
					countVerts++;
				}
			}
		}
		
	}

	else if(p1.gety()==winMin.gety())//p1在下邊界
	{
		if(p1.getx()!=winMax.getx())
		{
			if(p2.gety()!=winMin.gety())
			{
				CPverts[countVerts].setCoords(winMax.getx(),winMin.gety());
				countVerts++;
				if(p2.getx()!=winMax.getx())
				{
					CPverts[countVerts].setCoords(winMax.getx(),winMax.gety());
					countVerts++;
					if(p2.gety()!=winMax.gety())
					{
						CPverts[countVerts].setCoords(winMin.getx(),winMax.gety());
						countVerts++;
					}
				}
			}
		}
		else
		{
			if(p2.getx()!=winMax.getx())
			{
				CPverts[countVerts].setCoords(winMax.getx(),winMax.gety());
				countVerts++;
				if(p2.gety()!=winMax.gety())
				{
					CPverts[countVerts].setCoords(winMin.getx(),winMax.gety());
					countVerts++;
				}
			}
		}
		
	}
	
}

bool lineClipLiangBarsk(wcPt2D p1,wcPt2D p2)
{
	GLfloat u1=0.0,u2=1.0,dx=p2.getx()-p1.getx(),dy;

	if(clipTest(-dx,p1.getx()-winMin.getx(),u1,u2))
		if(clipTest(dx,winMax.getx()-p1.getx(),u1,u2))
		{
			dy=p2.gety()-p1.gety();
			if(clipTest(-dy,p1.gety()-winMin.gety(),u1,u2))
				if(clipTest(dy,winMax.gety()-p1.gety(),u1,u2))
				{
					if(u1==0.0)
					{
						CPverts[countVerts].setCoords(p1.getx()+u2*dx,p1.gety()+u2*dy);
						countVerts++;
					}
					else if(u1>0.0&&u2<=1.0)
					{
						wcPt2D tmp;
						tmp.setCoords(p1.getx()+u1*dx,p1.gety()+u1*dy);
						if(!flag)
						{
							isAddVerts(CPverts[countVerts-1],tmp);
							flag=true;
						}
						CPverts[countVerts].setCoords(tmp.getx(),tmp.gety());
						countVerts++;
						CPverts[countVerts].setCoords(p1.getx()+u2*dx,p1.gety()+u2*dy);
						countVerts++;
					}
					return true;
				}
		}
	return false;
}

void init()
{
	glClearColor(1.0,1.0,1.0,0.0);

	glMatrixMode(GL_PROJECTION);
	gluOrtho2D(0.0,200.0,0.0,150.0);
}
void initPolygon()
{
	Pverts[0].setCoords(50.0,50.0);
	Pverts[1].setCoords(120.0,60.0);
	Pverts[2].setCoords(150.0,80.0);
	Pverts[3].setCoords(110.0,130.0);
	Pverts[4].setCoords(70.0,110.0);
	Pverts[5].setCoords(30.0,75.0);
}
void initClipWindow()
{
	winMin.setCoords(35.0,55.0);
	winMax.setCoords(110.0,90.0);
}
void showClipWindow()
{
	glBegin(GL_LINE_LOOP);
	glVertex2f(winMin.getx(),winMin.gety());
	glVertex2f(winMax.getx(),winMin.gety());
	glVertex2f(winMax.getx(),winMax.gety());
	glVertex2f(winMin.getx(),winMax.gety());
	glEnd();
}
void showPolygon(wcPt2D *verts,int n)
{
	glBegin(GL_POLYGON);
	for(int i=0;i<n;i++)
		glVertex2f(verts[i].getx(),verts[i].gety());
	glEnd();
}
void clip()
{
	for(int i=0;i<nVerts;i++)
	{
		if(!lineClipLiangBarsk(Pverts[i],Pverts[(i+1)%nVerts]))
			flag=false;
	}
	
}
void displayFcn()
{
	glClear(GL_COLOR_BUFFER_BIT);
	glColor3f(0.0,0.0,1.0);
	initPolygon();
	initClipWindow();
	showPolygon(Pverts,nVerts);//原多邊形顯示
	glColor3f(0.0,0.0,0.0);
	showClipWindow();//裁剪窗口顯示
	glColor3f(1.0,0.0,0.0);
	clip();
	showPolygon(CPverts,countVerts);
	glFlush();
}

int main(int argc,char **argv)
{
	glutInit(&argc,argv);
	glutInitDisplayMode(GLUT_SINGLE|GLUT_RGB);
	glutInitWindowPosition(50,100);
	glutInitWindowSize(400,300);
	glutCreateWindow("Liang-Barsk Programme");

	init();
	glutDisplayFunc(displayFcn);
	glutMainLoop();
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲同性gay激情无套| 99久久99久久精品免费观看| 精品亚洲porn| 国产精品中文字幕日韩精品| 狠狠色丁香九九婷婷综合五月| 国产精品青草久久| 国产午夜精品福利| 久久久av毛片精品| 一本大道av一区二区在线播放| 日韩综合小视频| 成人欧美一区二区三区| 欧美精品一区二区在线播放| 国产女人18水真多18精品一级做| 一区二区三区在线观看国产| 亚洲18女电影在线观看| 免费高清视频精品| 在线亚洲一区观看| 最新日韩av在线| 国产精品一线二线三线| 在线观看日韩国产| 国产精品―色哟哟| 国产精品 日产精品 欧美精品| 欧美性大战xxxxx久久久| 亚洲欧美综合另类在线卡通| 国产无遮挡一区二区三区毛片日本| 综合久久久久久| 另类专区欧美蜜桃臀第一页| 337p亚洲精品色噜噜狠狠| 久久蜜桃av一区精品变态类天堂| 亚洲成人免费av| 这里只有精品99re| 欧美精品一区二区三区久久久| 一区二区激情小说| 国产成人亚洲综合a∨猫咪| 91精品国产综合久久国产大片| 久久精品人人爽人人爽| 欧美韩国日本综合| 色视频成人在线观看免| 欧美日韩在线观看一区二区| 一区二区三区在线免费播放| 麻豆中文一区二区| 久久亚洲捆绑美女| 国产成人亚洲精品狼色在线 | 国产91色综合久久免费分享| 亚洲制服丝袜av| 日韩视频永久免费| 性欧美大战久久久久久久久| 中文字幕免费不卡| 亚洲国产成人在线| 国产午夜亚洲精品不卡| 制服丝袜激情欧洲亚洲| 欧美视频完全免费看| 日本精品一区二区三区高清| 成人免费看黄yyy456| 国产精品99久久久久久似苏梦涵| 久久精品国产精品亚洲红杏| 免费观看在线色综合| 蜜桃视频在线观看一区二区| 日本午夜精品一区二区三区电影 | 久久精品视频在线看| 26uuu另类欧美亚洲曰本| 欧美成人女星排行榜| 欧美成人一区二区三区| 在线成人小视频| 日韩一区二区三区视频| 91精品国产入口在线| 欧美一级理论片| 精品久久久久久久人人人人传媒| 欧美成人激情免费网| 精品欧美一区二区久久| 久久亚洲影视婷婷| 国产精品夫妻自拍| 亚洲一区中文日韩| 日本不卡不码高清免费观看| 久久99精品久久久久久国产越南| 乱一区二区av| 国产91精品精华液一区二区三区 | 国产寡妇亲子伦一区二区| 国产福利一区二区| 99久久99精品久久久久久 | 国产自产v一区二区三区c| 精品中文字幕一区二区| 国产成人免费网站| 91麻豆成人久久精品二区三区| 91麻豆产精品久久久久久| 欧美日韩国产美| 欧美变态tickle挠乳网站| 中文字幕欧美激情一区| 夜夜亚洲天天久久| 亚洲国产精品久久久久秋霞影院| 免费人成网站在线观看欧美高清| 国产另类ts人妖一区二区| 99re亚洲国产精品| 欧美久久久久免费| 久久综合久久综合久久综合| 中文字幕一区二区三区在线观看| 亚洲综合色丁香婷婷六月图片| 日韩黄色免费电影| 精品一区二区久久| 99精品视频在线免费观看| 欧美日韩国产高清一区二区三区| 久久久久久久久一| 亚洲一区二区在线观看视频| 日韩不卡一二三区| 国产麻豆精品theporn| 色婷婷综合久久久久中文| 精品嫩草影院久久| 一区二区三区不卡视频| 成人亚洲精品久久久久软件| 精品盗摄一区二区三区| 五月婷婷色综合| 欧洲精品一区二区| 亚洲欧美一区二区三区国产精品| 国产suv精品一区二区6| 2023国产精品视频| 久久精品国产秦先生| 91精品国产麻豆国产自产在线 | 亚洲国产精品嫩草影院| 91免费版在线| 亚洲日穴在线视频| 99天天综合性| 亚洲欧美影音先锋| 成人午夜免费av| 亚洲国产高清不卡| 懂色av一区二区三区免费观看| 久久久蜜臀国产一区二区| 老司机一区二区| 日韩精品一区二区三区swag | 在线日韩av片| 夜夜亚洲天天久久| 在线观看日韩毛片| 洋洋av久久久久久久一区| 日本黄色一区二区| 亚洲综合免费观看高清在线观看| 99久久99久久精品免费看蜜桃| 国产精品欧美极品| 91在线一区二区| 亚洲美女视频在线观看| 国产精品久久久久aaaa| 成人h动漫精品一区二区| 日韩一区有码在线| 色综合久久久网| 亚洲一区二区三区三| 欧美精品日韩一本| 麻豆视频观看网址久久| 精品久久一二三区| 成人综合在线观看| 中文字幕一区二区三区乱码在线| 99久久综合色| 亚洲午夜激情网页| 91精品国产品国语在线不卡 | 在线观看免费视频综合| 天天色图综合网| 日韩精品一区二区三区在线| 国产精品自拍在线| 亚洲色图一区二区三区| 欧美视频一区二区| 久久99日本精品| 中文字幕一区二区三区四区不卡| 在线观看视频一区二区欧美日韩| 日韩成人午夜电影| 国产午夜精品在线观看| 在线精品视频免费播放| 美女视频黄免费的久久| 欧美激情中文字幕一区二区| 日本精品视频一区二区| 久久99国产精品久久99果冻传媒| 国产肉丝袜一区二区| 在线影视一区二区三区| 蜜臀av国产精品久久久久| 国产精品人人做人人爽人人添| 在线观看国产一区二区| 韩国一区二区三区| 亚洲美女淫视频| 精品国产亚洲一区二区三区在线观看| 成人福利电影精品一区二区在线观看 | 3d成人h动漫网站入口| 国产精品亚洲午夜一区二区三区| 亚洲色图第一区| 91精品国产91久久综合桃花| 国产成a人亚洲精品| 偷拍日韩校园综合在线| 中文幕一区二区三区久久蜜桃| 欧美日韩中字一区| 粉嫩aⅴ一区二区三区四区| 五月天久久比比资源色| 国产精品久久久久四虎| 91精品视频网| 一本久久a久久精品亚洲| 久久不见久久见免费视频1| 一区二区三区在线观看视频| 久久综合久久鬼色| 欧美日韩国产系列| 99re热视频精品| 国产美女精品一区二区三区| 亚洲综合在线电影| 国产精品久久久久一区二区三区| 日韩欧美一级二级三级久久久| 91福利区一区二区三区| 国产99久久久国产精品潘金网站|