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

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

?? robot.cpp

?? 用于機器人開發環境的仿真程序
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
								"OpenGL",							// Class Name
								title,								// Window Title
								dwStyle |							// Defined Window Style
								WS_CLIPSIBLINGS |					// Required Window Style
								WS_CLIPCHILDREN,					// Required Window Style
								0, 0,								// Window Position
								WindowRect.right-WindowRect.left,	// Calculate Window Width
								WindowRect.bottom-WindowRect.top,	// Calculate Window Height
								NULL,								// No Parent Window
								hMenu,								// No Menu
								hInstance,							// Instance
								NULL)))								// Dont Pass Anything To WM_CREATE
	{
		KillGLWindow();								// Reset The Display
		MessageBox(NULL,"Window Creation Error.","ERROR",MB_OK|MB_ICONEXCLAMATION);
		return FALSE;								// Return FALSE
	}

	static	PIXELFORMATDESCRIPTOR pfd=				// pfd Tells Windows How We Want Things To Be
	{
		sizeof(PIXELFORMATDESCRIPTOR),				// Size Of This Pixel Format Descriptor
		1,											// Version Number
		PFD_DRAW_TO_WINDOW |						// Format Must Support Window
		PFD_SUPPORT_OPENGL |						// Format Must Support OpenGL
		PFD_DOUBLEBUFFER,							// Must Support Double Buffering
		PFD_TYPE_RGBA,								// Request An RGBA Format
		bits,										// Select Our Color Depth
		0, 0, 0, 0, 0, 0,							// Color Bits Ignored
		0,											// No Alpha Buffer
		0,											// Shift Bit Ignored
		0,											// No Accumulation Buffer
		0, 0, 0, 0,									// Accumulation Bits Ignored
		16,											// 16Bit Z-Buffer (Depth Buffer)  
		0,											// No Stencil Buffer
		0,											// No Auxiliary Buffer
		PFD_MAIN_PLANE,								// Main Drawing Layer
		0,											// Reserved
		0, 0, 0										// Layer Masks Ignored
	};
	
	if (!(hDC=GetDC(hWnd)))							// Did We Get A Device Context?
	{
		KillGLWindow();								// Reset The Display
		MessageBox(NULL,"Can't Create A GL Device Context.","ERROR",MB_OK|MB_ICONEXCLAMATION);
		return FALSE;								// Return FALSE
	}

	if (!(PixelFormat=ChoosePixelFormat(hDC,&pfd)))	// Did Windows Find A Matching Pixel Format?
	{
		KillGLWindow();								// Reset The Display
		MessageBox(NULL,"Can't Find A Suitable PixelFormat.","ERROR",MB_OK|MB_ICONEXCLAMATION);
		return FALSE;								// Return FALSE
	}

	if(!SetPixelFormat(hDC,PixelFormat,&pfd))		// Are We Able To Set The Pixel Format?
	{
		KillGLWindow();								// Reset The Display
		MessageBox(NULL,"Can't Set The PixelFormat.","ERROR",MB_OK|MB_ICONEXCLAMATION);
		return FALSE;								// Return FALSE
	}

	if (!(hRC=wglCreateContext(hDC)))				// Are We Able To Get A Rendering Context?
	{
		KillGLWindow();								// Reset The Display
		MessageBox(NULL,"Can't Create A GL Rendering Context.","ERROR",MB_OK|MB_ICONEXCLAMATION);
		return FALSE;								// Return FALSE
	}

	if(!wglMakeCurrent(hDC,hRC))					// Try To Activate The Rendering Context
	{
		KillGLWindow();								// Reset The Display
		MessageBox(NULL,"Can't Activate The GL Rendering Context.","ERROR",MB_OK|MB_ICONEXCLAMATION);
		return FALSE;								// Return FALSE
	}

	ShowWindow(hWnd,SW_SHOW);						// Show The Window
	SetForegroundWindow(hWnd);						// Slightly Higher Priority
	SetFocus(hWnd);									// Sets Keyboard Focus To The Window
	ReSizeGLScene(width, height);					// Set Up Our Perspective GL Screen

	if (!InitGL())									// Initialize Our Newly Created GL Window
	{
		KillGLWindow();								// Reset The Display
		MessageBox(NULL,"Can't Activate The GL Rendering Context.","ERROR",MB_OK|MB_ICONEXCLAMATION);
		return FALSE;								// Return FALSE
	}

	return TRUE;									// Success
}

