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

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


相关推荐

  • RabbitMQ(二):Work Queues、循环分发、消息确认、持久化、公平分发

    RabbitMQ(二):Work Queues、循环分发、消息确认、持久化、公平分发

    2021年10月5日
    39
  • c++string截取字符串

    c++string截取字符串C++的string类提供了大量的字符串操作函数,提取字符串的一部分,可采用substr函数实现:头文件:#include<string>//注意没有.hstring.h是C的标准字符串函数数,c++中一般起名为ctring.而string头文件是C++的字符串头文件。函数原型:stringsubstr(intpos=0,intn)const;函数说明:参数1:pos是必填参数参数2:n是可参数,表示取多少个字符,不填表示截取到末尾该函数功能为:返回从

    2022年5月12日
    52
  • Java正则表达式的语法与示例

    Java正则表达式的语法与示例Java正则表达式的语法与示例正则表达式是什么?用我的理解就是一个表达式。用来匹配,替换,判断字符串,之前业务就出现过判断返回值是否为邮箱。以下内容来自于http://baike.xsoftlab.net/view/207.html#3java正则表达式正则表达式语法java正则表达式语法java正则表达式概要:Java正则表达式的语法与示例

    2022年7月19日
    17
  • 字符串指针赋值小结

    字符串指针赋值小结字符指针赋值探究小结1,字符指针有初始值时,不能修改其中字符的值#include<iostream>usingnamespacestd;intmain(){ char*p1=”nihao”;//字符指针赋值给字符指针只能读不能修改字符的值 …

    2022年7月27日
    6
  • pycharm激活码 2021 3月最新注册码

    pycharm激活码 2021 3月最新注册码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月14日
    73
  • 移动端H5开发基础[通俗易懂]

    移动端H5开发基础[通俗易懂]文章目录前言一、移动端屏幕相关概念1.屏幕尺寸2.屏幕分辨率3.屏幕像素密度(ppi=pixelsperinch)二、像素1.物理像素2.CSS像素3.设备独立像素4.位图像素5.像素比(dpr)三、视口1.布局视口2.视觉视口3.理想视口三、缩放行为1.用户缩放2.系统总结前言随着移动端H5需求场景越来越多,例如微信公众号中H5页面的开发,APP中内嵌H5页面等,移动端H5开发基础知识和技巧是前端开发工程师必备的技能~一、移动端屏幕相关概念1.屏幕尺寸.

    2022年6月21日
    24

发表回复

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

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