怎么画等距线_十字线画法

怎么画等距线_十字线画法 等距线的画法本文作者徐庆荣(武汉大学) 等距线画法可分为栅格(光栅)方式和矢量方式二种。栅格方式一般采用“距离变换”等算子实现,算法简练,但在不同方向上的等距线可能不严格等距。矢量方式是按几何关系通过坐标计算获得等距线位置,算法复杂,但精度高。本文介绍的是矢量方式的等距线画法。1.      概述简言之,等距线是指与已知线条(折线或曲线)等距的线条。等距线的应用甚广,例如

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

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

等距线的画法

本文作者 徐庆荣(武汉大学)

 等距线画法可分为栅格(光栅)方式和矢量方式二种。栅格方式一般采用“距离变换”等算子实现,算法简练,但在不同方向上的等距线可能不严格等距。矢量方式是按几何关系通过坐标计算获得等距线位置,算法复杂,但精度高。本文介绍的是矢量方式的等距线画法。

1.       概述

简言之,等距线是指与已知线条(折线或曲线)等距的线条。等距线的应用甚广,例如:在地图上用于表示由平行线组成的各种线状符号(如道路,管线等);在多边形内可由一系列闭合的等距线(称等距圈或同心线,例如在CorelDraw中执行Effects->Contour选项所产生的图形)来表示某种区域特征;在GIS“缓冲带”分析时,“缓冲带”的轮廓就是以某一线状要素为中轴在其两侧构造等距线,并使两端闭合的图形。又如,沿海国家可按等距线方法计算确定专属经济区海域的界线。此外,等距线还用于数控机床刀路计算和机器人行走路径规划等。

设等距线偏离(法线方向)已知线条的距离用d 表示。若有已知曲线C,在C 上的每点沿法线方向(同侧)与该点相距d 处定一新点,则这些点的轨迹C0 称为曲线C 的等距线。

这里,我们称构造等距线所依据的已知线条(折线或曲线)为原始线。当原始线是折线时,等距线可用“推平行线”法产生。若原始线是任一参数曲线Ct),则理论上其等距线的数学表达式为

C0(t) = C(t) ±d·N(t)

式中t 为曲线参数,Nt)为曲线在t 处的单位主法矢量,其方向指向曲线凹的一侧。式中的正号或负号取决于等距线的偏离方向。当等距线偏离方向与主法矢量同向时取正号,反之取负号。在曲线拐点处,法矢量为不确定,须作特殊处理。若Ct)={ xt),yt},即Ct)为平面参数曲线,则

N(t)={-y’(t)sqrt((x’(t))2+(y’(t)) 2) x’(t)sqrt((x’(t)) 2+(y’(t)) 2)}

2.       折线的等距线

原始线为折线的等距线,其计算和绘制过程(“推平行线”)如下。

1)计算折线节点(各直线段的转折点)处的角平分线方向B

折线是由各直线段组成的,与各直线段等距的同侧平行线邻接于折线节点处的角平分线上。这里约定:角平分线方向指向折线走向的左侧(面向线段前进方向看的情况),并是从轴正向起算按反时针方向计的角度。角平分线方向B 由与之相邻的两直线段的方向来计算确定。

2)计算等距线的节点坐标

这里,等距线节点是指等距线上相邻直线段的交接点,它位于角平分线上,与原始线节点(xy)对应的等距线节点的坐标(x0y0)为:

x0=x±d’×cosB

y0=y±d’×sinB

 式中d’表等距线在角平分线上的截距,可由d和相邻的两直线段方向算得,一般情况下d’> d。如果在折线左侧作等距线,式中d’前的符号应取正号,反之取负号。

对于不闭合的折线,在首、末点处,以垂直于该处直线段的方向作为角平分线方向。等距线在首、末点处的端点坐标亦按上式计算。

3)从等距线始点起顺序连接等距线各节点直至终点(也可一边计算一边连接)

3.       参数曲线的等距线

在计算参数曲线的等距线过程中,须用折线逼近原始曲线Ct)和等距线C0t),即根据逼近的精度要求,以合适的步距(Δt)将曲线Ct)离散化,在离散点上计算等距线点,最后,以顺序连接各等距线点形成的折线近似作为等距线C0t)。具体过程如下。

1)令曲线参数tt0t0是曲线起点处的参数),计算曲线起点处的Nt)和等距线点;

2)根据逼近Ct)和C0t)的精度要求确定Δt,在下一离散点(tt+Δt)处,计算原始曲线的Nt)和等距线点;

3)反复(2)的过程,直至终点;

4)顺序连接各等距线点(也可一边计算一边连接)。

Δt 的值也可以根据曲线情况分段确定,在变化不大的同一段曲线上采用相同的Δt

参数曲线常用于拟合各种不规则曲线,这种拟合本身已具有一定误差。因此,在实际计算此种曲线的等距线时,可将曲线离散化后近似按折线处理。

4.       异常处理

当等距线与原始线(折线或曲线)的间距d 较大时(d 大于该处原始曲线的曲率半径),或者原始线迂回形成的自身间隔小于d 的两倍时,计算得到的等距线可能产生自交(形成“自交圈”)、不协调弯曲等异常现象。在计算过程中可按如下步骤判别和消除异常(以折线的等距线为例)。