LRESULT CALLBACK WndProc(	HWND	hWnd,			// Handle For This Window
							UINT	uMsg,			// Message For This Window
							WPARAM	wParam,			// Additional Message Information
							LPARAM	lParam)			// Additional Message Information
{
	HMENU hMenu;
	switch (uMsg)									// Check For Windows Messages
	{
		case WM_ACTIVATE:							// Watch For Window Activate Message
		{
			if (!HIWORD(wParam))					// Check Minimization State
			{
				active=TRUE;						// Program Is Active
			}
			else
			{
				active=FALSE;						// Program Is No Longer Active
			}

			return 0;								// Return To The Message Loop
		}

		case WM_COMMAND:
		{
			hMenu = GetMenu(hWnd);
			switch(wParam)
			{
			case ID_GET_Q1:
				{
					int t;
					t=q1/360;
					q1=q1-t*360;
					MessageBoxPrintf(TEXT("繞基座旋轉的角度值"),TEXT("%f"),q1);
					return(0);
				}
			case ID_GET_q2:
				{
					int t;
					t=q2/360;
					q2=q2-t*360;
					MessageBoxPrintf(TEXT("繞關節1旋轉的角度值"),TEXT("%f"),q2);
					return(0);
				}
			case ID_GET_q3:
				{
					int t;
					t=q3/360;
					q3=q3-t*360;
					MessageBoxPrintf(TEXT("繞關節3旋轉的角度值"),TEXT("%f"),q3);
					return(0);
				}
			case ID_GET_q4:
				{
					int t;
					t=q4/360;
					q4=q4-t*360;
					MessageBoxPrintf(TEXT("繞手坐標系x軸旋轉的角度值"),TEXT("%f"),q4);
					return(0);
				}
			case ID_GET_q5:
				{
					int t;
					t=q5/360;
					q5=q5-t*360;
					MessageBoxPrintf(TEXT("繞手坐標系y軸旋轉的角度值"),TEXT("%f"),q5);
					return(0);
				}
			case ID_GET_q6:
				{
					int t;
					t=q6/360;
					q6=q6-t*360;
					MessageBoxPrintf(TEXT("繞手坐標系z軸旋轉的角度值"),TEXT("%f"),q6);
					return(0);
				}


			case ID_CAL_MATRIX:                                  //繞基座旋轉
				{
					float theta;
					const float pi=3.1415926;
					theta=q1*pi/180;
					float M[3][3];
					CalMatrixY(M,theta);
					MessageBoxPrintf(TEXT("繞基座旋轉的變換矩陣"),TEXT("%f %f %f\n%f %f %f\n%f %f %f"),M[0][0],M[0][1],M[0][2],M[1][0],M[1][1],M[1][2],M[2][0],M[2][1],M[2][2]);
					return(0);
				}

			case ID_CAL_MATRIX2:                               //繞關節1旋轉                              
				{
					float theta;
					const float pi=3.1415926;
					theta=q2*pi/180;
					float M[3][3];
					CalMatrixZ(M,theta);
					MessageBoxPrintf(TEXT("繞關節1旋轉的變換矩陣"),TEXT("%f %f %f\n%f %f %f\n%f %f %f"),M[0][0],M[0][1],M[0][2],M[1][0],M[1][1],M[1][2],M[2][0],M[2][1],M[2][2]);
					return(0);
				}

			case ID_CAL_MATRIX3:                             //繞關節3旋轉
				{
					float theta;					
					theta=q3*pi/180;
					float M[3][3];
					CalMatrixZ(M,theta);
					MessageBoxPrintf(TEXT("繞關節3旋轉的變換矩陣"),TEXT("%f %f %f\n%f %f %f\n%f %f %f"),M[0][0],M[0][1],M[0][2],M[1][0],M[1][1],M[1][2],M[2][0],M[2][1],M[2][2]);
					return(0);
				}
			case ID_CAL_TRANSMATRIX:                       //計算坐標變換矩陣
				{
					int i,j;
					float M1[3][3],M2[3][3],M3[3][3];
					float RotateMatrix[3][3];
					float AidedMatrix[3][3];//輔助矩陣
					for(i=0;i<3;i++)
						for(j=0;j<3;j++)
						{
							AidedMatrix[i][j]=0.0;
							RotateMatrix[i][j]=0.0;
						}
                    CalMatrixY(M1,q1*pi/180);
					CalMatrixZ(M2,q2*pi/180);
					CalMatrixZ(M3,q3*pi/180);
					MatrixMultiply(M1,M2,AidedMatrix);
                    MatrixMultiply(AidedMatrix,M3,RotateMatrix);//相乘次序:M3M2M1
					MessageBoxPrintf(TEXT("旋轉變換矩陣"),TEXT("%f %f %f\n%f %f %f\n%f %f %f"),RotateMatrix[0][0],RotateMatrix[0][1],RotateMatrix[0][2],RotateMatrix[1][0],RotateMatrix[1][1],RotateMatrix[1][2],RotateMatrix[2][0],RotateMatrix[2][1],RotateMatrix[2][2]);
					return(0);
				}
			}
			break;
		}
			
		case WM_SYSCOMMAND:							// Intercept System Commands
		{
			switch (wParam)							// Check System Calls
			{
				case SC_SCREENSAVE:					// Screensaver Trying To Start?
				case SC_MONITORPOWER:				// Monitor Trying To Enter Powersave?
				return 0;							// Prevent From Happening
			}
			break;									// Exit
		}

		case WM_CLOSE:								// Did We Receive A Close Message?
		{
			PostQuitMessage(0);						// Send A Quit Message
			return 0;								// Jump Back
		}

		case WM_KEYDOWN:							// Is A Key Being Held Down?
		{
			keys[wParam] = TRUE;					// If So, Mark It As TRUE
			return 0;								// Jump Back
		}

		case WM_KEYUP:								// Has A Key Been Released?
		{
			keys[wParam] = FALSE;					// If So, Mark It As FALSE
			return 0;								// Jump Back
		}

		case WM_LBUTTONDOWN:
			{
					return(0);
			}

		case WM_SIZE:								// Resize The OpenGL Window
		{
			ReSizeGLScene(LOWORD(lParam),HIWORD(lParam));  // LoWord=Width, HiWord=Height
			return 0;								// Jump Back
		}
	}

	// Pass All Unhandled Messages To DefWindowProc
	return DefWindowProc(hWnd,uMsg,wParam,lParam);
}

