一些转换器的用法和注意事项(五)——图层的缩放(Scaler转换器)

原文发布时间:2010-07-02

作者:毛毛虫

有客户在使用转换器Scaler对图层进行缩放时,说是遇到变形问题,这里就主要说一下如何对图层进行缩放。

首先看一下Scaler转换器,它的属性如下:

图片已丢失

这个转换器可以用于矢量数据也可以用于栅格数据,作用是缩放目标使得它们更大或更小。可以分别在X, Y, 和Z轴上设置乘数。对于二维要素,Z的乘数被忽略。如果Text Scaling被设置为"Location and Size",那么任何文本要素也会根据设置的比例来缩放;如果选择"Location Only",则文本保持不变,不进行缩放。

注意:这个转换器简单的乘以所有的用户指定的缩放比例因子,如果对象不在坐标系统的0,0点,也不靠近0,0点,使用Scaler也会在数据中引入一个位移。

 

原图层如下:


当我们对这个图层使用Scaler转换器,x、y轴上都设置个系数2时,生成的图层如下:


转换前后的图层对比下,图层确实不同了,但是分析之后就会发现,并不是缩放之后图形发生了变形,而是Scaler转换器是对每个要素分别进行缩放的,经过缩放后,要素之间发生了覆盖,如图:

图片已丢失

我们只需要将这个图层进行聚合处理,使用Aggregator转换器把所有要素聚合为一个要素,然后再进行缩放就可以了。
注意使用转换器Aggregator时,需要在List Name中输入一个名称,这个生成的list可以保留原来要素的属性,转换器设置如下:

在完成缩放后,使用Deaggregator转换器打散聚合,并在List Attribute中选择我们在Aggregator转换器中生成的List就可以把原来每个要素的属性再分配给对应的要素。


此时缩放后的效果如下:

图片已丢失

这时就不会有原来所认为的“变形”问题了。
 
还要注意下参数 Scale Origin的选项: 

Center Point:是以要素的中心点为参考来进行缩放的,如上面我们都是选择的这个选项。

0,0:以坐标系统的原点0,0为参考来进行缩放。如果要素的坐标与0,0相距很大,转换前后输入要素与输出要素的距离也可能很远。

如下图是我设置为0,0后的效果(做标记的位置是转换前后图层所在的位置):

图片已丢失

如果原数据的坐标就在0,0附近,则不会有这么大的唯一。如下图:

图片已丢失






猜你喜欢

转载自blog.csdn.net/fmechina/article/details/80925278
今日推荐