微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

是否可以以及如何在 Phaser 3 中加载 SVG 字符串而不是从路径/url 加载它?

如何解决是否可以以及如何在 Phaser 3 中加载 SVG 字符串而不是从路径/url 加载它?

我的代码中有几个 SVG,我想将它们与 Phaser(专门用于粒子)一起使用,而无需将它们保存到单独的 SVG 文件中。

const svgString = `<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M24 10h-10v-10h-4v10h-10v4h10v10h4v-10h10z"/></svg>`;

function preload()
{
    // Usual way
    this.load.svg('plus','assets/svg/plus.svg');

    // What I would like to do
    this.load.svg('plus',svgString)
}

有没有办法实现这一目标(以及如何实现)?

解决方法

问题已在 Phaser 3 论坛上得到解答 - https://phaser.discourse.group/t/is-it-possible-and-how-to-load-svg-string-in-phaser-3-instead-of-loading-it-from-path-url/9668

const svgString = `<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M24 10h-10v-10h-4v10h-10v4h10v10h4v-10h10z"/></svg>`;

function preload()
{
    const blob = new Blob([svgString],{ type: 'image/svg+xml' });
    const url = URL.createObjectURL(blob);

    this.load.svg('plus',url)
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。