php svg 图元,SVG画图功能:svg实现画出一朵花(附代码)

本篇文章给大家带来的内容是关于SVG画图功能:svg实现画出一朵花(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

标记和 SVG 以及 VML 之间的一个重要的不同是, 有一个基于 JavaScript 的绘图 API,而 SVG 和 VML 使用一个 XML 文档来描述绘图。

一、创建一个 XXX.svg文件(该文件,创建了一个红色的圆)<?xml version="1.0" standalone="no"?>

/p>

"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">

xmlns="http://www.w3.org/2000/svg">

stroke-width="2" fill="red"/>

SVG使用XML编写,并保存为.svg文件。该.svg文件必须在.html文件中被引用

二、svg in HTML

1)使用标签:被所有主流的浏览器支持,并允许使用脚本

注释:当在 HTML 页面中嵌入 SVG 时使用 标签是 Adobe SVG Viewer 推荐的方法!然而,如果需要创建合法的 XHTML,就不能使用 。任何 HTML 规范中都没有 标签。

type="image/svg+xml"

pluginspage="http://www.adobe.com/svg/viewer/install/" />

pluginspage: 指向下载插件的url

2)使用object标签:html4的标准标签,被所有较新的浏览器支持,不允许使用脚本

type="image/svg+xml"

codebase="http://www.adobe.com/svg/viewer/install/" />

codebase:指向下载插件的url

3)iframe标签:(推荐)

三、SVG的形状

1、矩形

style="fill:rgb(0,0,255);stroke-width:1;

stroke:rgb(0,0,0)"/>

style 属性用来定义 CSS 属性

stroke-width 属性定义矩形边框的宽度

stroke 属性定义矩形边框的颜色

2、圆形

3、椭圆

style="fill:rgb(200,100,50);

stroke:rgb(0,0,100);stroke-width:2"/>

这里的椭圆只有一个圆点( 数学的椭圆通常说有两个焦点 )

cx 属性定义圆点的 x 坐标

cy 属性定义圆点的 y 坐标

rx 属性定义水平半径(通过两个焦点的线的一半)

ry 属性定义垂直半径

4、线条

5、多边形

6、折线

7、路径

在标签中,如果都在一个位置上,后边的形状会覆盖前面的形状

小花的代码

flower.svg<?xml version="1.0" standalone="no"?>

/p>

"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">

xmlns="http://www.w3.org/2000/svg">

style="stroke:rgb(100,55,69);stroke-width:2"/>

style="fill:lime"/>

style="fill:lime"/>

index.html

Title

效果图

c13d6aeb4bbc0ac34c1fa098162b4ce7.png

虽然丑了些,总体还是一朵花啦!嘻嘻

总体来说,svg就是用来画图的,还可以将各种图形叠加,形成你自己的图

相关文章推荐:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你想使用Vue 3来实现SVG元的鼠标滚轮控制尺寸,并将初始尺寸设置为1,可以按照以下步骤进行操作: 1. 在Vue项目中安装`vue-svg-inline-loader`库,该库用于加载SVG文件并以内联方式显示。 ```bash npm install vue-svg-inline-loader ``` 2. 创建一个Vue组件,命名为`SvgElement.vue`,并在该组件中添加SVG元。 ```html <template> <div> <svg ref="svgElement" v-html="svgCode" @wheel="handleWheel"></svg> </div> </template> <script> export default { data() { return { svgCode: '<circle cx="50" cy="50" r="50" fill="red"></circle>', size: 1 }; }, methods: { handleWheel(event) { event.preventDefault(); const delta = Math.sign(event.deltaY); if (delta > 0) { this.size += 0.1; } else { this.size -= 0.1; if (this.size < 0.1) { this.size = 0.1; } } this.updateSvgSize(); }, updateSvgSize() { const svgElement = this.$refs.svgElement; svgElement.style.width = `${this.size}rem`; svgElement.style.height = `${this.size}rem`; } }, mounted() { this.updateSvgSize(); } }; </script> <style scoped> svg { transition: width 0.2s, height 0.2s; } </style> ``` 3. 在你的Vue页面中使用`SvgElement`组件,并传递相应的SVG代码。 ```html <template> <div> <svg-element></svg-element> </div> </template> <script> import SvgElement from "@/components/SvgElement.vue"; export default { components: { SvgElement } }; </script> ``` 这样,当你在SVG元素上滚动鼠标滚轮时,尺寸会相应地增加或减小。初始尺寸为1,并且使用了Vue的响应式数据来实时更新SVG元的大小。请确保已经安装了相关依赖并正确配置了Vue项目。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值