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

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

?? tin3dview.cpp

?? Tin3D.rar 三維TIN的構建方面的東西
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// CTin3DView.cpp : implementation of the CTin3DView class
//

#include "stdafx.h"
#include "Tin3D.h"

#include "Tin3DDoc.h"
#include "Tin3DView.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CTin3DView

IMPLEMENT_DYNCREATE(CTin3DView, CView)

BEGIN_MESSAGE_MAP(CTin3DView, CView)
//{{AFX_MSG_MAP(CTin3DView)
ON_WM_CREATE()
ON_WM_DESTROY()
ON_WM_SIZE()
ON_WM_PAINT()
ON_WM_LBUTTONDOWN()
ON_COMMAND(ID_TX, OnTx)
ON_COMMAND(ID_POINT, OnPoint)
//}}AFX_MSG_MAP
// Standard printing commands
ON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint)
ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)
ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CTin3DView construction/destruction

CTin3DView::CTin3DView()
{
	
	
	m_Rotateangle=0;
	MAX=624;
	IsOpen=0;
	n=0;
}

CTin3DView::~CTin3DView()
{
}

BOOL CTin3DView::PreCreateWindow(CREATESTRUCT& cs)
{
	cs.style |= (WS_CLIPCHILDREN | WS_CLIPSIBLINGS); 
	return 	CView::PreCreateWindow(cs);
	
}

/////////////////////////////////////////////////////////////////////////////
// CTin3DView drawing

void CTin3DView::OnDraw(CDC* pDC)
{
	CTin3DDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	CClientDC dc(this);
	
	
	// TODO: add draw code for native data here
}

/////////////////////////////////////////////////////////////////////////////
// CTin3DView printing

BOOL CTin3DView::OnPreparePrinting(CPrintInfo* pInfo)
{
	// default preparation
	
	return DoPreparePrinting(pInfo);
}



void CTin3DView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add cleanup after printing
}

/////////////////////////////////////////////////////////////////////////////
// CTin3DView diagnostics

#ifdef _DEBUG
void CTin3DView::AssertValid() const
{
	CView::AssertValid();
}

void CTin3DView::Dump(CDumpContext& dc) const
{
	CView::Dump(dc);
}

CTin3DDoc* CTin3DView::GetDocument() // non-debug version is inline
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CTin3DDoc)));
	return (CTin3DDoc*)m_pDocument;
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CTin3DView message handlers




void CTin3DView::TriDelaunay(Vertex p1,Vertex p2)
{   
	CClientDC dc(this);
	
    Vertex ThirdPoint;
    ThirdPoint.x=(GetThirdPoint(p1,p2)).x;
    ThirdPoint.y=(GetThirdPoint(p1,p2)).y;
    ThirdPoint.z=(GetThirdPoint(p1,p2)).z;
	
	
    if (ThirdPoint.x!=0 && ThirdPoint.y!=0)
	{		
		glBegin(GL_LINE_LOOP);
		glVertex3f(p1.x,p1.y,p1.z);
		glVertex3f(p2.x,p2.y,p2.z);
		glVertex3f(ThirdPoint.x,ThirdPoint.y,ThirdPoint.z);
		glEnd();
		Edge l1;
		l1.p1.x=p1.x;
		l1.p1.y=p1.y;
		l1.p1.z=p1.z;		
		
		l1.p2.x=p2.x;
		l1.p2.y=p2.y;
		l1.p2.z=p2.z;		
		
		m_edges.push_back(l1);
		
		Triangle triangle;
		triangle.ptr[0].x=p1.x;
		triangle.ptr[0].y=p1.y;
		triangle.ptr[0].z=p1.z;		
		
		triangle.ptr[1].x=p2.x;
		triangle.ptr[1].y=p2.y;
		triangle.ptr[1].z=p2.z;		
		
		triangle.ptr[2].x=ThirdPoint.x;
		triangle.ptr[2].y=ThirdPoint.y;
		triangle.ptr[2].z=ThirdPoint.z;		
		
		m_triangles.push_back(triangle);
	}
	
    else 
		return;//儲存已構成的直線 
	
	TriDelaunay(p1,ThirdPoint) ;             
	TriDelaunay(ThirdPoint,p2) ;  //標記已構三角形的邊,對尚未構三角形的邊用算法進行遞歸調用
}

