svg画简单的立方体

2024-05-28 20:20
文章标签 简单 立方体 svg

本文主要是介绍svg画简单的立方体,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

开发背景

要开发一个拖拽的大屏项目,其中涉及到一个装饰组件,是一个立方体cube,要求颜色可以修改,大小可以拖拽改变。

效果如下

在这里插入图片描述

分析

经过我一番奇思妙想,决定用svg实现,因为对svg比较熟悉。那就先来在草纸上画草图吧。

在这里插入图片描述

先假设它的长宽为400,300,4:3的数据好计算,有利于我们前期的分析。分析发现,这个立方体可以简化成两个平面,上面顶部蓝色的和侧面我们所看到的(呈渐变效果)。这就好办多了,定义两条path路径,由其中一个path构建顶部的面,再用另一个path构建侧边的面。

顶部的面设置其fill填充颜色为固定颜色,侧边的面设置其fill为渐变色。此处要注意,渐变色是从中间向两边扩散,这块我用的是linearGradient实现的,具体参照下面代码。

代码实现

分析完后就可以进入coding环节了,思路就是先按照草图画出一个固定宽高的原型,再用变量替换掉固定值。

已知变量
{width: 450,height: 170,decorationColor1: '#244ab2',decorationColor2: '#1c2c9d',fillColor: '#00dcff'
}
关键绘制部分代码
<svgheight="100%"width="100%"><defs><linearGradient id="gradient1"><stopoffset="0%":stop-color="decorationColor1"/><stopoffset="50%":stop-color="decorationColor2"/><stopoffset="100%":stop-color="decorationColor1"/></linearGradient></defs><path:fill="fillColor"stroke="transparent"stroke-width="0":d="`M 0 ${height * (1/3)}L ${width * 0.5} 0L ${width} ${height * (1/3)}L ${width * 0.5} ${height * (2/3)}L 0 ${height * (1/3)}`"/><pathfill="url(#gradient1)"stroke="transparent"stroke-width="0":d="`M 0 ${height * (1/3)}L ${width * 0.5} ${height * (2/3)}L ${width} ${height * (1/3)}L ${width} ${height * (2/3)}L ${width * 0.5} ${height}L 0 ${height * (2/ 3)}L 0 ${height * (1/3)}`"/>
</svg>
全部代码(vue
<template><div:key="updateKey"style="width: 100%;height: 100%"class="bs-design-wrap"><svgheight="100%"width="100%"><defs><linearGradient id="gradient1"><stopoffset="0%":stop-color="decorationColor1"/><stopoffset="50%":stop-color="decorationColor2"/><stopoffset="100%":stop-color="decorationColor1"/></linearGradient></defs><path:fill="fillColor"stroke="transparent"stroke-width="0":d="`M 0 ${height * (1/3)}L ${width * 0.5} 0L ${width} ${height * (1/3)}L ${width * 0.5} ${height * (2/3)}L 0 ${height * (1/3)}`"/><pathfill="url(#gradient1)"stroke="transparent"stroke-width="0":d="`M 0 ${height * (1/3)}L ${width * 0.5} ${height * (2/3)}L ${width} ${height * (1/3)}L ${width} ${height * (2/3)}L ${width * 0.5} ${height}L 0 ${height * (2/ 3)}L 0 ${height * (1/3)}`"/></svg></div>
</template>
<script>import {refreshComponentMixin} from 'data-room-ui/js/mixins/refreshComponent'export default {name: 'Decoration16',components: {},mixins: [refreshComponentMixin],props: {// 卡片的属性config: {type: Object,default: () => ({})}},data() {return {}},computed: {width() {return this.config.w},height() {return this.config.h},fillColor() {return this.config.customize.borderColor},decorationColor1() {return this.config.customize.decorationColor1},decorationColor2() {return this.config.customize.decorationColor2}},watch: {},mounted() {},methods: {}
}
</script><style lang="scss" scoped></style>

这篇关于svg画简单的立方体的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1011593

相关文章

一份LLM资源清单围观技术大佬的日常;手把手教你在美国搭建「百万卡」AI数据中心;为啥大模型做不好简单的数学计算? | ShowMeAI日报

👀日报&周刊合集 | 🎡ShowMeAI官网 | 🧡 点赞关注评论拜托啦! 1. 为啥大模型做不好简单的数学计算?从大模型高考数学成绩不及格说起 司南评测体系 OpenCompass 选取 7 个大模型 (6 个开源模型+ GPT-4o),组织参与了 2024 年高考「新课标I卷」的语文、数学、英语考试,然后由经验丰富的判卷老师评判得分。 结果如上图所

回调的简单理解

之前一直不太明白回调的用法,现在简单的理解下 就按这张slidingmenu来说,主界面为Activity界面,而旁边的菜单为fragment界面。1.现在通过主界面的slidingmenu按钮来点开旁边的菜单功能并且选中”区县“选项(到这里就可以理解为A类调用B类里面的c方法)。2.通过触发“区县”的选项使得主界面跳转到“区县”相关的新闻列表界面中(到这里就可以理解为B类调用A类中的d方法

自制的浏览器主页,可以是最简单的桌面应用,可以把它当成备忘录桌面应用

自制的浏览器主页,可以是最简单的桌面应用,可以把它当成备忘录桌面应用。如果你看不懂,请留言。 完整代码: <!DOCTYPE html><html lang="zh-CN"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><ti

python实现最简单循环神经网络(RNNs)

Recurrent Neural Networks(RNNs) 的模型: 上图中红色部分是输入向量。文本、单词、数据都是输入,在网络里都以向量的形式进行表示。 绿色部分是隐藏向量。是加工处理过程。 蓝色部分是输出向量。 python代码表示如下: rnn = RNN()y = rnn.step(x) # x为输入向量,y为输出向量 RNNs神经网络由神经元组成, python

宝塔面板部署青龙面板教程【简单易上手】

首先,你得有一台部署了宝塔面板的服务器(自己用本地电脑也可以)。 宝塔面板部署自行百度一下,很简单,这里就不走流程了,官网版本就可以,无需开心版。 首先,打开宝塔面板的软件商店,找到下图这个软件(Docker管理器)安装,青龙面板还是安装在docker里,这里依赖宝塔面板安装和管理docker。 安装完成后,进入SSH终端管理,输入代码安装青龙面板。ssh可以直接宝塔里操作,也可以安装ssh连接

XMG Quartz2D的简单使用

// //  Quratz2DView.m //  Quartz2D // //  Created by 王宁 on 16/5/6. //  Copyright © 2016年 ylshmacmini. All rights reserved. // #import "Quratz2DView.h" //Quartz@2D是一个二维绘图引擎,同时支

网页脚本输入这么简单

如何在网页中进行脚本操作呢? 研究了一下,很简单,用google浏览器的Console直接操作javaScript。思路: Created with Raphaël 2.1.0 开始 输入(如何输入) 点击(如何点击) 结束 下面是,通过脚本刷直播屏的实现,直接在Console输入即可 var words=new Arra

Linux网络编程之简单并发服务器

1.概念 与前面介绍的循环服务器不同,并发服务器对服务请求并发处理。而循环服务器只能够一个一个的处理客户端的请求,显然效率很低. 并发服务器通过建立多个子进程来实现对请求的并发处理,但是由于不清楚请求客户端的数目,因此很难确定子进程的数目。因此可以动态增加子进程与事先分配的子进程相结合的方法来实现并发服务器。 2. 算法流程 (1)TCP简单并发服务器:     服务器子进程1:

简单 使用 的makefile编写 框架

1、指定编译器,如海思平台:CROSS_COMPILE=arm-hisiv100nptl-linux-; 2、指定编译工具:GCC=$(CROSS_COMPILE)gcc   CC=$(CROSS_COMPILE)g++; 3、使用 export 导出 子makefile 要用的变量; 4、定义变量的形式  指定 工程源文件 需要使用到的 “宏”,在后面的 LDFLAGS 里面使用 -D将其

AOP架构的简单使用

手机App中,用户行为统计是非常重要的一部分,如何做到用户行为的统计呢,比较笨的方法是在需要统计的行为,例如朋友圈,语音等的方法的代码中,打印Log,但这样做非常的麻烦,而且工作量很大,那有没有更好的方法呢?答案就是通过AOP,那什么是AOP? AOP是指 Aspect oriented programming,也就是面向切面编程,接下来我将展现一下如何使用AOP进行拥护行为统计,以下是我的项目