SVG pattern 使用(patternUnits、patternContentUnits)

简介: SVG pattern 使用(patternUnits、patternContentUnits)

一、简介

  • <pattern>SVG 的一个图案填充标签,可以在 pattern 中定义好图案,然后通过 id 引用来对某个图形进行填充
  • <pattern>width / height 属性默认是根据所填充图形的百分比来确定的。

二、属性

  • pattern标签另外的两个属性为:
  • patternUnits:默认值为 objectBoundingBox
  • patternContentUnits:默认值为 userSpaceOnUse
    一般用来设置 pattern 内图案的单位大小,如下面实例中的 circle、polygon
  • Units的取值范围:
  • userSpaceOnUse
    xywidthheight表示的值都是当前用户坐标系统的值。也就是说,这些值没有缩放,都是绝对值。
  • objectBoundingBox(默认值)
    xywidthheight的值都是占外框(包裹 pattern 的元素)的百分比。

三、案例

  • 案例代码
<svg xmlns="http://www.w3.org/2000/svg" width="300" height="200">
    <defs>
      <pattern id="p1" x="0" y="0" width="0.2" height="0.2">
        <circle cx="10" cy="10" r="5" fill="red" />
        <polygon points="30 10 60 50 0 60" fill="green" />
      </pattern>
    </defs>
    <rect x="0" y="0" width="300" height="200" fill="url(#p1)" stroke="blue" />
</svg>
  • 案例效果


相关文章
|
设计模式 存储 前端开发
使用 JS 快速理解 Container/Presentational Pattern
在现代Web前端开发中,构建可维护、可扩展的应用程序变得越来越重要。为了实现这一目标,开发者需要遵循一些设计模式和最佳实践。其中之一是Container/Presentational(容器/展示)模式,它是一种用于组织和管理前端代码的技术。 本文将深入探讨Container/Presentational模式的概念,介绍如何使用JavaScript实现它,并探讨它在开发中的应用场景、优点和缺点。我们还将介绍一些知名项目中使用到这种模式的实际案例。
315 0
01-CSS3-justify-content: space-around; justify-content: space-between;
01-CSS3-justify-content: space-around; justify-content: space-between;
|
JavaScript 容器
HTML-Parser
背景:需求需要把 html 字符串转成 DOM 对象树或者 js 对象树,然后进行一些处理/操作。htmlparser 这个库还行,但是对 attribute 上一些特殊属性值转换不行,同时看了看开标签语法(syntax-start-tag:whatwg)、html-attribute 的支持规则(attributes:whatwg) 和一些其他库的实现,在一些边界场景(特殊属性值和web component)处理还是缺少,算了... 自己撸了个 html parser 的函数么好了。
1033 0
|
Apache Java Maven
|
JavaScript HTML5 移动开发