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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? 數(shù)控插補程序view.cpp

?? 數(shù)控插補算法
?? CPP
字號:
// 數(shù)控插補程序View.cpp : implementation of the CMyView class
//

#include "stdafx.h"
#include "數(shù)控插補程序.h"

#include "數(shù)控插補程序Doc.h"
#include "數(shù)控插補程序View.h"
#include "Math.h"

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

/////////////////////////////////////////////////////////////////////////////
// CMyView

IMPLEMENT_DYNCREATE(CMyView, CView)

BEGIN_MESSAGE_MAP(CMyView, CView)
	//{{AFX_MSG_MAP(CMyView)
		// NOTE - the ClassWizard will add and remove mapping macros here.
		//    DO NOT EDIT what you see in these blocks of generated code!
	//}}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()

/////////////////////////////////////////////////////////////////////////////
// CMyView construction/destruction

CMyView::CMyView()
{
	// TODO: add construction code here

}

CMyView::~CMyView()
{
}

BOOL CMyView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs

	return CView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CMyView drawing

void CMyView::OnDraw(CDC* pDC)
{
	CMyDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	// TODO: add draw code for native data here
	//設(shè)置坐標系
	pDC->SetMapMode(MM_ANISOTROPIC);
	pDC->SetWindowOrg(-20000,15000);
	pDC->SetWindowExt(int(200*200.00),-int(200*150.00));
    CRect rc;
	GetClientRect(&rc);
	pDC->SetViewportOrg(0,0);
	pDC->SetViewportExt(rc.Width(),rc.Height());

    
    a1=pDoc->x1;
	b1=pDoc->y1;
	a2=pDoc->x2;
	b2=pDoc->y2;
	step=pDoc->step;
    p1=pDoc->m1;
	q1=pDoc->n1;
	p2=pDoc->m2;
	q2=pDoc->n2;
	bc=pDoc->bc;
	    
	//畫網(wǎng)格程序段
    CPen hGreen(PS_DOT, 10, RGB(100,120,255));
	CPen *pOld;
    pOld=pDC->SelectObject(&hGreen);
    int i,j;
	for(i=-20000;i<20000;i+=1000)
	{
		pDC->MoveTo(i,-20000);
        pDC->LineTo(i,20000);
	}
    for(j=-20000;j<20000;j+=1000)
	{
		pDC->MoveTo(-20000,j);
		pDC->LineTo(20000,j);
	}
    pDC->SelectObject(pOld);

	//畫坐標軸程序段(選用蘭色畫筆)
    CPen hBlue(PS_SOLID, 80, RGB(0,0,255));
    if(pOld=pDC->SelectObject(&hBlue))
	{
	    pDC->MoveTo(-20000,0);
	    pDC->LineTo(20000,0);
	    pDC->TextOut(19000,1000,"X");
	    pDC->MoveTo(0,-20000);
	    pDC->LineTo(0,20000);
	    pDC->TextOut(-1000,14000,"Y");
		pDC->TextOut(0,-100,"0");
	
      
	}
	
		pDC->TextOut(-20000,-100,"-200");
		pDC->TextOut(19000,-100,"200");
		pDC->TextOut(100,-14000,"-150");
		pDC->TextOut(100,15000,"150");

    //畫直線
    pDC->MoveTo(int(a1*100),int(b1*100)); 
	pDC->LineTo(int(a2*100),int(b2*100));
	pDC->SelectObject(pOld);
	
	double i1; i1=0.0;
    double j1; j1=0.0;
    double F;  F=0.0;
    int E;  E=(abs(int(100*(a1-a2)))+abs(int(100*(b2-b1))))/int((100*step));

	//設(shè)定插補直線的顏色和類型
	CPen Pen6(PS_SOLID,80,RGB(255,0,0));
	CPen *pOld6=pDC->SelectObject(&Pen6);

    while(E>0)
	{	   
		//延時0.5秒
	   DWORD iTime=GetCurrentTime();
       while(GetCurrentTime()<(iTime+500));
	   
	   if(F>=0)//偏差判別
	   {
		 if((a2>a1)&&(b1>b2))
		 {//滿足條件就向-Y軸發(fā)出一個脈沖
		  pDC->MoveTo(int(a1*100+i1*100),int(b1*100+j1*100));
		  pDC->LineTo(int(a1*100+i1*100),int(b1*100+(j1-step)*100));
		  j1=j1-step;
          F=F-abs(int(100*(a2-a1))/100);
		 }
		 else if((a2<a1)&&(b1<b2))
		 {//滿足條件就向-X軸發(fā)出一個脈沖
		  pDC->MoveTo(int(a1*100+i1*100),int(b1*100+j1*100));
		  pDC->LineTo(int(a1*100+(i1-step)*100),int(b1*100+j1*100));
		  i1=i1-step;
          F=F-abs(int(100*(b2-b1))/100);
		 }
		 else if((a2<a1)&&(b1>b2))
		 {//滿足條件就向-Y軸發(fā)出一個脈沖
		  pDC->MoveTo(int(a1*100+i1*100),int(b1*100+j1*100));
		  pDC->LineTo(int(a1*100+i1*100),int(b1*100+(j1-step)*100));
		  j1=j1-step;
          F=F-abs(int(100*(a2-a1))/100);
		 }
		 else if((a2>a1)&&(b1<b2))
		 {//滿足條件就向+X軸發(fā)出一個脈沖
		  pDC->MoveTo(int(a1*100+i1*100),int(b1*100+j1*100));
		  pDC->LineTo(int(a1*100+(i1+step)*100),int(b1*100+j1*100));
		  i1=i1+step;
          F=F-abs(int(100*(b2-b1))/100);
		 }
	   }

	   else
	   {
		 if((a2>a1)&&(b1>b2))
		 {//滿足條件就向+X軸發(fā)出一個脈沖
		  pDC->MoveTo(int(a1*100+i1*100),int(b1*100+j1*100));
		  pDC->LineTo(int(a1*100+(i1+step)*100),int(b1*100+j1*100));
		  i1=i1+step;
		  F=F+abs(int(100*(b2-b1)/100));
		 }
		 else if((a2<a1)&&(b1<b2))
		 {//滿足條件就向+Y軸發(fā)出一個脈沖
		  pDC->MoveTo(int(a1*100+i1*100),int(b1*100+j1*100));
		  pDC->LineTo(int(a1*100+i1*100),int(b1*100+(j1+step)*100));
		  j1=j1+step;
          F=F+abs(int(100*(a1-a2)/100));
		 }
		 else if((a2<a1)&&(b1>b2))
		 {//滿足條件就向-X軸發(fā)出一個脈沖
		  pDC->MoveTo(int(a1*100+i1*100),int(b1*100+j1*100));
		  pDC->LineTo(int(a1*100+(i1-step)*100),int(b1*100+j1*100));
		  i1=i1-step;
          F=F+abs(int(100*(b1-b2)/100));
		 }
		 else if((a2>a1)&&(b1<b2))
		 {//滿足條件就向+Y軸發(fā)出一個脈沖
		  pDC->MoveTo(int(a1*100+i1*100),int(b1*100+j1*100));
		  pDC->LineTo(int(a1*100+i1*100),int(b1*100+(j1+step)*100));
		  j1=j1+step;
          F=F+abs(int(100*(a2-a1)/100));
		 }
	   }
	   E=E-1;
	     
	}

	pDC->SelectObject(pOld6);

	//畫圓弧
	CPen hBlue1(PS_SOLID, 80, RGB(0,0,255));
	CPen *pOld1;
    pOld1=pDC->SelectObject(&hBlue);
	t=sqrt(p1*p1+q1*q1);
	pDC->Arc(-int(100*t),-int(100*t),int(100*t),int(100*t),int(100*p1),int(100*q1),int(100*p2),int(100*q2));
	pDC->SelectObject(pOld1);

	//設(shè)定插補圓弧的顏色和類型
	CPen Pen4(PS_SOLID,80,RGB(255,0,0));
	CPen *pOld2=pDC->SelectObject(&Pen4);

      //插補圓弧 采用7位寄存器
      int Jrx=0;//畫右半圓時用
      int Jry=0;
      int Jrx1=0;//畫左半圓時用
      int Jry1=0;
      int Jvx=int(100*q1);//存起點的Y坐標
      int Jvy=int(100*p1);//存起點的X坐標
	  double c=sqrt(p1*p1+q1*q1);//半徑
	  //判斷是否到了終點
	  while((Jvy>0)||(Jvx!=int(100*q2)))
	  {
		  //延時0.5秒
          DWORD iTime=GetCurrentTime();
	      while(GetCurrentTime()<(iTime+500));
		  //判斷是右半圓
		  if(Jvy>0){
			  //一直累加直到有X軸或Y軸溢出
		      while((Jrx<12800)&&(Jry<12800))
			  {
			     if(Jvx<int(100*c))
					 Jry=Jvy+Jry;
			     //當加工位置已經(jīng)到達終點時Jvx不再加
			       Jrx=Jvx+Jrx;
			  }
		      if((Jrx>=12800)&&(Jry<12800))//如果X軸溢出
			  {
				 Jrx=Jrx-12800;
				 //當加工位置已經(jīng)到達終點時Jvx不再加
			     Jvy=Jvy-int(100*bc);
                 pDC->MoveTo(Jvy+int(100*bc),Jvx); 
			     pDC->LineTo(Jvy,Jvx);
			  }
		      else if((Jrx<12800)&&(Jry>=12800))//如果Y軸溢出
			  {
			     Jry=Jry-12800;
		         Jvx=Jvx+int(100*bc);
			     pDC->MoveTo(Jvy,Jvx-int(100*bc));
			     pDC->LineTo(Jvy,Jvx);
              
			  }
			  else if((Jrx>=12800)&&(Jry>=12800))//如果X軸和Y軸都溢出
			  {
			     Jrx=Jrx-12800;
				 Jry=Jry-12800;
				 //當加工位置已經(jīng)到達終點時Jvx不再加
				   Jvy=Jvy-int(100*bc);
				 Jvx=Jvx+int(100*bc);
                 pDC->MoveTo(Jvy+int(100*bc),Jvx-int(100*bc));
				 pDC->LineTo(Jvy,Jvx);
			  }
		
		  }
		  //判斷是下半圓
          else if((Jvy<=0)&&(Jvx>0))
		  {
            //一直累加直到有X軸或Y軸溢出
			while((Jrx1<12800)&&(Jry1<12800))
			{
			   if(Jvy>-int(100*c))
				   Jrx1=Jvx+Jrx1;
               //當加工位置已經(jīng)到達終點時Jvy不再加
		       Jry1=-Jvy+Jry1;
			}
            if((Jrx1>=12800)&&(Jry1<12800))//如果X軸溢出
			{
			   Jrx1=Jrx1-12800;
			   Jvy=Jvy-int(100*bc);
			   pDC->MoveTo(Jvy+int(100*bc),Jvx);
			   pDC->LineTo(Jvy,Jvx);
			}
		    else if((Jrx1<12800)&&(Jry1>=12800))//如果Y軸溢出
			{
			   Jry1=Jry1-12800;
         
		         Jvx=Jvx-int(100*bc);
			   pDC->MoveTo(Jvy,Jvx+int(100*bc));
			   pDC->LineTo(Jvy,Jvx);
			}
			else if((Jrx1>=12800)&&(Jry1>=12800))//如果X軸和Y軸都溢出
			{
				Jrx1=Jrx1-12800;
				Jry1=Jry1-12800;
				Jvy=Jvy-int(100*bc);
			
				  Jvx=Jvx-int(100*bc);
                pDC->MoveTo(Jvy+int(100*bc),Jvx+int(100*bc));
			    pDC->LineTo(Jvy,Jvx);
			}		
		  }        
	  }
	
    pDC->SelectObject(pOld2);	
}