void CTin3DView::initial()
{
	
	int i;
	for (i=0;i<m_edges.size();i++)
	{
        m_edges[i].no=i+1;     
        m_edges[i].length=1.0;
        m_edges[i].usetimes=0;
		m_edges[i].p1.x=0;
		m_edges[i].p1.y=0;
		m_edges[i].p1.z=0;
		
		
		
		
		m_edges[i].p2.x=0;
		m_edges[i].p2.y=0;
		m_edges[i].p2.z=0;
		
		
		
	}
	/////////////////////////////////////////////////////////////
	for (i=0;i<m_triangles.size();i++)
	{
        m_triangles[i].no=i+1;
		m_triangles[i].edgeno[0]=-1;
		m_triangles[i].edgeno[1]=-1;	
        m_triangles[i].edgeno[2]=-1;
		
        m_triangles[i].Normal[0]=-1;
        m_triangles[i].Normal[1]=-1;
		m_triangles[i].Normal[2]=-1;
		
		
	}
	
}
Vertex CTin3DView::GetThirdPoint(Vertex p1, Vertex p2)
{
	/*-------------判定邊是否被標記-------------------*/
	bool sign=true;
	Edge edge;
	
	edge.p1.x=p1.x;
	edge.p1.y=p1.y;
	edge.p1.z=p1.z;
	
	
	edge.p2.x=p2.x;
	edge.p2.y=p2.y;
	edge.p2.z=p2.z;
	
	
	
	for(int i=0;i<m_edges.size();i++)
	{
		if(edge.p1.x==m_edges[i].p1.x &&
			edge.p1.y==m_edges[i].p1.y&&
			edge.p1.z==m_edges[i].p1.z&&
			edge.p2.x==m_edges[i].p2.x&&
			edge.p2.y==m_edges[i].p2.y&&
			edge.p2.z==m_edges[i].p2.z)
			sign=false;
	}
	double temp=1;   //采用最大張角,即最小余弦的判別準則
	int j=0; 
	for( i=0;i<MAX;i++)
	{  
		double equation;
		equation = ((p1.y - p2.y) * (m_vertex[i].x - p2.x))
			- ((m_vertex[i].y - p2.y) * (p1.x - p2.x));//確定基線的方向
		if(equation<=0) continue;                      //沿基線>0固定方向
		double a=sqrt(pow(p1.x-m_vertex[i].x,2)+pow(p1.y-m_vertex[i].y,2));
		double b=sqrt(pow(p2.x-m_vertex[i].x,2)+pow(p2.y-m_vertex[i].y,2));
		double c=sqrt(pow(p1.x-p2.x,2)+pow(p1.y-p2.y,2));
		double d=(a*a+b*b-c*c)/(2*a*b);
		if(d<temp && equation>0 && sign)
		{
			temp=d;
			j=i;
		}	
	}
	if(j!=0)
		return m_vertex[j];
	else
	{
		Vertex temp_vertex;
		temp_vertex.x=0;
		temp_vertex.y=0;
		temp_vertex.z=0;
		
		return temp_vertex;	
	}
	
}







int CTin3DView::OnCreate(LPCREATESTRUCT lpCreateStruct) 
{
	
	if (CView::OnCreate(lpCreateStruct) == -1)	 return -1;
	HWND hWnd = GetSafeHwnd(); 
	HDC hDC = ::GetDC(hWnd); 
	
	
	
	
	
		 	
	
	
	if (SetWindowPixelFormat(hDC)==FALSE)  return 0; 
	if (CreateViewGLContext(hDC)==FALSE) 	return 0; 
	return 0; 
	
	
}

