基本信息
源码名称:用C++模拟圆弧插补(图形)
源码大小:2.44KB
文件格式:.cpp
开发语言:C/C++
更新时间:2019-04-25
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):78630559
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
用C 模拟圆弧插补(图形) http://blog.csdn.net/z893345329/article/details/25922857
用C 模拟圆弧插补(图形) http://blog.csdn.net/z893345329/article/details/25922857
#include <graphics.h>
#include <conio.h>
#include<iostream>
using namespace std;
void main(){
int x0,y0,xe,ye,xi=0,yi=0,x,y,Fe,i=1,shun,rr=NULL;//rr为半径的平方
int a1,a2,b1,b2;
cout<<"######################"<<endl;
cout<<"#欢迎来到圆弧插补程序#"<<endl;
cout<<"######################"<<endl<<endl;
do{
cout<<"请输入起点坐标:"<<endl;
cin>>x0>>y0;
cout<<"请输入终点坐标:"<<endl;
cin>>xe>>ye;
cout<<"请输入圆心坐标:"<<endl;
cin>>x>>y;
if((xe-x)*(xe-x) (ye-y)*(ye-y)==(x0-x)*(x0-x) (y0-y)*(y0-y))
rr=(xe-x)*(xe-x) (ye-y)*(ye-y);
else cout<<"您输入的坐标够不成圆弧!"<<endl<<"请重新输入"<<endl;
} while(rr==NULL);
do{
cout<<"选择圆弧方向:1、顺时针;2、逆时针"<<endl;
cin>>shun;
}while(shun!=1&&shun!=2);
cout<<endl<<"*****************************************************************************"<<endl;
/* x0=300;y0=200;
xe=400;ye=300;
x=400;y=200;
rr=(xe-x)*(xe-x) (ye-y)*(ye-y);
shun=1;*/
xi=x0;yi=y0;//起点赋给xiyi
initgraph(600, 600);
while(xi!=xe||yi!=ye)//没有到达终点时
{
Fe=(xi-x)*(xi-x) (yi-y)*(yi-y)-rr;
//cout<<"Fe:"<<Fe<<endl;//system("pause");
if(Fe>=0)
{
if(shun==1){
if(xi>=x&&yi<=y)
xi--;
else if(xi<=x&&yi<=y)
yi ;
else if(xi<=x&&yi>=y)
xi ;
else if(xi>=x&&yi>=y)
yi--;
}
else if(shun==2){
if(xi>=x&&yi<=y)
yi ;//xi--;
else if(xi<=x&&yi<=y)
xi ;//yi ;
else if(xi<=x&&yi>=y)
yi--;//xi ;
else if(xi>=x&&yi>=y)
xi--;//yi--;
}
}
else
{
if(shun==1){
if(xi>=x&&yi<=y)
yi--;//xi--;
else if(xi<=x&&yi<=y)
xi--;//yi ;
else if(xi<=x&&yi>=y)
yi ;//xi ;
else if(xi>=x&&yi>=y)
xi ;//yi--;
}
else if(shun==2){
if(xi>=x&&yi<=y)
xi ;//yi ;//xi--;
else if(xi<=x&&yi<=y)
yi--;//xi ;//yi ;
else if(xi<=x&&yi>=y)
xi--;//yi--;//xi ;
else if(xi>=x&&yi>=y)
yi ;//xi--;//yi--;
}
}
b1=xi;b2=yi;
if(i==1){
a1=b1;a2=b2;
}
line(a1,(600-a2),b1,(600-b2));//line(a1,a2,b1,b2);
a1=b1;a2=b2;
cout<<i<<":\t"<<xi<<","<<yi<<endl;
i ;
//system("pause");
}
//cout<<x0<<y0<<xe<<ye<<xi<<yi<<x<<y<<Fe<<i<<shun<<rr;
cout<<endl<<"*****************************************************************************"<<endl<<endl;
getch(); // 按任意键继续
closegraph(); // 关闭图形界面
system("pause");
}