int WINAPI WinMain(	HINSTANCE	hInstance,			// Instance
					HINSTANCE	hPrevInstance,		// Previous Instance
					LPSTR		lpCmdLine,			// Command Line Parameters
					int			nCmdShow)			// Window Show State
{
	MSG		msg;									// Windows Message Structure
	BOOL	done=FALSE;	

	if (!CreateGLWindow("Unimation Puma560 機器人動力學仿真與軌跡規劃",640,480,16,false))
	{
		return 0;									// Quit If Window Was Not Created
	}

	while(!done)									// Loop That Runs While done=FALSE
	{
		if (PeekMessage(&msg,NULL,0,0,PM_REMOVE))	// Is There A Message Waiting?
		{
			if (msg.message==WM_QUIT)				// Have We Received A Quit Message?
			{
				done=TRUE;							// If So done=TRUE
			}
			else									// If Not, Deal With Window Messages
			{
				TranslateMessage(&msg);				// Translate The Message
				DispatchMessage(&msg);				// Dispatch The Message
			}
		}
		else										// If There Are No Messages
		{
			// Draw The Scene.  Watch For ESC Key And Quit Messages From DrawGLScene()
			if (active)								// Program Active?
			{
		    	if (keys[VK_ESCAPE])				// Was ESC Pressed?
				{
					done=TRUE;						// ESC Signalled A Quit
				}
				else								// Not Time To Quit, Update Screen
				{
					DrawGLScene();					// Draw The Scene
					SwapBuffers(hDC);				// Swap Buffers (Double Buffering)
				}
			}
		//////////////////////////////////////////////////////////////////////////////
		////////////////     響應鍵盤動作              //////////////////////////////
			if(keys[VK_LEFT])//連桿1左右旋轉(y軸)
			{				
				q1-=1.5f;			
			}
			if(keys[VK_RIGHT])
			{
				q1+=1.5f;
			}

			//////////////////////連桿2繞z軸旋轉
			if(keys[VK_PRIOR])
			{				
				q2+=2.0f;			
			}
            if(keys[VK_NEXT])
			{				
				q2-=2.0f;			
			}

			///////////////////////////連桿4繞z軸旋轉
			if(keys[VK_UP])
			{
				q3+=1.5f;				
			}
            if(keys[VK_DOWN])
			{
				q3-=1.5f;				
			}

			////////////////////////手坐標系的旋轉
			if(keys[VK_MULTIPLY])//繞y軸
			{
				q4+=1.5f;			
			}

			if(keys[VK_DIVIDE])//繞x軸
			{
				q5+=1.5f;			
			}

			if(keys[VK_SUBTRACT])//繞z軸
			{
				q6+=1.5f;				
			}


			if(keys[VK_HOME])
			{
				q1=q2=q3=0;
				q4=0.0f;
				q5=q6=0.0f;
			}
		}
	}
	

	KillGLWindow();									// Kill The Window
	return (msg.wParam);							// Exit The Program
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
波多野洁衣一区| 国产成人综合网| 一区二区三区资源| 一区二区三区在线观看网站| 日韩久久一区二区| 亚洲啪啪综合av一区二区三区| 国产精品伦理一区二区| 亚洲色图视频免费播放| 亚洲欧美另类小说视频| 午夜精品在线视频一区| 日本不卡视频一二三区| 精品一区二区三区在线观看 | 亚洲va国产va欧美va观看| 亚洲黄色小说网站| 午夜精品aaa| 九九精品视频在线看| 粉嫩欧美一区二区三区高清影视| 成人黄色国产精品网站大全在线免费观看 | 日韩一区二区在线看片| www精品美女久久久tv| 国产精品久久午夜夜伦鲁鲁| 亚洲免费伊人电影| 天天射综合影视| 国产电影一区二区三区| 91福利社在线观看| 久久综合色之久久综合| 亚洲欧美另类小说| 美国毛片一区二区三区| av午夜一区麻豆| 日韩欧美一区电影| 成人欧美一区二区三区在线播放| 亚洲一区在线免费观看| 国产自产高清不卡| 色婷婷av一区二区三区大白胸| 日韩欧美国产三级| 亚洲猫色日本管| 国产麻豆视频一区| 欧美在线观看一区| 欧美经典一区二区| 日本va欧美va欧美va精品| 国产精品亚洲人在线观看| 欧美少妇xxx| 中文字幕欧美一| 精品一区二区三区在线观看国产| 色综合色综合色综合 | 一本色道亚洲精品aⅴ| 日韩一区二区在线免费观看| 亚洲天天做日日做天天谢日日欢| 蜜臀久久久久久久| 欧美人牲a欧美精品| 一色桃子久久精品亚洲| 九九久久精品视频| 日韩一区二区中文字幕| 天天影视网天天综合色在线播放| 99视频一区二区| 国产日韩欧美不卡在线| 精品一区二区在线视频| 91精品国产乱| 香蕉av福利精品导航| 91黄色免费看| 亚洲人成亚洲人成在线观看图片| 高清日韩电视剧大全免费| 久久久美女毛片| 日本怡春院一区二区| 欧美色图一区二区三区| 亚洲欧美激情视频在线观看一区二区三区 | 久久精品亚洲一区二区三区浴池 | 亚洲欧美一区二区三区孕妇| 丁香六月综合激情| 国产欧美综合在线| 国产v综合v亚洲欧| 欧美国产一区在线| 成人黄色电影在线| 日韩一区欧美一区| 一本大道久久a久久精二百| 成人欧美一区二区三区黑人麻豆| 成人精品国产福利| 中文字幕亚洲区| 色综合天天综合网国产成人综合天| 欧美国产视频在线| 91丨porny丨蝌蚪视频| 亚洲精品国产无天堂网2021| 91年精品国产| 午夜精品久久久久影视| 91精品国模一区二区三区| 免费不卡在线视频| 国产日韩精品一区二区三区在线| 国产成人精品免费| 亚洲免费观看视频| 欧美精品v日韩精品v韩国精品v| 日本亚洲最大的色成网站www| 日韩色在线观看| 国产盗摄一区二区三区| 亚洲色图丝袜美腿| 制服丝袜中文字幕亚洲| 国产麻豆视频一区| 亚洲精品久久久蜜桃| 日韩一区二区三区电影在线观看| 国产一区二区三区日韩| 国产农村妇女精品| 欧美片网站yy| 国产精品一二三| 亚洲午夜在线电影| 26uuu色噜噜精品一区二区| av在线免费不卡| 日本一道高清亚洲日美韩| 国产午夜亚洲精品羞羞网站| 日本电影欧美片| 九色|91porny| 亚洲国产一区二区在线播放| 久久亚洲二区三区| 欧美美女一区二区| 国产福利不卡视频| 无码av中文一区二区三区桃花岛| 久久精品免费在线观看| 欧美午夜精品电影| 成人午夜激情片| 久久精品国产久精国产爱| 亚洲视频1区2区| 久久久噜噜噜久噜久久综合| 欧美挠脚心视频网站| 丁香婷婷综合色啪| 麻豆91在线看| 丝袜脚交一区二区| 亚洲欧美另类在线| 国产精品欧美综合在线| 日韩免费电影一区| 色国产综合视频| 99久久免费视频.com| 国产一区二区三区免费观看| 青青草精品视频| 亚洲国产日韩一区二区| 日韩伦理av电影| 亚洲国产岛国毛片在线| 久久久久国产免费免费| 日韩欧美自拍偷拍| 69久久夜色精品国产69蝌蚪网| 97国产精品videossex| 国产成人一区在线| 国产精品中文欧美| 国产一区999| 国产主播一区二区三区| 欧美a级一区二区| 日韩电影网1区2区| 无码av免费一区二区三区试看| 亚洲精品成人a在线观看| 亚洲视频在线一区| 亚洲精品国产精品乱码不99| 亚洲免费av观看| 亚洲制服丝袜在线| 亚洲国产人成综合网站| 亚洲6080在线| 蜜臀av国产精品久久久久| 日韩中文欧美在线| 久久成人免费网站| 国产一区二区精品久久99| 国产激情91久久精品导航| 国产精品1024| 不卡影院免费观看| 色视频成人在线观看免| 欧美在线观看一二区| 欧美一区二区三区四区在线观看 | 国产精品一区二区在线观看不卡| 久久精品国产在热久久| 国产精品一区免费视频| 91麻豆文化传媒在线观看| 91久久线看在观草草青青| 欧美日本不卡视频| 26uuu精品一区二区三区四区在线| 久久久无码精品亚洲日韩按摩| 国产精品成人免费精品自在线观看| 国产精品久久国产精麻豆99网站| 亚洲女同ⅹxx女同tv| 偷拍一区二区三区| 国产一区二区三区在线观看免费视频| 国产成人自拍在线| 在线看一区二区| 日韩欧美国产系列| 亚洲天堂免费看| 免费成人美女在线观看.| 国产成人精品www牛牛影视| 一本到不卡免费一区二区| 欧美一区二区三区四区视频 | 欧美精品九九99久久| 久久久蜜臀国产一区二区| 一个色在线综合| 国产乱理伦片在线观看夜一区| 色久综合一二码| 久久精品欧美一区二区三区不卡 | 国产精品69毛片高清亚洲| 色就色 综合激情| 久久精品人人爽人人爽| 午夜电影网亚洲视频| 国产成人午夜电影网| 91精品一区二区三区在线观看| 欧美极品美女视频| 久久精品国产久精国产| 欧美三级日韩三级| 国产精品久久久久永久免费观看| 免费人成在线不卡|