BOOL CTin3DView::SetWindowPixelFormat(HDC hDC)
{
	PIXELFORMATDESCRIPTOR pixelDesc; 
	pixelDesc.nSize = sizeof(PIXELFORMATDESCRIPTOR); 	pixelDesc.nVersion = 1; 
	pixelDesc.dwFlags = PFD_DRAW_TO_WINDOW | 		 			     PFD_DRAW_TO_BITMAP | 					    PFD_SUPPORT_OPENGL | 					    PFD_SUPPORT_GDI | 						   PFD_STEREO_DONTCARE; 	pixelDesc.iPixelType = PFD_TYPE_RGBA; 	pixelDesc.cColorBits = 32; 
	pixelDesc.cRedBits = 8;
	pixelDesc.cRedShift = 16;
	pixelDesc.cGreenBits = 8; 
	pixelDesc.cGreenShift = 8; 
	pixelDesc.cBlueBits = 8; 
	pixelDesc.cBlueShift = 0;
	pixelDesc.cAlphaBits = 0;
	pixelDesc.cAlphaShift = 0;
	pixelDesc.cAccumBits = 64; 
	pixelDesc.cAccumRedBits = 16; 
	pixelDesc.cAccumGreenBits = 16; 
	pixelDesc.cAccumBlueBits = 16; 
	pixelDesc.cAccumAlphaBits = 0;
	pixelDesc.cDepthBits = 32; 
	pixelDesc.cStencilBits = 8; 
	pixelDesc.cAuxBuffers = 0; 
	pixelDesc.iLayerType = PFD_MAIN_PLANE; 
	pixelDesc.bReserved = 0; 
	pixelDesc.dwLayerMask = 0; 
	pixelDesc.dwVisibleMask = 0; 
	pixelDesc.dwDamageMask = 0; 
	m_GLPixelIndex = ChoosePixelFormat( hDC, &pixelDesc);
	if (m_GLPixelIndex==0) // Let's choose a default index. 
	{    m_GLPixelIndex = 1; 
	if (DescribePixelFormat(hDC, m_GLPixelIndex, 		   		sizeof(PIXELFORMATDESCRIPTOR),&pixelDesc)==0) 
		return FALSE; 	
	} 
	if (SetPixelFormat( hDC, m_GLPixelIndex,&pixelDesc)==FALSE) 		 return FALSE; 
	return TRUE; 
	
	
	
}

BOOL CTin3DView::CreateViewGLContext(HDC hDC)
{
	m_hGLContext = wglCreateContext(hDC); 
	if (m_hGLContext == NULL) 
		return FALSE; 
	if (wglMakeCurrent(hDC, m_hGLContext)==FALSE) 		 return FALSE; 
	return TRUE; 
}

