首页 > 编程语言 >微信小程序 Path2D 不支持 svg 路径的解决办法

微信小程序 Path2D 不支持 svg 路径的解决办法

时间:2024-02-05 16:47:12浏览次数:32  
标签:... canvasCommands 微信 cmd ctx Path2D svg 80

问题

开发一个微信小程序项目的时候需要用到Path2D这个对象,但是发现小程序的Path2D对象不支持实例化的时候直接传入'svg path',导致下面的代码运行的时候报错(浏览器中可运行)

#其它代码(省略)
...

//核心代码
let p = new Path2D("M10 10 h 80 v 80 h -80 Z");   //微信小程序中会报错
ctx.fill(p);

而小程序的Path2D对象只支持用命令式编程的方式去构建Path2D路径,代码如下:

#其它代码(省略)
...

//核心代码
let p = new Path2D();
p.moveTo(10, 10);
p.lineTo(90, 10);
p.lineTo(90, 90);
p.lineTo(10, 90);
p.closePath();
ctx.fill(p);

这种方式有两个问题:

  • 路径比较复杂这样的绘制代码就会很多(不优雅)
  • 不能使用现有svg path(主要问题)

解决办法

查了相关的开发文档之后决定写一个工具函数svgPathStringToCanvas来解析svg path并且生成这样的绘制命令,这样就完美解决了上面两个问题

function svgPathStringToCanvas(svgPathData) {
    console.log(svgPathData);
    // 使用正则表达式拆分 SVG 路径字符串
    const pathParts = svgPathData
        .split(/(^|\s+)(?=[A-Z])/)
        .filter((part) => part !== " ");
    // 存储 Canvas 绘图命令的数组
    const canvasCommands = [];
    // 遍历 SVG 路径的各个部分
    for (const part of pathParts) {
        // 将部分拆分为命令符(如 M、L、C、Q、Z)和对应的参数
        const [cmd, ...rawParams] = part.split(/\s+/);
        // 将参数转换为浮点数数组
        const params = rawParams.map((param) => parseFloat(param));
        // 根据命令符生成对应的 Canvas 绘图命令并存储到数组中
        if (cmd === "M") {
            canvasCommands.push((ctx) => ctx.moveTo(...params));
        } else if (cmd === "L") {
            canvasCommands.push((ctx) => ctx.lineTo(...params));
        } else if (cmd === "C") {
            canvasCommands.push((ctx) => ctx.bezierCurveTo(...params));
        } else if (cmd === "Q") {
            canvasCommands.push((ctx) => ctx.quadraticCurveTo(...params));
        } else if (cmd === "Z") {
            canvasCommands.push((ctx) => ctx.closePath());
        }
    }
    // 返回一个函数,该函数接受 Canvas 上下文对象并执行存储的绘图命令
    return (ctx) => canvasCommands.forEach((cmd) => cmd(ctx));
}

有了这个函数就可以不使用Path2D相关api了,兼容性也更好了。

使用方式

 #其它代码(省略) 
...

//核心代码
var canvasPathFun  = svgPathStringToCanvas("M10 10 h 80 v 80 h -80 Z");
canvasPathFun(ctx)
ctx.fill()

参考文档

原文地址:https://www.abcddd.xyz/posts/2024/01/31/weixin-miniapp-path2d-not-support-svg-path/

标签:...,canvasCommands,微信,cmd,ctx,Path2D,svg,80
From: https://www.cnblogs.com/wuhuan-think/p/18008386

相关文章

  • flutter3+dart3聊天室|Flutter3跨平台仿微信App语音聊天/朋友圈
    全新研发flutter3+dart3+photo_view跨多端仿微信App界面聊天Flutter3-Chat。flutter3-chat基于最新跨全平台技术flutter3+dart3+material-design+shared_preferences+easy_refresh构建的仿微信APP界面聊天实例项目。实现发送图文表情消息/gif大图、长按仿微信语音操作面板、图片......
  • C# 微信公众号token 认证笔记
     因公司需要,开通了微信公众号。在开发对接中摸索了2天,写下此记,备忘。 服务器地址(URL):https://www.findtechgroup.net/Handler1.ashx因http80端口已被其他业务占用,只能用https(443)协议,需路由映射服务器的443端口。 IIS中需要添加SSL证书,这个证书在阿里云中免费申请,......
  • 微信支付普通商户与AppID账号关联管理-授权
     微信支付普通商户与AppID账号关联管理二、名词解释名词释义微信支付普通商户公司企业、政府机关、事业单位、社会组织、个体工商户、个人卖家、小微商户。(微信支付商户接入指引)AppID已通过微信认证的服务号,订阅号*[1],小程序,企业微信*[2],移动应用*[3]......
  • 如何通过APPID查询微信小程序,看看那些appid都是谁
    通过统计看到一些跳转来源的appid,有时候很想知道这些appid都是谁,做到心里有数,但现在appid反查小程序的信息,官方没有开放的接口。目前大多数的方案是:通过自己做一个小程序页面,在这个页面去调用这个appid,微信小程序会提示是否打开“xxx”小程序,在这里可以看到。在公众号去绑......
  • 微信小程序如何取得用户的openid
    在微信小程序中,可以通过调用微信提供的API来获取用户的openid。以下是获取用户openid的步骤:首先,在微信开放平台(https://open.weixin.qq.com/)上注册一个小程序,并获取到AppID和AppSecret。在小程序的app.js文件中,引入微信小程序的SDK:constwx=require('wx');在小程序......
  • 还在用QQ微信截图?这款神器你值得拥有
    在这个网络十分发达的时代,QQ、微信的使用已经十分普遍,所以大多数人都经常使用QQ和微信截图。但是,你是否遇到过这样的困难:着急截一个图,还得先登录微信QQ?微信QQ截图功能不够强大?这时候,肯定有人说,Snipaste不香吗,要微信QQ截图有什么用?的确,但是Snipaste是收费的,时不时会弹出一些提......
  • Java生成微信小程序二维码的方式有哪些?
    大家好我是咕噜美乐蒂,很高兴又见面啦!今天我们来谈一下如何使用Java生成微信小程序二维码,有哪些方式方法呢?生成微信小程序二维码是开发微信小程序时的常见需求之一。在Java中,我们可以使用多种方式来生成微信小程序二维码。本文将为您介绍几种常用的方式。一、使用第三方库1.zxingzxi......
  • 微信小程序如何实现动态显示和隐藏某个控件
    Hello大家好!我是咕噜铁蛋!微信小程序作为一种轻量级的应用开发平台,越来越受到开发者和用户的关注。在微信小程序的开发过程中,控制元素的显示和隐藏是一个常见的需求。通过动态显示和隐藏某个控件,我们可以根据用户的操作或特定的条件来提供更好的用户体验。本文铁蛋将为为大家详细介......
  • 【Java】SpringBoot集成微信V3支付
    前言这篇文章主要实现一下通过IJPay来实现微信v3支付案例,本篇文章使用的是JSAPI即小程序支付准备工作导入依赖<dependency><groupId>com.github.javen205</groupId><artifactId>IJPay-WxPay</artifactId><version>2.9.6</versio......
  • 微信小程序如何控制元素的显示和隐藏
    Hello大家好我是咕噜铁蛋!在微信小程序开发中,控制元素的显示和隐藏是非常常见的需求。通过控制元素的显示和隐藏,我们可以根据用户的操作或特定的条件来动态地展示或隐藏某些内容,从而提升用户体验。在本文中,我将分享如何在微信小程序中实现元素的显示和隐藏的方法。使用wx:if和hidden......