我从VML迁移到SVG。路径填充方式存在问题。这是一个例子:
左侧是用VML绘制的星形图,右侧是SVG。 VML的源代码(仅适用于IE):
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html xmlns:v="urn:schemas-microsoft-com:vml">
<head>
<style> v\:* { behavior: url(#default#VML); }</style >
</head>
<body>
<div style="width:300; height:270;">
<v:shape fillcolor="blue" strokecolor="red" coordorigin="0 0" coordsize="300 270"
strokeweight="2" style="position:relative; top:20; left:20; width:300; height:270"
path="m150,20 l240,240 l30,90 l270,90 l60,240 x e">
</v:shape>
</div>
</body>
SVG的源代码:
<!DOCTYPE html>
<html>
<head>
</head>
<body>
<svg width="300" height="270">
<path d="M150,20 L240,240 L30,90 L270,90 L60,240 Z" fill="blue" stroke="red" stroke-width="3"/>
</svg>
</body>
</html>
在恒星中间填充有明显的区别。我更喜欢VML风格。有没有办法用SVG做到这一点?
答案 0 :(得分:3)
当然,你只想要一个偶数fill-rule
<!DOCTYPE html>
<html>
<head>
</head>
<body>
<svg width="300" height="270">
<path d="M150,20 L240,240 L30,90 L270,90 L60,240 Z" fill-rule="evenodd" fill="blue" stroke="red" stroke-width="3"/>
</svg>
</body>
</html>