/////////////////////////////////////////////////////////////////////////////
// CMyView printing

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

void CMyView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add extra initialization before printing
}

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

/////////////////////////////////////////////////////////////////////////////
// CMyView diagnostics

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

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

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

/////////////////////////////////////////////////////////////////////////////
// CMyView message handlers

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品成人一区二区艾草 | 中文字幕视频一区| 奇米影视在线99精品| 在线免费观看日韩欧美| 亚洲女人****多毛耸耸8| 成人黄色在线看| 国产亚洲精品资源在线26u| 捆绑紧缚一区二区三区视频| 欧美一区二区视频在线观看| 亚洲h在线观看| 91久久精品一区二区三区| 亚洲精品免费在线| 91美女片黄在线观看91美女| 最新高清无码专区| 91麻豆123| 一区二区三区精品在线| 在线亚洲欧美专区二区| 无码av免费一区二区三区试看 | 欧美日韩高清影院| 亚洲一区二区三区视频在线播放| 91久久一区二区| 亚洲成人午夜影院| 欧美一区欧美二区| 久久99深爱久久99精品| 久久精品夜色噜噜亚洲a∨| 粉嫩av亚洲一区二区图片| 国产精品系列在线| 91婷婷韩国欧美一区二区| 一区二区三区精品视频在线| 欧美久久久一区| 蜜臀av性久久久久蜜臀aⅴ四虎| 精品女同一区二区| 国产成人av一区二区三区在线| 中文无字幕一区二区三区| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 亚洲韩国精品一区| 欧美精品国产精品| 精品一区二区三区在线观看| 久久精品视频一区二区三区| 99精品黄色片免费大全| 亚洲一区二区三区免费视频| 欧美一区二区在线免费观看| 国产精品综合av一区二区国产馆| 欧美国产97人人爽人人喊| 99vv1com这只有精品| 亚洲高清三级视频| 精品国产污网站| 播五月开心婷婷综合| 亚洲午夜激情网站| 日韩欧美123| 成人教育av在线| 亚洲电影欧美电影有声小说| 精品精品国产高清a毛片牛牛| 成人午夜碰碰视频| 亚洲成人av一区| 久久久久久电影| 色婷婷av一区二区三区gif| 日本亚洲视频在线| 中文字幕一区免费在线观看| 欧美男同性恋视频网站| 国产福利一区二区三区| 亚洲影院理伦片| 久久女同互慰一区二区三区| 91电影在线观看| 韩国午夜理伦三级不卡影院| 一区二区三区精品在线| 久久这里只有精品视频网| 日本丶国产丶欧美色综合| 久久66热re国产| 一区二区三区在线不卡| www一区二区| 欧洲日韩一区二区三区| 国产电影一区在线| 香蕉影视欧美成人| 亚洲国产经典视频| 日韩欧美在线123| 色欲综合视频天天天| 激情都市一区二区| 午夜精品福利在线| 中文字幕中文在线不卡住| 日韩一二三区视频| 91久久线看在观草草青青| 国产成人午夜视频| 三级一区在线视频先锋| 亚洲欧美综合色| 精品成a人在线观看| 欧美亚洲愉拍一区二区| 成人性生交大片免费看视频在线| 日本少妇一区二区| 一区二区三区中文字幕| 亚洲国产精华液网站w| 日韩精品一区二区三区四区| 欧美性感一区二区三区| 成人性生交大片免费看中文网站| 另类小说视频一区二区| 亚洲va国产天堂va久久en| 亚洲乱码国产乱码精品精小说| 久久久久久日产精品| 日韩一级视频免费观看在线| 91成人网在线| 色综合色综合色综合色综合色综合 | thepron国产精品| 韩国三级在线一区| 麻豆国产精品官网| 亚洲一区二区三区视频在线播放| 成人免费在线视频观看| 国产日产欧美一区| 久久众筹精品私拍模特| 日韩欧美亚洲国产另类| 欧美区在线观看| 欧美日韩国产一区| 91豆麻精品91久久久久久| 99久久99久久久精品齐齐| 国产精品一区二区无线| 极品少妇一区二区三区精品视频 | 午夜精品久久久久久| 亚洲激情图片qvod| 中文字幕亚洲欧美在线不卡| 中文字幕欧美激情| 久久综合九色综合久久久精品综合 | 国产成人福利片| 国产毛片精品视频| 极品少妇xxxx精品少妇偷拍| 免费欧美高清视频| 日韩国产欧美三级| 日韩制服丝袜先锋影音| 亚洲午夜激情网站| 天天影视网天天综合色在线播放| 亚洲一二三区在线观看| 亚洲精品乱码久久久久| 亚洲人成影院在线观看| 综合色中文字幕| 一区二区三区欧美日韩| 亚洲制服丝袜av| 亚洲一区二区三区爽爽爽爽爽| 亚洲午夜在线观看视频在线| 亚洲国产视频网站| 亚洲高清视频中文字幕| 午夜精品福利一区二区蜜股av| 五月激情六月综合| 美女尤物国产一区| 久久97超碰国产精品超碰| 国产精品亚洲第一区在线暖暖韩国| 国产麻豆精品theporn| 国产高清精品在线| 99久久99久久精品免费观看| 在线免费不卡视频| 51精品视频一区二区三区| 91精品国产综合久久久久久久久久| 欧美一区二区三区白人| 日韩精品一区二区在线| 日韩精品影音先锋| 国产三区在线成人av| 国产精品久久午夜| 日韩午夜电影在线观看| 欧美乱妇23p| 精品精品欲导航| 日韩视频中午一区| 久久视频一区二区| 国产精品色婷婷久久58| 亚洲美女免费视频| 天堂av在线一区| 精品久久一区二区三区| 久久久夜色精品亚洲| 国产精品每日更新| 亚洲精品视频自拍| 首页国产欧美久久| 国产麻豆精品在线| 成人18视频日本| 欧美色中文字幕| 欧美大肚乱孕交hd孕妇| 国产欧美精品区一区二区三区| 亚洲天堂福利av| 亚洲bdsm女犯bdsm网站| 国产精品99久久久久| 91在线精品一区二区三区| 欧美肥大bbwbbw高潮| 久久久久久毛片| 一区二区三区久久久| 免播放器亚洲一区| 成人污视频在线观看| 欧美亚洲愉拍一区二区| 精品国产免费人成在线观看| 成人免费在线观看入口| 青青草一区二区三区| 成人激情图片网| 51精品国自产在线| 亚洲欧洲成人精品av97| 蜜臀av一区二区在线免费观看| 99re这里都是精品| 精品毛片乱码1区2区3区| 亚洲天堂2014| 久久电影网站中文字幕| 99精品黄色片免费大全| 精品国产精品网麻豆系列| 亚洲激情综合网| 国产一区二区三区综合| 91极品美女在线| 久久久一区二区三区| 婷婷综合五月天|