windows程序设计第五版_windows程序设计入门

windows程序设计第五版_windows程序设计入门Ellipse函数的用法函数功能:该函数用于画一个椭圆,椭圆的中心是限定矩形的中心,使用当前画笔画椭圆,用当前的画刷填充椭圆。函数原型:BOOL Ellipse(HDC hdc, int nLeftRect, int nTopRect, nRightRect, int nBottomRect);参数:hdc:设备环境句柄。nLeftRect:指定限定矩形左上角的X坐标。nTopRect…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

Ellipse函数的用法

函数功能:该函数用于画一个椭圆,椭圆的中心是限定矩形的中心,使用当前画笔画椭圆,用当前的画刷填充椭圆。

函数原型:BOOL Ellipse(HDC hdc, int nLeftRect, int nTopRect, nRightRect, int nBottomRect);

参数:

  • hdc:设备环境句柄。

  • nLeftRect:指定限定矩形左上角的X坐标。

  • nTopRect:指定限定矩形左上角的Y坐标。

  • nRightRect:指定限定矩形右下角的X坐标。

  • nBottomRect:指定限定矩形右下角的Y坐标。

返回值:如果函数调用成功,返回值非零;如果函数调用失败,返回值是0。

Windows NT:若想获得更多错误信息,请调用GetLastError函数。

备注:椭圆既不使用也不改变当前位置。

Windows 95和Windows 98:限定矩形的坐标值之和不能超过32767。nLeftRect与nRigthRect或nTopRectn与BottomRect之和不能超过32767

注意:

Ellipse(x1,y1,x2,y2),你必须确保x2-x1==y2-y1,这样你画出的就是正圆,而不是椭圆了.

不用Windows自带的画椭圆函数画椭圆方法参考

代码如下:


//画一个椭圆中点算法
void CGraphicsView::midleEllipse(int xCenter, int yCenter, int Rx, int Ry, HDC dc)
{ 
   
	int Rx2 = Rx*Rx;
	int Ry2 = Ry*Ry;
	int twoRx2 = 2*Rx2;
	int twoRy2 = 2*Ry2;
	int p;
	int x=0;
	int y=Ry;
	int px = 0;
	int py = twoRx2*y;
	SetPixel(dc,xCenter+x,yCenter+y,RGB(255,0,0));
	SetPixel(dc,xCenter-x,yCenter+y,RGB(255,0,0));
	SetPixel(dc,xCenter+x,yCenter-y,RGB(255,0,0));
	SetPixel(dc,xCenter-x,yCenter-y,RGB(255,0,0));
	//Region 1
	p = (int)(Ry2-Rx2*Ry+0.25*Rx2);
	while(px<py)
	{ 
   
		x++;
		px+=twoRy2;
		if(p<0)
			p+=Ry2+px;
		else
		{ 
   
			y--;
			py-=twoRx2;
			p+=Ry2+px-py;
		}
		SetPixel(dc,xCenter+x,yCenter+y,RGB(255,0,0));
		SetPixel(dc,xCenter-x,yCenter+y,RGB(255,0,0));
		SetPixel(dc,xCenter+x,yCenter-y,RGB(255,0,0));
		SetPixel(dc,xCenter-x,yCenter-y,RGB(255,0,0));
	}
	//Region 2
	p = (int)(Ry2*(x+0.5)*(x+0.5)+Rx2*(y-1)*(y-1)-Rx2*Ry2);
	while(y>0)
	{ 
   
		y--;
		py-=twoRx2;
		if(p>0)
			p+=Rx2-py;
		else
		{ 
   
			x++;
			px+=twoRy2;
			p+=Rx2-py+px;
		}
		SetPixel(dc,xCenter+x,yCenter+y,RGB(255,0,0));
		SetPixel(dc,xCenter-x,yCenter+y,RGB(255,0,0));
		SetPixel(dc,xCenter+x,yCenter-y,RGB(255,0,0));
		SetPixel(dc,xCenter-x,yCenter-y,RGB(255,0,0));
	}

}


// 画圆
void circleMidpoint(int xCenter,int yCenter,int radius,HDC dc)
{ 
   
	int x = 0;
	int y = radius;
	int p=1-radius;
	while(x<y)
	{ 
   
		x++;
		if(p<0)
		{ 
   
			p+=2*x+1;
		}
		else
		{ 
   
			y--;
			p+=2*(x-y)+1;
		}
		SetPixel(dc,xCenter+x,yCenter+y,RGB(255,0,0));
		SetPixel(dc,xCenter-x,yCenter+y,RGB(255,0,0));
		SetPixel(dc,xCenter+x,yCenter-y,RGB(255,0,0));
		SetPixel(dc,xCenter-x,yCenter-y,RGB(255,0,0));
		
		SetPixel(dc,xCenter+y,yCenter+x,RGB(255,0,0));
		SetPixel(dc,xCenter-y,yCenter+x,RGB(255,0,0));
		SetPixel(dc,xCenter+y,yCenter-x,RGB(255,0,0));
		SetPixel(dc,xCenter-y,yCenter-x,RGB(255,0,0));
	}
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/170964.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 华为手机切换屏幕效果_华为p40页面切换效果怎么换

    华为手机切换屏幕效果_华为p40页面切换效果怎么换通过style自定义Activity切换动画在华为上失效问题

    2022年4月22日
    199
  • Java中String转换为JSONArray发生错误[通俗易懂]

    Java中String转换为JSONArray发生错误[通俗易懂]直入主题:一个Map里面,有两种String:第一种解析的字符串结构keywords:[{keyword=关键字,matchType=1},{keyword=关键字,matchType=1}]这里假设Stringstr1=[{keyword=关键字,matchType=1},{keyword=关键字,matchType=1}]第二种解析的字符串结构keywords:[{…

    2022年6月20日
    80
  • linux java 日志_linux 查看日志

    linux java 日志_linux 查看日志1、cat命令:功能:1)显示整个文件。示例:$catfileName2)把文件串连接后传到基本输出,如将几个文件合并为一个文件或输出到屏幕。示例:$catfile1file2>file说明:把档案串连接后传到基本输出(屏幕或加>fileName到另一个档案)cat参数详解:-n或–number由1开始对所有输出的行数编号-b或–number-no…

    2022年6月16日
    21
  • js最简单的几个特效_js编程

    js最简单的几个特效_js编程fabricjs-全面基础掌握-1.1.Fabricjs介绍1.背景2.用途3.基本对象完整课程目录1.背景官方文档:http://fabricjs.com/docs/Fabric.js是一个完全开源的JavascriptHTML5(画布库)项目,于2010年左右开始创建,降低了开发Canvas的过程中,各种类型的交互与>变更的复杂度Fabric在画布元素之上提供交互式对象模型,Fabric也有SVG-to-canvas(和canvas-to-SVG)解析器2.用途通过Fab

    2025年7月9日
    1
  • chrome调试appweb_调试应用是什么意思

    chrome调试appweb_调试应用是什么意思googleDevice使用

    2025年7月24日
    0
  • Vue电商后台管理系统(1)

    Vue电商后台管理系统(1)Vue电商后台管理系统(1)登录在components文件夹下创建登录组件,Login.vue,并快速生成template、script和style骨架。配置路由,进入router文件夹,导入Login组件,创建路由并重定向首页为登录界面,进入首页时会自动跳转至登录页面,配置如下:绘制页面:<template><divclass=”login_container”><divclass=”login_box”><!–

    2022年5月9日
    79

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号