首页前端开发HTMLsvg中元素的使用及marker属性的介绍

svg中元素的使用及marker属性的介绍

时间2024-01-23 14:55:29发布访客分类HTML浏览687
导读:收集整理的这篇文章主要介绍了svg中<marker>元素的使用及marker属性的介绍,觉得挺不错的,现在分享给大家,也给大家做个参考。使用SVG绘制的图形是箭头, 可以在<defs>和<symbol>中...
收集整理的这篇文章主要介绍了svg中marker> 元素的使用及marker属性的介绍,觉得挺不错的,现在分享给大家,也给大家做个参考。使用SVG绘制的图形是箭头, 可以在defs> 和symbol> 中定义好再去重用,但是你每次应用的时候都需要对其移动或旋转。直接用一个marker> 元素的话会方便很多。

marker> 元素

marker是一种可以连结一个或多个path、line、polyline、或polygon的顶点的标志类型。最常见的用例是绘制箭头或在输出结果的线上的标记一个(polymarker)图形。
使用marker> 元素创建一个marker,以及其相关属性。通常我们把marker放在defs> 元素中,然后在其它地方对其进行引用。下面我们通过一个简单的实例来学习。

svg width="600px" height="100px">
         defs>
         marker id="arrow" markerWidth="10" markerHeight="10" refx="0" refy="3" orient="auto" markerUnITs="strokeWidth">
     path d="M0,0 L0,6 L9,3 z" fill="#f00" />
         /marker>
        /defs>
         line x1="50" y1="50" x2="250" y2="50" stroke="#000" stroke-width="5" marker-end="url(#arrow)" />
    /svg>
    

marker的属性

markerWidth和markerHeight属性定义了marker视窗的宽度和高度。

上面的实例中我把markerWidth和markerHeight都设置为10px。path中绘制出的三角形需要适应9px x 6px的面积,所以我也可以把markerWidth设置为9,然互markerHeight设置为6。这是marker可以接受的最小尺寸,任何小于这个的尺寸都会导致图形被裁剪。
接下来的两个属性,refX和refY,指的是图形元素和marker连接的位置坐标。我们还给背后的场景应用了一个变换,来移动marker,与之对齐。

下一个属性,orient,这个属性是我为什么在转换line的方向时,不需要调整marker的原因。它接受一个auto值,或者一个角度值,这个值决定了marker是否要旋转,在与其它内容连接的时候。

auto这个值表示marker会随着应用的元素一起旋转。45deg这个值则表示marker的方向一直保持45deg,不会随着连接的元素一起旋转。大多数时候这个值都是设置为auto的。

最后一个属性是markerUNits,用于确定marker是否进行缩放。它定义了markerWidth和markerHeight,以及marker的内容本身的坐标系统。

它接受两个值,strokeWidth和userSpaceOnUse。默认值是strokeWidth,这也是大家大多数情况下会设置的值,因为它允许你的marker随着它连接的line进行缩放。

strokeWidth:坐标系统中的marker值和当前描边宽度的单位是相同的尺寸。也就是说strokeWidth这个值允许你的marker缩放。
userSpaceOnUse: marker的值是当前用户坐标系统的值。也就是说如果你的marker是一个半径为10px的圆,它就一直都是10px的半径,不受连接的元素的影响。

Marker特性——在元素中引用Marker

marker-end="url(#arrow)”

给line、path、polyline、polygon这些基础图形应用marker一共有四种方法:

  • marker-start=”url(#marker-id)”

  • marker-mid=”url(#marker-id)”

  • marker-end=”url(#marker-id)”

  • marker=”url(#marker-id)”

相关文章推荐:

svg如何实现坐标系统变换(附代码)

在react中使用svg的各种方法总结(附代码)

以上就是svg中marker> 元素的使用及marker属性的介绍的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: HTML5实现魔方游戏的代码下一篇:svg如何实现坐标系统变换(附代码...猜你在找的html5相关文章 关于移动端h5开发相关内容总结2022-05-17html5教程-学表单的第二天2018-12-10html5教程-HTML5浏览器支持2018-12-10html5教程-HTML5智能表单2018-12-10html5教程-微信H5使用resLoader实现加载页效果2018-12-10html5教程-day01-初级-JS0-热身运动JS入门教程2018-12-10html5教程-html5shiv.js和respond.min.js2018-12-10html5教程-不同浏览器对于html5 audio标签和音频格式的兼容性2018-12-10html5教程-使用Html5实现手风琴案例2018-12-10html5教程-html5笔记2018-12-10 其他相关热搜词更多phpjavapython程序员load

若转载请注明出处: svg中元素的使用及marker属性的介绍
本文地址: https://pptw.com/jishu/584332.html
H5中画布、拖放事件以及音视频的代码实例 HTML5实现魔方游戏的代码

游客 回复需填写必要信息