1)消除“反向自交圈”

我们称下列之一为反向自交圈(不包括首、末端闭合形成的等距线圈):

a. 当等距线在原始线的左侧时,顺时针走向的等距线自交圈。

b. 当等距线在原始线的右侧时,逆时针走向的等距线自交圈。

2)若等距线自交圈含有“逆向线段”,则该自交圈应被消除

如果等距线上的某直线段与对应的原始线上的直线段方向相反,则称等距线上的该直线段为逆向线段。含有逆向线段的自交圈,不管圈的走向,都应将其删除。

3)消除含有“逆向线段”的不协调弯曲

尽管不在自交圈上,但若等距线局部线段为逆向线段,则在该处会形成与原始线不协调的弯曲。这时应作调整或删除,使等距线中不含逆向线段,从而消除不协调弯曲。

4)消除与邻近原始线相距小于d 的自交圈或线段

若等距线某线段与邻近原始线的距离小于d(计算等距线时采用的应偏离原始线的距离),则应删去该线段。若此种线段位于自交圈,则应删去整个自交圈。

对于曲线的等距线,若在处理过程中它是被离散化的,则上述原则亦能适用。

对等距线可能出现的各种异常,尚难完全预料;由于机器精度所限的计算误差亦可能导致判别失误。上述消除异常的措施只是初步的,尚需有进一步的解决办法。

5.       应用

上述等距线生成和异常处理的算法,已用于图形软件开发工具UGS(通用绘图软件),UGS采用此法在区域内生成的等距圈纹理,效果如下图。UGS发布于CSDN(图形处理类),下载处:http://www.csdn.net/cnshare/shtm/18.shtm

 

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/193744.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • java中scanner意思_java中Scanner s = new Scanner(System.in);分别是什么意思?「建议收藏」

    java中scanner意思_java中Scanner s = new Scanner(System.in);分别是什么意思?「建议收藏」展开全部Scanner是一个类,nextDouble()是Scanner的成员函数,System.in作为参数传递给Scanner的构造函数,使Scanner用62616964757a686964616fe78988e69d8331333366303839键盘作为输入,然后用new在内存中实例化一个Scanner出来,使得其它变量能调用这块内存区。Scanner类简介:Java5添加了java….

  • apk伪造签名_如何反编译app

    apk伪造签名_如何反编译app反编译apk过程反编译目的需要的环境和工具工具环境反编译流程apktool解包导出apk的源代码修改Smali代码无法选中文本框添加开机自启Smali源码Java源码apktool打包apk签名模拟器安装apk验证apk反编译目的反编译apk:1  对apk应用进行激活成功教程并重新打包,反编译就是逆向的过程。  Androidapk是用高级语言源代码,通常是Java,对apk的逆向智能转换成汇编语言,即Smali。  这次反编译的目的是为了学习apk的软件安全,了解apk的编译过程。现有一个apk的

  • 网站挂马检测_域名拦截检测网站

    网站挂马检测_域名拦截检测网站网站挂马检测工具,网站挂马如何检测,如何检测网站挂马在最近的一次网站优化项目中,我负责的一个网站出现了网站被挂马问题,所以网站的关键词排名很快就从首页消失了。把网站挂马问题解决后,花费了很多的精力才让关键词排名恢复。在seo公司工作期间,经常听到同事说起网站挂马的危害,因为没有切身体会,所以并没有太多感触。突然网站挂马的问题落到了自己负责的项目上,这才意识到网站挂马问题真的很不简单,在平时…

  • Idea激活码永久有效Idea2018.2.7激活码教程-持续更新,一步到位「建议收藏」

    Idea激活码永久有效Idea2018.2.7激活码教程-持续更新,一步到位「建议收藏」Idea激活码永久有效2018.2.7激活码教程-Windows版永久激活-持续更新,Idea激活码2018.2.7成功激活

  • vb.net 学习「建议收藏」

    vb.net 学习「建议收藏」一、vb.net是什么vb:即VisualBasic.net:是一个开发平台,在这个平台上可以开发多种语言。bcl:我的理解就是类的定义clr:我的理解就是类的使用。作用:(相当于java虚拟机,内存管理,垃圾清理)注:因为百度上说的都太宏观了,目前还是刚刚接触这个,是从名字上去理解,有其他见解可以留言或后面我有不同感悟再改二、vb.net有什么用目前我接触到:控制台程序 窗体程序 webservice三、怎么用说一个可能很多人忽略或只有我忽略了一下吧.

  • 继电器驱动电路原理及注意事项[通俗易懂]

    继电器驱动电路原理及注意事项[通俗易懂]继电器驱动电流一般需要20-40mA或更大,线圈电阻100-200欧姆,因此要加驱动电路  1. 晶体管用来驱动继电器,必须将晶体管的发射极接地。具体电路如下:NPN晶体管                            PNP晶体管 NPN晶体管驱动时:当晶体管T1基极被输入高电平时,晶体管饱和导通,集电极变为低电平,因此继电器线圈通电,触点RL1吸

发表回复

您的电子邮箱地址不会被公开。

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