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

怎么画等距线_十字线画法 等距线的画法本文作者徐庆荣(武汉大学) 等距线画法可分为栅格(光栅)方式和矢量方式二种。栅格方式一般采用“距离变换”等算子实现,算法简练,但在不同方向上的等距线可能不严格等距。矢量方式是按几何关系通过坐标计算获得等距线位置,算法复杂,但精度高。本文介绍的是矢量方式的等距线画法。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

 

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

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

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


相关推荐

  • CSS 鼠标样式和手指样式整理

    CSS 鼠标样式和手指样式整理巧合要用到鼠标样式效果,就顺便整理了下十五种CSS鼠标样式,小例子供大家使用啊。CSS鼠标样式语法如下: 任意标签中插入style=”cursor:*” 例子:文本或其它页面元素文本或其它页面元素注意把*换成如下15个效果的一种: 下面是对这15种效果的解释。移动鼠标到解释上面,看看你的鼠标起了什么变化吧! hand是手型 例子:CSS鼠标手型效果CSS鼠标手

    2022年5月13日
    45
  • 基于Qt的音乐播放器(二)切换歌曲,调节音量,调节语速,暂停

    基于Qt的音乐播放器(二)切换歌曲,调节音量,调节语速,暂停切换歌曲,调节音量,调节语速,暂停先说一下,针对上一次的ui界面,这次做了重新设计,第一张是以前的,第二张是现在的设计,不要喷我按钮的ui,都是临时的,后面会用一种风格整体替换,我还加入了皮肤切换,不过还没有实现功能,这个ui也不是最终设计,后期还是会更新的,争取做到最好,说实话,这个设计真是让人头疼,毕竟是把美工的活抢了,哈哈,然后这个ui的设计,我们先不讲,如果需求高的话,会考虑再写一篇有关ui的,完整项目已上传github,自行下载,其他就没有了,我们赶紧进入今天的正题。

    2022年5月24日
    37
  • python中bool()函数

    python中bool()函数python中bool()函数

    2022年5月29日
    39
  • 如何运用LoadRunner进行http接口测试[通俗易懂]

    如何运用LoadRunner进行http接口测试[通俗易懂]目前自己有接触到的接口主要有三类:WCF、WebService及http接口,前两类是标准型的服务接口。这对于如何对接口进行功能测试,大家可以去网上查找下,有很多已有的测试工具,比如SoapUI、HttpClient等。在这里,我将主要针对如何运用LoadRunner进行接口的性能测试进行说明,其实LoadRunner也可以进行接口的功能测试。在这之前,我相信大家应该都清楚LoadRunner是

  • error launching installer-最新版Win 10 解决方案

    error launching installer-最新版Win 10 解决方案

    2021年11月7日
    73
  • clion激活码(破解版激活)[通俗易懂]

    clion激活码(破解版激活),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月17日
    68

发表回复

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

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