winform 根据两点求出线上所有点及画出这条线
找出所有点:
根据斜率按照一个方向递增,求出对应的另一个方向的整数值。
Point pStart = new Point(0, 2);
Point pEnd = new Point(8, 2);
//定义线上的点
List<Point> linePoint = new List<Point>();
//定义x坐标的大小
Point pointMaxX = new Point();
Point pointMinX = new Point();
//给x坐标大的点和小的点赋值
if (Math.Max(pStart.X, pEnd.X) == pStart.X)
{
pointMaxX = pStart;
pointMinX = pEnd;
}
else
{
pointMaxX = pEnd;
pointMinX = pStart;
}
// 循环x坐标(循环满足x坐标为整数的y坐标)或者y坐标均可
for (int i = pointMinX.X + 1; i < pointMaxX.X; i++)
{
// 计算斜率
double k = ((double)(pointMinX.Y - pointMaxX.Y)) / (pointMinX.X - pointMaxX.X);
// 根据斜率,计算y坐标
double y = k * (i - pointMinX.X) + pointMinX.Y;
// 简单判断一下y是不是整数
double d = y - (int)y;
if (0.001 > d && d > -0.001)
{
linePoint.Add(new Point(i,(int)d));
}
}
//打印点
foreach (var item in linePoint)
{
Console.WriteLine(item.X + @"," + item.Y);
}
画线
依据某个端点,找出这个端点方向的下一个三个周围点,找出最符合斜率的点。
public bool DrawLineOnPicture(Color c, Point start, Point end)
{
if (MyBitmapData == null) { return false; }
int x, y;
int dstStride = MyBitmapData.Stride;
//Object thisLock = new Object();
//lock (thisLock){
System.IntPtr dstScan0 = MyBitmapData.Scan0;
try
{
if (start.X > end.X)
{
Point temp = start;
start = end;
end = temp;
}
int step;
if (start.Y < end.Y)
step = 1;
else
step = -1;
x = start.X;
y = start.Y;
unsafe
{
byte* pDst = (byte*)(void*)dstScan0; while ((x != end.X) || (y != end.Y))
{ pDst[x * 3 + y * dstStride] = c.R;
pDst[x * 3 + y * dstStride + 1] = c.G;
pDst[x * 3 + y * dstStride + 2] = c.B; Point p1 = new Point(x + 1, y);
Point p2 = new Point(x, y + step);
Point p3 = new Point(x + 1, y + step); double distance1 = DistanceToLine(p1, start, end);
double distance2 = DistanceToLine(p2, start, end);
double distance3 = DistanceToLine(p3, start, end); double distance = Math.Min(Math.Min(distance1, distance3), distance2);
if (distance == distance1)
{
x = p1.X;
y = p1.Y;
}
else if (distance == distance2)
{
x = p2.X;
y = p2.Y;
}
else
{
x = p3.X;
y = p3.Y;
}
}
}
}
catch (Exception )
{
//DBConnection.LevelTrace(TraceLevel.Error, "MyImage-->DrawLineOnPicture failed with:" + e);
return false;
}
//}
return true;
}
private double DistanceToLine(Point p, Point lineStart, Point lineEnd)
{
if (lineStart.X == lineEnd.X)
return (Math.Abs(p.X - lineEnd.X));
else if (lineStart.Y == lineEnd.Y)
return (Math.Abs(p.Y - lineEnd.Y));
else
{
double a = 1.0 * (lineEnd.Y - lineStart.Y) / (lineEnd.X - lineStart.X);
double b = lineStart.Y - a * lineStart.X;
double b2 = p.Y - a * p.X;
return (Math.Abs(b2 - b));
}
}
winform 根据两点求出线上所有点及画出这条线的更多相关文章
- 机器学习入门-数值特征-数据四分位特征 1.quantile(用于求给定分数位的数值) 2.plt.axvline(用于画出竖线) 3.pd.pcut(对特征进行分位数切分,生成新的特征)
函数说明: 1. .quantile(cut_list) 对DataFrame类型直接使用,用于求出给定列表中分数的数值,这里用来求出4分位出的数值 2. plt.axvline() # 用于画 ...
- p点到(a,b)点两所在直线的垂点坐标及p点是否在(a,b)两点所在直线上
/// <summary> /// p点到(a,b)点两所在直线的垂点坐标 /// </summary> /// <p ...
- TZOJ 1689 Building A New Barn(求平面上有几个其它点求到n个点的曼哈顿距离最小)
描述 After scrimping and saving for years, Farmer John has decided to build a new barn. He wants the b ...
- hdu 5017 模拟退火/三分求椭圆上离圆心最近的点的距离
http://acm.hdu.edu.cn/showproblem.php?pid=5017 求椭圆上离圆心最近的点的距离. 模拟退火和三分套三分都能解决 #include <cstdio> ...
- 由两点坐标如何画出直线 matlab
由两点坐标如何画出直线 方法1:利用直线方程 斜率加截距 方法2:数据拟合 %由两点坐标得数据拟合直线与画线 x = [,]; y = [,]; k = ((-)/(-));% 由两点坐标得到直线斜 ...
- c编程:求出4×4矩阵中最大和最小元素值及其所在行下标和列下标,求出两条主对角线元素之和。
//求出4×4矩阵中最大和最小元素值及其所在行下标和列下标,求出两条主对角线元素之和 #include <stdio.h> int main() { int sum=0; int max, ...
- Android中Google地图路径导航,使用mapfragment地图上画出线路(google map api v2)详解
在这篇里我们只聊怎么在android中google map api v2地图上画出路径导航,用mapfragment而不是mapview,至于怎么去申请key,manifest.xml中加入的权限,系 ...
- java绘图原理------在窗口界面(或面板上)画出一张或多张图片问题解决方法
/** *@author blovedr * 功能: java绘图原理------在窗口界面(或面板上)画出一张或多张图片问题解决方法 * 日期: 2018年4月28日 16:20 * 注释: ...
- 使用JavaScript在Canvas上画出一片星空
随着Html5的迅猛发展,画布也变得越来越重要.下面我就写一个关于在canvas上画出一片星空的简单的代码的示例. 理论基础 初始化一个canvas,获得一个用于绘制图形的上下文环境context.并 ...
随机推荐
- Struts-Core jar包
密码t6mp https://pan.baidu.com/share/init?surl=E--zExzI9-VY1zaT8F9i9w
- iOS开发CGRectGetMidX. CGRectGetMidY.CGRectGetMinY. CGRectGetMaxY. CGRectGetMinX. CGRectGetMaxX的使用
[iOS开发]iOS开发CGRectGetMidX. CGRectGetMidY.CGRectGetMinY. CGRectGetMaxY. CGRectGetMinX. CGRectGetMaxX的 ...
- iOS之UIKeyboardType 11种键盘图片展示
UIKeyboardTypeDefault UIKeyboardTypeASCIICapable == UIKeyboardTypeAlphabet UIKeyboardTyp ...
- Spring知识点小结(一)
一.Spring的简介 1.spring是一个full-stack轻量级开源框架 2.spring的两大核心 IoC: inverse of control 控制反转:反转是对象 ...
- 【网络流】EK算法及其优化
今天上午我仿佛知道了什么叫做网络流,这里推荐一篇博客,大家入门网络流的可以看一下这篇博客,保证一看就懂! 博客链接: 网络流入门 这里有一篇经过我改过的EK带注释代码(博客里也有一样的,只是加了一些注 ...
- ABAP术语-Function Group
Function Group 原文:http://www.cnblogs.com/qiangsheng/archive/2008/02/13/1067699.html Group of logical ...
- CentOS7 安装 Docker,10分钟入门!
本次安装是在VM虚拟机的CentOS 7环境下,仅为了学习和测试的简单安装,如果在真实生产环境还需要考虑安全策略的其他问题. 1.Linux内核版本需要 3.10.0 以上并且是64位 [root@l ...
- (转)Windows安装和使用zookeeper
(转)原地址https://www.cnblogs.com/shanyou/p/3221990.html 之前整理过一篇文章<zookeeper 分布式锁服务>,本文介绍的 Zookeep ...
- js实现监听浏览器窗口大小改变事件
window.onresize = function(){ }
- 误删 EhCache 中的数据?
最近遇到一个问题:在使用ehcache时,通过CacheManager.getCache(chachename).get(key),获取相应的缓存内对象(当时这个对象是个list), 有个同事写个方法 ...