中秋赏月:基于vite.js+vue3.js+fabric.js在线制作月饼

简介: 中秋赏月:基于vite.js+vue3.js+fabric.js在线制作月饼

image.png

MoonCake

在线制作中秋月饼


言简意赅,我主要分享一下思路


体验基于vite.js + vue3.js 的快速开发过程,并将代码发布到github


技术方案


vite.js: https://vitejs.dev/

vue3.js: https://cn.vuejs.org/index.html

fabric.js: http://fabricjs.com/

FileSaver.js https://www.npmjs.com/package/file-saver

开始项目


pnpm create vite

选择vue模板


核心代码


<template>
  <div class="app">
    <div class="canvas-warp">
      <canvas
        width="400"
        height="400"
        id="canvas"
      ></canvas>
    </div>
    <button
      style="margin-top: 20px"
      class="button"
      @click="handleExportClick"
    >
      制作月饼
    </button>
  </div>
</template>
<script>
// created at 2022-08-23
import { fabric } from 'fabric'
import FileSaver from 'file-saver'
export default {
  name: 'App',
  props: {},
  components: {},
  data() {
    return {
      canvas: null,
    }
  },
  computed: {},
  methods: {
    async getData() {},
    // 导出为图片
    handleExportClick() {
      let base64 = this.canvas.toDataURL('png')
      FileSaver.saveAs(base64, 'mooncake.png')
      // 输出 png 图片可能会打断 canvas 的渲染
      this.canvas.requestRenderAll()
    },
  },
  mounted() {
    const canvas = new fabric.Canvas('canvas', {
      preserveObjectStacking: true, // 被选中时保持原有层级
      // selection: false,
    })
    // canvas.selection = false
    // 绘制一个圆
    const circle = new fabric.Circle({
      // top: 100,
      // left: 100,
      radius: 100, // 圆的半径 50
      fill: 'rgb(250,201,81)',
    })
    canvas.add(circle)
    circle.viewportCenter()
    // 绘制月饼馅
    const text = new fabric.Textbox('五仁月饼', {
      fill: 'rgb(180,110,48)',
    })
    canvas.add(text)
    text.viewportCenter()
    this.canvas = canvas
    // console.log(canvas.getObjects())
  },
  created() {
    this.getData()
  },
}
</script>
<style lang="less"></style>
<style lang="less" scoped>
.app {
  text-align: center;
}
.canvas-warp {
  border: 1px solid #ccc;
  box-sizing: border-box;
}
#canvas {
  width: 100%;
  height: 100%;
}
@media only screen and (max-width: 768px) {
  .app {
    padding: 0 8px;
  }
  .button {
    width: 80%;
    padding: 20px 0;
    font-size: 1.5rem;
  }
  .canvas-warp{
    padding: 10px;
  }
}
</style>

整体不难,调用Fabric.js 的接口,绘制一个基本的圆,就是月饼,再绘制一个文字,就完成了月饼的制作。


Fabric.js还提供了编辑功能,可以将文字修改为你想要的月饼馅,然后导出图片,直接将绘制完成的月饼下载到本地,发给你想要送月饼的人即可。


最后还通过github提供的github Actions 自动将提交的代码打包发布到github page。


这样就完成了项目创建到打包发布的完整过程。


源码:https://github.com/mouday/moon-cake


在线体验制作月饼:https://mouday.github.io/moon-cake/

相关文章
|
Java
Notepad++ 中如何将代码格式化
Notepad++ 中如何将代码格式化   在阅读别人的代码时偶尔会遇到格式很乱,阅读起来很费劲的情况,若手动改,很容易出错且很费时间,这时可以借助一些专业的编辑器来格式化代码,NotePad++是一个轻量级的代码编辑器,占用内存少,运行速度快,但是Notepad++本身是不带这个格式化功能的,但他支持NppAStyle插件 完成格式化。
4995 0
|
5月前
|
人工智能 数据可视化 调度
【三桥君】如何画前趋图?如何正确绘制前趋图,以清晰地展示语句或进程之间的依赖关系?
本文AI专家三桥君系统介绍了前趋图(Precedence Graph)这一可视化工具。前趋图作为有向无环图,能清晰展示任务间的执行顺序和依赖关系。三桥君详细阐述了前趋图的基本概念、绘制步骤(包括任务识别、依赖分析、节点绘制等),并通过实例展示了简单和复杂两种场景下的应用。同时指出前趋图在程序优化、进程调度和任务管理等领域的重要价值,强调其能有效避免逻辑错误、优化资源分配。三桥君认为掌握前趋图的绘制方法对提升程序性能和项目管理效率具有重要意义。
173 0
|
移动开发 前端开发 安全
uni-app跨域调试你学会了没
uni-app跨域调试你学会了没
380 0
|
数据采集 分布式计算 监控
深入调查研究 Kettle
【10月更文挑战第20天】
230 0
|
开发工具 git
Git恢复之前版本的两种方法reset、revert(图文详解)
Git恢复之前版本的两种方法reset、revert(图文详解)
1369 0
|
开发框架 Unix Linux
LangChain 构建问题之在Unix/Linux系统上设置OpenAI API密钥如何解决
LangChain 构建问题之在Unix/Linux系统上设置OpenAI API密钥如何解决
227 0
|
存储 缓存 前端开发
掌握Nginx缓存策略:提高网站性能,降低响应时间
掌握Nginx缓存策略:提高网站性能,降低响应时间
812 1
|
人工智能 Ubuntu C语言
【Ubuntu工具】详细图文教程:Ubuntu系统上安装QT6.2
【Ubuntu工具】详细图文教程:Ubuntu系统上安装QT6.2
1547 0
|
前端开发 API
vue3使用canvas画布合成图片
Vue3中可以使用&lt;canvas>标签绘制图形,并使用Canvas API对图形进行操作和绘制,其中包括了对图形进行合成的方法。下面是一个使用Canvas API合成图片的简单例子:
1571 0
|
JSON 前端开发 数据格式
前端提升生产力系列一(vue3 element-plus 配置json快速生成form表单组件)
在PC端日常的使用中,使用最多的莫过于表单和列表了,故此对table列表和form表单进行了统一的封装,通过json配置就可以快速适配table列表和form表单。
526 0
前端提升生产力系列一(vue3 element-plus 配置json快速生成form表单组件)