C#窗体程序画倾斜一定角度的椭圆
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Drawing.Drawing2D;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace Ellipse
{
public partial class Form1 : Form
{
PointF xyPoint = new PointF(); //左上角的X,Y坐标
PointF centerPoint = new PointF();//椭圆的中心点
PointF movePoint = new PointF();
PointF xiePointF=new PointF();
PointF xiedPointF = new PointF();//倾斜一定角度后的点
private double perAngle = 0;
private double nowAngle;
PointF[] pointFs=new PointF[201];
PointF[] pointFs1=new PointF[201];//与pointFs对称的点数组,椭圆是对称的
PointF[] xiePointFs=new PointF[201];//倾斜的椭圆上半部分
PointF[] xiePointFs1 = new PointF[201];//倾斜的椭圆下半部分,对称的部分
private float a =200;
private float b =100;
private float stepLength = 2;//通过X坐标逐次加2计算出Y坐标,将所有坐标存在数组中,用DrawCurve连接
private float xLength = 0;//点到坐标Y轴的线段距离
private float yLength = 0;//颠倒坐标X轴的线段距离
private float dbYlength = 0;
private float xiedLength = 0;//点到椭圆中心点的线段长度
private int angle = 0;//倾斜的角度
public Form1()
{
InitializeComponent();
}
private void panel1_Paint(object sender, PaintEventArgs e)
{
}
private void panel1_MouseClick(object sender, MouseEventArgs e)////画布鼠标键点击事件,重画图形
{
if (e.Button != MouseButtons.Left)
{
return;
}
if (this.textBox1.Text == "")
{
this.errorProvider1.SetError(this.textBox1, "请输入倾斜的角度");
return;
}
else
{
this.errorProvider1.SetError(this.textBox1, "");
}
xyPoint.X = this.panel1.Width/2-200;
xyPoint.Y = this.panel1.Height/2-100;
centerPoint.X = xyPoint.X + a;
centerPoint.Y = xyPoint.Y + b;
Graphics graphics = this.panel1.CreateGraphics();
graphics.SmoothingMode = SmoothingMode.HighQuality;
graphics.Clear(this.panel1.BackColor);
Pen pen = new Pen(Color.Red);
for (int index = 0; index < pointFs.Length; index++)
{
movePoint.X = index * stepLength + xyPoint.X;
xLength = centerPoint.X - movePoint.X;
yLength = (float)(Math.Sqrt((1 - (xLength * xLength) / 40000) * 10000));
movePoint.Y = b - yLength + xyPoint.Y;
pointFs[index] = movePoint;
}
graphics.DrawCurve(pen, pointFs, 1.5f);
for (int index = 0; index < pointFs1.Length; index++)
{
dbYlength = centerPoint.Y - pointFs[index].Y;
pointFs1[index].Y = centerPoint.Y + dbYlength;
pointFs1[index].X = pointFs[index].X;
}
graphics.DrawCurve(pen, pointFs1, 1.5f);
for (int index = 0; index < pointFs.Length; index++)
{
xiePointF = pointFs[index];
double startAngle = Math.Atan2(xiePointF.Y - centerPoint.Y, xiePointF.X - centerPoint.X);
string jiaodu = this.textBox1.Text;
perAngle = int.Parse(jiaodu) * Math.PI / 180;
nowAngle = startAngle + perAngle;
xiedLength = (float)Math.Sqrt(Math.Pow(xiePointF.X - centerPoint.X, 2) + Math.Pow(xiePointF.Y - centerPoint.Y, 2));
xiedPointF.X = centerPoint.X - (float)(xiedLength * Math.Cos(nowAngle));
xiedPointF.Y = centerPoint.Y + (float)(xiedLength * Math.Sin(nowAngle));
xiePointFs[index] = xiedPointF;
}
graphics.DrawCurve(pen, xiePointFs, 1.5f);
for (int index = 0; index < pointFs1.Length; index++)
{
xiePointF = pointFs1[index];
double startAngle = Math.Atan2(xiePointF.Y - centerPoint.Y, xiePointF.X - centerPoint.X);
string jiaodu = this.textBox1.Text;
perAngle = int.Parse(jiaodu) * Math.PI / 180;
nowAngle = startAngle + perAngle;
xiedLength = (float)Math.Sqrt(Math.Pow(xiePointF.X - centerPoint.X, 2) + Math.Pow(xiePointF.Y - centerPoint.Y, 2));
xiedPointF.X = centerPoint.X - (float)(xiedLength * Math.Cos(nowAngle));
xiedPointF.Y = centerPoint.Y + (float)(xiedLength * Math.Sin(nowAngle));
xiePointFs1[index] = xiedPointF;
}
graphics.DrawCurve(pen, xiePointFs1, 1.5f);
}
private void button1_Click(object sender, EventArgs e)//倾斜角度,每次递增10度
{
angle += 10;
this.textBox1.Text = angle.ToString();
if (this.textBox1.Text == "")
{
this.errorProvider1.SetError(this.textBox1, "请输入倾斜的角度");
return;
}
else
{
this.errorProvider1.SetError(this.textBox1, "");
}
xyPoint.X = this.panel1.Width / 2-200;
xyPoint.Y = this.panel1.Height / 2-100;
centerPoint.X = xyPoint.X + a;
centerPoint.Y = xyPoint.Y + b;
Graphics graphics = this.panel1.CreateGraphics();
graphics.SmoothingMode = SmoothingMode.HighQuality;
graphics.Clear(this.panel1.BackColor);
Pen pen = new Pen(Color.Red);
for (int index = 0; index < pointFs.Length; index++)
{
movePoint.X = index * stepLength + xyPoint.X;
xLength = centerPoint.X - movePoint.X;
yLength = (float)(Math.Sqrt((1 - (xLength * xLength) / 40000) * 10000));
movePoint.Y = b - yLength + xyPoint.Y;
pointFs[index] = movePoint;
}
graphics.DrawCurve(pen, pointFs, 1.5f);
for (int index = 0; index < pointFs1.Length; index++)
{
dbYlength = centerPoint.Y - pointFs[index].Y;
pointFs1[index].Y = centerPoint.Y + dbYlength;
pointFs1[index].X = pointFs[index].X;
}
graphics.DrawCurve(pen, pointFs1, 1.5f);
for (int index = 0; index < pointFs.Length; index++)
{
xiePointF = pointFs[index];
double startAngle = Math.Atan2(xiePointF.Y - centerPoint.Y, xiePointF.X - centerPoint.X);
string jiaodu = this.textBox1.Text;
perAngle = int.Parse(jiaodu) * Math.PI / 180;
nowAngle = startAngle + perAngle;
xiedLength = (float)Math.Sqrt(Math.Pow(xiePointF.X - centerPoint.X, 2) + Math.Pow(xiePointF.Y - centerPoint.Y, 2));
xiedPointF.X = centerPoint.X - (float)(xiedLength * Math.Cos(nowAngle));
xiedPointF.Y = centerPoint.Y + (float)(xiedLength * Math.Sin(nowAngle));
xiePointFs[index] = xiedPointF;
}
graphics.DrawCurve(pen, xiePointFs, 1.5f);
for (int index = 0; index < pointFs1.Length; index++)
{
xiePointF = pointFs1[index];
double startAngle = Math.Atan2(xiePointF.Y - centerPoint.Y, xiePointF.X - centerPoint.X);
string jiaodu = this.textBox1.Text;
perAngle = int.Parse(jiaodu) * Math.PI / 180;
nowAngle = startAngle + perAngle;
xiedLength = (float)Math.Sqrt(Math.Pow(xiePointF.X - centerPoint.X, 2) + Math.Pow(xiePointF.Y - centerPoint.Y, 2));
xiedPointF.X = centerPoint.X - (float)(xiedLength * Math.Cos(nowAngle));
xiedPointF.Y = centerPoint.Y + (float)(xiedLength * Math.Sin(nowAngle));
xiePointFs1[index] = xiedPointF;
}
graphics.DrawCurve(pen, xiePointFs1, 1.5f);
}
private void button2_Click(object sender, EventArgs e)//倾斜角度,每次递减10度
{
angle -= 10;
this.textBox1.Text = angle.ToString();
if (this.textBox1.Text == "")
{
this.errorProvider1.SetError(this.textBox1, "请输入倾斜的角度");
return;
}
else
{
this.errorProvider1.SetError(this.textBox1, "");
}
xyPoint.X = this.panel1.Width / 2-200;
xyPoint.Y = this.panel1.Height / 2-100;
centerPoint.X = xyPoint.X + a;
centerPoint.Y = xyPoint.Y + b;
Graphics graphics = this.panel1.CreateGraphics();
graphics.SmoothingMode = SmoothingMode.HighQuality;
graphics.Clear(this.panel1.BackColor);
Pen pen = new Pen(Color.Red);
for (int index = 0; index < pointFs.Length; index++)
{
movePoint.X = index * stepLength + xyPoint.X;
xLength = centerPoint.X - movePoint.X;
yLength = (float)(Math.Sqrt((1 - (xLength * xLength) / 40000) * 10000));
movePoint.Y = b - yLength + xyPoint.Y;
pointFs[index] = movePoint;
}
graphics.DrawCurve(pen, pointFs, 1.5f);
for (int index = 0; index < pointFs1.Length; index++)
{
dbYlength = centerPoint.Y - pointFs[index].Y;
pointFs1[index].Y = centerPoint.Y + dbYlength;
pointFs1[index].X = pointFs[index].X;
}
graphics.DrawCurve(pen, pointFs1, 1.5f);
for (int index = 0; index < pointFs.Length; index++)
{
xiePointF = pointFs[index];
double startAngle = Math.Atan2(xiePointF.Y - centerPoint.Y, xiePointF.X - centerPoint.X);
string jiaodu = this.textBox1.Text;
perAngle = int.Parse(jiaodu) * Math.PI / 180;
nowAngle = startAngle + perAngle;
xiedLength = (float)Math.Sqrt(Math.Pow(xiePointF.X - centerPoint.X, 2) + Math.Pow(xiePointF.Y - centerPoint.Y, 2));
xiedPointF.X = centerPoint.X - (float)(xiedLength * Math.Cos(nowAngle));
xiedPointF.Y = centerPoint.Y + (float)(xiedLength * Math.Sin(nowAngle));
xiePointFs[index] = xiedPointF;
}
graphics.DrawCurve(pen, xiePointFs, 1.5f);
for (int index = 0; index < pointFs1.Length; index++)
{
xiePointF = pointFs1[index];
double startAngle = Math.Atan2(xiePointF.Y - centerPoint.Y, xiePointF.X - centerPoint.X);
string jiaodu = this.textBox1.Text;
perAngle = int.Parse(jiaodu) * Math.PI / 180;
nowAngle = startAngle + perAngle;
xiedLength = (float)Math.Sqrt(Math.Pow(xiePointF.X - centerPoint.X, 2) + Math.Pow(xiePointF.Y - centerPoint.Y, 2));
xiedPointF.X = centerPoint.X - (float)(xiedLength * Math.Cos(nowAngle));
xiedPointF.Y = centerPoint.Y + (float)(xiedLength * Math.Sin(nowAngle));
xiePointFs1[index] = xiedPointF;
}
graphics.DrawCurve(pen, xiePointFs1, 1.5f);
}
private void textBox1_TextChanged(object sender, EventArgs e)//输入倾斜的角度
{
angle = int.Parse(this.textBox1.Text);
}
}
}
C#窗体程序画倾斜一定角度的椭圆的更多相关文章
- 如何给windows窗体程序打包成一个安装包
http://blog.csdn.net/xyy410874116/article/details/6341787 给windows窗体程序打包成一个安装包:具体操作在:http://hi.baidu ...
- 学习java随笔第十一篇:java窗体程序
要开java的窗体程序,就要下载开发窗体的工具. 这里我用的是的myeclipse,可以直接在网上下载安装即可. 我用的是10.0版本的,如果需要汉化的话,可以看一下这篇文章:myeclipse.10 ...
- VS2010 win32项目windows窗体程序 向导生成代码解析
目录: 1.Win32项目的windows窗体程序的向导生成了如下代码 2.手工生成代码如下 3.当消息队列中没有消息需要处理,我们可以利用这段时间处理我们自己的任务 1.Win32项目的window ...
- 使用控制台调试WinForm窗体程序
.程序代码结构 .Win32DebuggerHelper.cs using System.Runtime.InteropServices; /* TODO:使用方法 Win32.AllocConsol ...
- 两种方法:VS2008下C++窗体程序显示控制台的方法——在QT程序中使用cout和cin
老蔡写了一个基于QT的窗体程序,而过去写的类的调试信息都是用cout显示的,苦于窗体程序无法显示cout信息很多信息都看不到,于是就想到让控制台和窗体同时显示.显示控制台方法如下 1.项目(或者叫“工 ...
- C#窗体程序与sql sever 数据库链接
一.所用工具 Visual Studio 2017和SQL Server Management Studio 2012 二.连接 打开SQL Server Management Studio 2012 ...
- winform窗体程序运行后怎样隐藏?
运行winform窗体,我们是怎样隐藏的呢? 例子: 1)创建简单winform窗体 2)编写隐藏窗体程序的代码 3)效果演示 1)创建一个简单的winform窗体MainForm,
- MFC窗体程序中添加调试控制台
在编写复杂程序的过程中,我们经常需要将一些信息输出到文件或者屏幕上.较控制台应用程序,MFC窗体程序要显得麻烦一些! 下面有2种方法来实现为MFC窗体程序添加调试控制台,方便程序员调试程序和了解当前程 ...
- c# WinForm窗体编程中对窗体程序设置快捷键
c# WinForm窗体编程中对窗体程序设置快捷键http://www.cnblogs.com/bison1989/archive/2011/09/19/2180977.html /// <su ...
随机推荐
- 黑马程序员_<<GUI(图形用户管理)-----2>>
--------------------ASP.Net+Android+IOS开发..Net培训.期待与您交流! -------------------- 8.对话框 对列出目录内容增加了对话框提示, ...
- assembly的说明
Assembly SampleAssembly; // Instantiate a target object. Int32 Integer1 = new Int32(); Type Type1; / ...
- php动态网页实现页面静态化 通过在初次被访问时生成html文件保存起来,下次该PHP程序被访问时就直接找到以前被访问过的html页面
一.什么是静态页面?什么是动态页面 静态页面是网页的代码都在页面中,不需要执行asp,php,jsp,.net等程序生成客户端网页代码的网页.不能 静态页面 动态页面 区别: ...
- Gwt 整合FusionCharts及封装搜狗地图时出现的问题
smartGwt 整合FusionCharts 把需要的.swf文件和FusionCharts.js放在war下面(路径就自己定了) 可以工程的html文件中引FusionCharts.js文件 也可 ...
- 屏蔽全部统计代码(51.la cnzz 百度统计 谷歌分析师adsense、屏蔽淘宝客广告代码)的方法
支持百度统计 .51.la统计.cnzz统计.51yes统计.谷歌分析师.阿里妈妈淘宝客广告.chinaz弹窗.假设有很多其它的须要屏蔽的,欢迎联系 default7#zbphp.com 改动etc的 ...
- Android自己定义控件而且使其能够在xml中自己定义属性
为什么要自己定义View android开发中自己定义View的优点是显而易见的.比方说以下的这个顶部导航,它被设计出如今应用的每一个界面,但每次的内容却不尽同样.我们不能在每一个layout资源中都 ...
- 使用systemtap调试linux内核
http://blog.csdn.net/heli007/article/details/7187748 http://linux.chinaunix.net/docs/2006-12-15/3479 ...
- MapReduce输出格式
针对前面介绍的输入格式,MapReduce也有相应的输出格式.默认情况下只有一个 Reduce,输出只有一个文件,默认文件名为 part-r-00000,输出文件的个数与 Reduce 的个数一致. ...
- IOS-UIProgressView的简单介绍
IOS-UIProgressView的简单介绍 转载:http://blog.sina.com.cn/s/blog_9c2363ad0101e1jy.html // UIProgressView的使用 ...
- [转] 学习使用:before和:after伪元素
http://www.w3cplus.com/css3/learning-to-use-the-before-and-after-pseudo-elements-in-css.html 如果你一直密切 ...