当前位置: 首页 > wzjs >正文

合肥做网站优化哪家好app运营需要做哪些

合肥做网站优化哪家好,app运营需要做哪些,请人做软件开发的网站,专做眼镜的网站使用html2canvas进行截图操作 在 Vue 中使用 ​​html2canvas​​ 将 HTML 元素(如包含贝塞尔曲线的 Canvas/SVG)转换为图片 下载html2canvas npm install html2canvas在页面中使用,要截取哪个div的内容,先给这个div加一个ref标…

使用html2canvas进行截图操作

在 Vue 中使用 ​​html2canvas​​ 将 HTML 元素(如包含贝塞尔曲线的 Canvas/SVG)转换为图片

下载html2canvas

npm install html2canvas

在页面中使用,要截取哪个div的内容,先给这个div加一个ref标识,如ref=“html_container”

主要用到的:
在这里插入图片描述

具体代码:

<template><div class="CanvasPage" ref="html_container"><!-- 未处理时的canvas画布数据 --><canvas :id="'canvas' + '002'" :style="`position: absolute; `"></canvas><!-- 使用赛贝尔曲线以及笔锋处理之后的画布数据 --><canvas:id="'canvas' + '001'"@pointerdown.stop="onPointerDown":style="`position: absolute; `"@touchstart="onTouchstart"></canvas><div class="CanvasPageSave"><el-button @click="toSave" type="primary">保存当前页面</el-button></div></div>
</template><script setup>
import { ref, reactive, onMounted } from "vue";
import { Bezier } from "bezier-js";
import html2canvas from 'html2canvas'
let html_container = ref(null);
let canvas, ctx;
let canvasCover, ctxCover;
const winH = window.innerHeight,winW = window.innerWidth;let isMove = false;
// canvas初始化
const initCanvas = () => {canvas = document.getElementById("canvas001");ctx = canvas.getContext("2d", {antialias: true, // 抗锯齿});canvas.width = winW; // canvas宽度canvas.height = winH; // canvas高度ctx.lineWidth = 2; // 画线默认宽度ctx.strokeStyle = "red"; // 设置颜色// 复制出来一份原始的canvas画线数据canvasCover = document.getElementById("canvas002");ctxCover = canvasCover.getContext("2d", {antialias: true, // 抗锯齿});canvasCover.width = winW; // canvas宽度canvasCover.height = winH; // canvas高度ctxCover.lineWidth = 2; // 画线默认宽度ctxCover.strokeStyle = "red"; // 设置颜色
};let startx = ref(0), //起始坐标starty = ref(0),pointerId = ref(null);let points = []; // 收集所有点的数据// pointerdown同时处理鼠标、触摸屏和触控笔。
const onPointerDown = (e) => {points = [];isMove = true;const { offsetX, offsetY } = e;pointerId = e.pointerId;startx.value = offsetX;starty.value = offsetY;canvas.addEventListener("pointermove", onDrawMove);canvas.addEventListener("pointerup", onDrawUp);
};/* 单个触摸事件 */
// 处理移动逻辑
const onDrawMove = (e) => {if (isMove) {const { offsetX, offsetY } = e;if (pointerId != e.pointerId) return;// 原始画线数据ctxCover.beginPath();ctxCover.lineWidth = 2; // 设置线条粗细ctxCover.moveTo(startx.value, starty.value);ctxCover.lineTo(offsetX, offsetY);ctxCover.stroke();ctxCover.closePath();startx.value = offsetX;starty.value = offsetY;points.push({x: offsetX,y: offsetY,});e.preventDefault();}
}
// 处理释放逻辑
const onDrawUp = (e) => {ctx.closePath();// 鼠标释放时处理线条,将处理过的数据显示,之前的数据清空drawSmoothLine();points = [];isMove = false;document.removeEventListener("pointermove", onDrawMove);document.removeEventListener("pointerup", onDrawUp);
}
// 优化线条
const drawSmoothLine = () => {isMove = false;if (points.length > 1) {let num1 = 200; // 补点数let num2 = 20; // 从后面开始变细的点数const startWidth = 2; // 设置线条粗细const endWidth = 0; // 最后变细的宽度ctxCover.clearRect(0, 0, canvasCover.width, canvasCover.height); // 清除原始数据// 在释放的时候使用贝塞尔曲线重新处理画出来的线ctx.lineWidth = startWidth;// 设置线条粗细// 使用赛贝尔曲线让线条更丝滑const bez = new Bezier(points);const pointOnCurve = bez.getLUT(num1); // 补点ctx.beginPath();ctx.moveTo(pointOnCurve[0].x, pointOnCurve[0].y);// 截取,从开始截取到需要变细的位置,正常画线pointOnCurve.slice(0, -num2).forEach((p) => ctx.lineTo(p.x, p.y)); ctx.stroke();// 笔锋,设置线从哪个位置开始,按一定比例变细pointOnCurve.slice(-num2).forEach((p, px) => {const lineWidth = startWidth + ((endWidth - startWidth) * px) / num2;ctx.lineWidth = lineWidth;ctx.lineTo(p.x, p.y);ctx.stroke();});ctx.lineWidth = startWidth;ctx.closePath();}
};const toSave = () => {// html2canvas截取工具,第一个参数是截取的元素这里使用的ref,第二个参数是相应的配置html2canvas(html_container.value, {background: 'transparent',useCORS: true}).then((canvas) => {const base64 = canvas.toDataURL().replace(/^data:image\/(png|jpg);base64,/, '');// console.log(`data:image/png;base64,${base64}`);// 可选:自动下载图片const link = document.createElement('a');link.download = 'bezier-curve.png';link.href = `data:image/png;base64,${base64}`;link.click();});
}
onMounted(() => {initCanvas();
});
</script><style scoped lang="scss">
.CanvasPage {width: 100%;height: 100%;background-color: #044444;position: relative;.CanvasPageSave {position: absolute;left: 0;top: 0;}
}
</style>
http://www.dtcms.com/wzjs/329635.html

相关文章:

  • 大连做网站制作营销网站建设软件下载
  • 邯郸网站设计怎么注册百度投流
  • 整个网站的关键词网站快速上排名方法
  • 绵阳网站建设企业河北网站seo外包
  • 网站页面数怎么做微商怎么引流被加精准粉
  • dedecms学校网站今日深圳新闻最新消息
  • 南昌英文网站建设成人技能培训
  • 超市网站开发建设建议百度站长中心
  • 河东网站建设网络优化工具
  • 网站推广广告 优帮云google play应用商店
  • 白领兼职做网站百度百科合作模式
  • 虎门镇最新疫情最新消息绍兴seo排名公司
  • 湖南营销型网站建设 真好磐石网络嘉兴网站建设
  • 廉江网站开发公司乱码链接怎么用
  • 织梦唯美网站源码怎么优化网站关键词排名
  • 网站改版竞品分析怎么做360收录
  • 青岛网站seo收费企业网站seo平台
  • 网站建设baner市场监督管理局上班时间
  • 技术支持 东莞网站建设深圳关键词优化
  • liunx做网站跳转网站搭建源码
  • 如何构思公司网站企业网站设计毕业论文
  • 怎样模仿别人的网站百度seo点击工具
  • 网站如何做即时聊天杭州关键词优化测试
  • 外国平面设计网站有哪些网站关键词seo优化公司
  • wordpress 上传文件名百度搜索seo优化技巧
  • 饭店餐厅网站建设品牌营销策划包括哪些内容
  • .net网站开发教程360seo关键词优化
  • 昆山靠谱的网站建设公司色盲测试图
  • 做网站运营有前景吗客服外包
  • 域名怎么卖出去东莞seo优化团队