void CTin3DView::OnDestroy() 
{
    if(wglGetCurrentContext()!=NULL) 
		wglMakeCurrent(NULL, NULL) ; 
	if (m_hGLContext!=NULL) 
	{ 
		wglDeleteContext(m_hGLContext); 
		m_hGLContext = NULL; 
	} 	
	CView::OnDestroy();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一区视频| 国产一区二区看久久| 国产91富婆露脸刺激对白| 国产欧美视频一区二区| 久久99精品国产.久久久久久| 久久综合久久鬼色中文字| youjizz国产精品| 午夜电影一区二区三区| www国产成人| 欧美三日本三级三级在线播放| 国产精品日韩精品欧美在线| 欧美日韩激情一区| 国产99久久久国产精品潘金| 欧美国产精品劲爆| 欧美顶级少妇做爰| 波多野结衣中文字幕一区二区三区| 亚洲一区二区欧美激情| 久久精品日产第一区二区三区高清版| 在线精品亚洲一区二区不卡| 国产在线乱码一区二区三区| 亚洲一区二区三区中文字幕在线| www欧美成人18+| 欧美日韩日本视频| 91麻豆文化传媒在线观看| 综合久久久久综合| 欧美成人a视频| 国产成人一级电影| 青青草精品视频| 亚洲六月丁香色婷婷综合久久| 精品国产青草久久久久福利| 欧美日韩激情一区| 精品一区二区免费在线观看| 亚洲一区二区三区在线播放 | 国产蜜臀av在线一区二区三区| 成人丝袜高跟foot| 一区二区三区成人在线视频| 日韩一区二区在线观看视频播放| 99久久伊人网影院| 国产一区欧美二区| 一区二区在线免费观看| 国产精品天美传媒沈樵| 欧美在线观看禁18| 一本一本大道香蕉久在线精品| 精品在线亚洲视频| 美女高潮久久久| 三级久久三级久久| 亚洲chinese男男1069| 亚洲日本免费电影| 日韩欧美中文字幕公布| 欧美一区二区三区免费大片| 欧美日韩久久一区| 欧亚一区二区三区| 国产一区美女在线| 亚洲国产精品久久一线不卡| 亚洲精品国产一区二区三区四区在线| 欧美一区二区三区视频在线观看| 国产在线视视频有精品| 国内外成人在线视频| 亚洲欧美区自拍先锋| 亚洲青青青在线视频| 亚洲男女一区二区三区| 欧美不卡123| 欧美性生交片4| 国产成人夜色高潮福利影视| 高清国产一区二区三区| 国产传媒欧美日韩成人| 日韩中文字幕1| 免费视频一区二区| 亚洲乱码国产乱码精品精98午夜| 精品粉嫩超白一线天av| 久久嫩草精品久久久久| 国产欧美日韩在线看| 国产精品对白交换视频| 亚洲精品免费在线| 亚洲va欧美va天堂v国产综合| 亚洲电影一区二区三区| 国产精品美女一区二区三区 | 韩国v欧美v日本v亚洲v| 一片黄亚洲嫩模| 日韩精品成人一区二区在线| 全国精品久久少妇| 亚洲成人www| 美腿丝袜一区二区三区| 国产一区福利在线| 91网站最新地址| 欧美久久免费观看| 欧美日韩亚洲高清一区二区| 国产成人av一区二区三区在线| www.亚洲色图.com| 韩国女主播成人在线| 日韩高清一级片| 国产一区美女在线| 精品一区二区三区的国产在线播放 | 中文字幕电影一区| 一区二区免费视频| 亚洲老司机在线| 国产精品久久久久毛片软件| 一区二区在线观看免费视频播放| 性欧美疯狂xxxxbbbb| 老司机一区二区| 99精品黄色片免费大全| 成人免费视频视频| 欧美精品aⅴ在线视频| 欧美美女直播网站| 中文字幕乱码日本亚洲一区二区| 一个色妞综合视频在线观看| 一区二区免费在线| 国产精品影视在线| 精品视频全国免费看| 欧美视频完全免费看| 久久九九全国免费| 国产亚洲欧美在线| 丝袜诱惑制服诱惑色一区在线观看 | 国产成人精品免费看| 国产成人午夜电影网| 欧美日韩精品一区二区三区蜜桃 | 国产色综合一区| 国产欧美一区视频| 亚洲欧美综合网| 一区二区三区av电影| 悠悠色在线精品| 精彩视频一区二区| 欧美日韩一卡二卡三卡| 欧美精品久久99| 日韩一区二区三| 一区二区三区在线影院| 丰满白嫩尤物一区二区| 日韩欧美中文字幕公布| 亚洲午夜激情网站| 免费一级片91| 欧美日韩电影一区| 亚洲精品一区二区三区福利| 国产嫩草影院久久久久| 免费久久99精品国产| 国产精品一区二区三区网站| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 国产精品乡下勾搭老头1| 99视频一区二区| 国产午夜亚洲精品羞羞网站| 亚洲欧美国产三级| 国产激情偷乱视频一区二区三区| 99视频国产精品| 欧美日韩激情在线| 国产亚洲欧美色| 一区二区国产盗摄色噜噜| 日本中文字幕不卡| 欧美性做爰猛烈叫床潮| 亚洲三级在线观看| 美女一区二区久久| 欧美人伦禁忌dvd放荡欲情| 亚洲精品国产视频| 91性感美女视频| 亚洲色图.com| 91麻豆福利精品推荐| 国产精品成人一区二区三区夜夜夜| 国产精品一区二区在线看| 在线日韩国产精品| 久久色.com| 亚洲国产日日夜夜| 欧洲一区二区av| 亚洲动漫第一页| 波多野结衣欧美| 中文字幕一区二区三区精华液 | 另类中文字幕网| 精品国产凹凸成av人导航| 一区二区三区久久久| 在线一区二区三区四区| 亚洲精品成a人| 在线观看日韩国产| 中文字幕av资源一区| 成人永久aaa| 亚洲欧美日韩久久| 国产一区二区精品久久99 | 精品一区二区三区不卡| 在线精品国精品国产尤物884a| 亚洲精品亚洲人成人网 | 久久久久亚洲综合| 亚洲a一区二区| 日韩一级完整毛片| 国产一区视频网站| 在线播放欧美女士性生活| 日韩专区中文字幕一区二区| 日韩亚洲欧美在线观看| 国产在线精品不卡| 中文字幕一区二区三区av | 亚洲同性同志一二三专区| 国产真实乱子伦精品视频| 国产精品久久久久久亚洲伦| 久久97超碰国产精品超碰| 欧美日韩高清一区二区三区| 亚洲三级小视频| 欧美精品乱码久久久久久| 精品一区二区三区在线播放视频 | 一区二区久久久久久| 欧美日本乱大交xxxxx| 亚洲一区欧美一区| 日韩三级精品电影久久久| 午夜电影一区二区| 欧美日韩精品一区二区| 亚洲一级二级三级|