- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
编辑:
我终于找到了一种侵 eclipse 和扩张多边形(偏移)的方法,以便使用 Clipper 库创建新的几何图形: https://sourceforge.net/projects/jsclipper/
Javascript Clipper 的现场演示: http://jsclipper.sourceforge.net/5.0.2.1/main_demo.html
Clipper 只能处理多边形或多多边形(例如带孔的多边形),因此要与其他 SVG 格式的图形对象一起使用,必须将它们转换为直线。至少使用 path.getTotalLength()
和 path.getPointAtLength()
( http://whaticode.com/2012/02/01/converting-svg-paths-to-polygons/ ) 可以很容易地将路径转换为行。
另一种可能性是使用类似的技术(不创建新的几何体): https://stackoverflow.com/a/12723835/1691517
<小时/>有什么方法可以通过 Javascript 腐 eclipse 和膨胀 SVG 中的形状吗?
我有以下 SVG 示例: http://jsfiddle.net/timo2012/2S4Kt/1/
共有三种形状,蓝色是原始形状,绿色是侵 eclipse (细化)形状,红色是扩张(加粗)形状。它们是用 Illustrator 制作的。
我测试过侵 eclipse 和膨胀滤镜,但效果不太好: https://dvcs.w3.org/hg/FXTF/raw-file/tip/filters/examples/feMorphology.svg
经过几个小时的互联网搜索,我只找到了有关位图图像腐 eclipse 和膨胀的示例,但没有找到有关矢量形状的示例。
我已经在 Python 中使用 Shapely ( http://toblerity.github.com/shapely/manual.html ) 成功地膨胀和腐 eclipse 了 SVG 多边形,方法是通过 Ajax 调用 PHP 脚本发送路径点,从而对 Python 脚本进行 system() 调用,但这种方法很慢并且需要服务器完成可以在客户端完成的工作。
这是我在 Python 中进行膨胀和腐 eclipse 的代码(如您所见,它非常短):
#!/usr/bin/python26
from shapely.geometry import Polygon
from shapely.geometry import MultiPolygon
import sys
if len(sys.argv)>2:
inset=eval(sys.argv[1])
coords=eval(sys.argv[2])
else:
sys.exit()
bowtie = Polygon(coords)
clean = bowtie.buffer(inset)
clean = clean.simplify(1, preserve_topology=False)
if clean.length>0:
if clean.geom_type=="MultiPolygon":
for n in range(0, len(clean)):
print list(clean[n].exterior.coords)
#print "\n"
elif clean.geom_type=="Polygon":
print list(clean.exterior.coords)
还可以找到这个文档,它尝试用数学术语定义膨胀和腐 eclipse : http://en.wikipedia.org/wiki/Mathematical_morphology
有句话“二值形态学的基本思想是用一个简单的、预定义的形状探测图像,得出这个形状如何适合或错过图像中的形状的结论。这个简单的“探测”称为结构元素,本身就是一个二值图像(即空间或网格的子集)。”
我认为这种方法可以用于变形矢量形状,但是如何...
编辑:回复中的一条评论提出了使用过滤器而不是创建新几何体的可能问题:如果有人想要向多边形点添加拖动 handle ,那么拖动 handle 可能似乎位于错误的位置。这是可以接受的,因为这样的印象是原始路径数据没有受到影响,这实际上是过滤器中的情况,但是 - 经过进一步的测试 - 事实证明质量是一个更大的问题。根据this和 this SVG 过滤器使用矢量图形对象的像素表示而不是路径数据本身,这导致 not so good looking results .
编辑2:可能的解决方法:本页中的答案之一使我使用可变宽度笔划和蒙版来实现此问题的美观解决方法。我做了一些测试并得到实现an Adobe Illustrator -like Offset Path Effect .
最佳答案
您可以通过使用不同笔画宽度结合 clip-path
或 mask
进行描画来获得您想要的效果。这是 example ,有关其构造方式的一些解释请参阅 here和 here (向上或向下箭头可查看该示例的其他一些幻灯片)。
它不会给你新的几何图形,只是一些看起来像新几何图形的东西。
关于javascript - 使用 Javascript 膨胀和腐 eclipse SVG 形状,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12684398/
我需要使用view.getWidth(),但我不能,因为我还没有膨胀 View 。在使用 view.getWidth() 之前如何膨胀 View ? MainActivity 类: p
这个问题很难尝试和表述,但我会尽力而为。 基本上,我有一个应用程序,我想将代码拆分得更多。为了尝试解释这一点,我将举一个我的屏幕示例。 在我的主屏幕上,我有一个标题、用户详细信息、余额、下一个账单详细
我有一个 TableLayout,我在其中动态添加行,一开始是空的,我想在用户单击它时在该行中加载一个 xml。 我已经给行赋值了OnClick方法,但是不知道在onclick方法中进入时如何加载xm
我使用的是 C++ 中的 libcurl 库,这是一个相当大的库(.lib 文件大约 2MB),项目是用 CURL_STATICLIB 编译的 至于现在我只有一个 .cpp 文件,其中包含 heade
背景: 我正在努力使一堆 PNG 尽可能小。我正在使用诸如 PngOut、PngCrush 和 OptiPng 之类的工具。 问题: 我遇到了一个大小为 1434 KB 但只有 230 x 230 像
我一直在努力找出我的应用程序使用的内存不断增长的原因,直到在 heroku 上的生产中它失败并下降。 经过一些相当广泛的研究,使用 Top 观察 RSIZE 在本地增长并使用 Oink 尝试查明我只是
我有一个使用 C++ 版本的 zlibs deflate 压缩的数据 ArrayBuffer(使用默认值)。由于没有服务器,我现在需要在客户端中增加这些数据。我已经使用 C++ 中的默认 inflat
我的代码有问题: @Override public View getView(int position, View convertView, ViewGroup parent) {
我有一个 fragment ,我像下面一样对其进行膨胀,但它给出了运行时错误: public View onCreateView(LayoutInflater inflater, ViewGroup
我正在学习 Fragment,并且我是通过在 Fragment 中使用 FB Login 来学习的。但我不断收到异常 Error inflateing class com.facebook.login
第一种方法: LinearLayout parent = ...; View child = LayoutInflator.inflate(context, parent, true); 第二种方法:
我刚刚完成了一个站点构建,在该站点构建中,我们必须将文件提供给第 3 方以与他们的系统集成。构建必须是独立的,因为会有多方部署它们,能力水平各不相同。 我遇到的问题是,在下载我的 Javascript
我正在寻找一种方法来“扩充”Android XML 布局,这在编译时是未知的。我已经搜索了几个小时,总能找到答案,这是不可能的,因为 LayoutInflater 不能使用简单的 XML 文件。好的,
我有一个从 Faragment 扩展而来的类,叫做 Agenda。它的布局有一个 listView,但是当这个类返回到主 Activity 时,我得到了一个错误。这是错误和代码: > 03-11 13
我的应用程序一启动就崩溃了。我收到以下错误: android.view.InflateException: Binary XML file line #34: Error inflating clas
我想膨胀 R.id.catText,但如果我自己膨胀它,它永远不会显示。如果我inflate R.id.assets(容器),那么两个元素都会正常显示。我只是不想要容器。如何在不膨胀 R.id.ass
我尝试创建自定义 ViewGroup 类,但是当我使用方法 findViewById() 时它返回 null,但展开 View 是可以的。 代码是: public class HorizontalLi
我正在尝试创建一个在屏幕上滑动的 textView,但它会产生错误,但我不知道为什么。这是我的 xml: 还有我的 Activity 课: package com.exampl
我正在构建一个应用程序,我在其中使用了 glomadrain 的动画切换按钮。完成编码后出现以下错误: at com.android.internal.os.ZygoteInit.main(Zygot
我只是想按照 android dev 上的示例代码来膨胀 Activity 中的 fragment 。我有一个更复杂的项目正在工作,但我遇到了与这里的简单项目相同的错误。谁能指出我正确的方向? 扩展
我是一名优秀的程序员,十分优秀!