之前在做一个吉他谱网站项目的时候一直想找一款可以在网页端渲染gp5格式乐谱(即guitar pro5的默认乐谱格式)的前端插件,不过一直没有找到合适的,就这样这个项目中止了半年多,但最近终于发现了一个非常不错的插件“AlphaTab”,它支持在网页端渲染乐谱,采用SVG绘制;它不仅支持gp5,也同样支持gp3、gp4、gpx,还支持一种专门为AlphaTab创造的用文本表示的乐谱格式。除了在它的官网有一些简单的教程,网上就没有找到什么教程说这个插件了,所以在看了它在github上面的demo之后,就想着写一个简单的关于如何使用alphatab的教程。

下载插件

这下面是alphatab的下载地址

AlphaTab下载地址

下载之后将压缩文件中的JavaScript文件夹复制出来。

准备一个gp5格式的乐谱文件

我在网上找了一个押尾光太郎的twilight的gp5格式的吉他指弹谱,我们将用这个乐谱来测试

代码部分

在在页面中引入 jquery和下载下来的JavaScript文件夹中的swfobject.jsalphaTab.min.js,然后再初始化alphatab,并指定gp5文件的路径。

<!DOCTYPE html>
<html>
    <head>
        <meta charset='utf-8'>
        <meta name='viewport' content='width=device-width,initial-scale=1.0'>
        <link href="https://s2.pstatp.com/cdn/expire-1-M/twitter-bootstrap/3.3.7/css/bootstrap.min.css" rel='stylesheet'>
        <script src="https://s1.pstatp.com/cdn/expire-1-M/jquery/2.2.1/jquery.min.js" type="application/javascript"></script>
        <script src="https://s2.pstatp.com/cdn/expire-1-M/twitter-bootstrap/3.3.7/js/bootstrap.min.js" type="application/javascript"></script>

        <!-- 引入alphatab的js文件 -->
        <script type="text/javascript" src="JavaScript/swfobject.js"></script>
        <script type="text/javascript" src="JavaScript/alphaTab.min.js"></script>
        <title>twilight</title>
        <script>

        </script>
    </head>
    <body>
        <div class='container'>
            <div class='row'>
                <div id='alphatab'></div>
            </div>
        </div>
    </body>
        <script>
            <!--初始化alphatab并指定gp5文件路径-->
            $('#alphatab').alphaTab({
                file: 'twilight.gp5',
                track: [0]
            })
        </script>
</html>

打开浏览器查看

使用AlphaTab在网页上渲染gp5格式的乐谱

这样就可以在网页端显示gp5格式文件了。

如果无法加载gp5文件出现了这样的错误:
Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension, https.
无法加载本地资源,只需要在浏览器的快捷方式中的目标后面添加上--allow-file-access-from-files,然后重启浏览器就行了。

使用AlphaTab在网页上渲染gp5格式的乐谱

之后部署在服务器上若gp5文件与网页不在同一域名下也可能会出现错误,只要处理好跨域请求就能正常显示。

其他

以上就是关于使用AlphaTab的简单教程啦,希望对有需要的小伙伴有所帮助,然后这个链接(https://www.alphatab.net/ ) 是alphatab的官方网站,可以在这里面下载与查看关于插件的使用教程;有问题的小伙伴欢迎在下面留言,我看到了会及时回复的。

评论

JJ

Jitashe.org (Discuz)可以用用loading的方式載入aphatab,Wordpress怎麼做呢,還請多指教

回复

JJ

能請問一下要怎麼從CMS裡把file 提取出來 file: 'twilight.gp5',

回复

  • 最新随笔

  • 尝试让DALLE生成一些连续的精灵图,让gpt帮忙生成一些提示词,如果能稳定输出的话就很强大了。
    让gpt帮忙生成的DALLE提示词
    "Generate a pixel art sprite sheet of a character walking in four directions (north, south, east, west) in a retro video game style."
    "Create a series of pixel art frames showing a character performing different actions like walking, running, jumping, and attacking in a classic 2D game aesthetic."
  • 路过别人山庄的门口,被一条大黑狗边叫边追过来,幸好骑电动车,不然还不一定跑得过,哈哈哈哈哈哈哈哈哈哈。
  • 最近两周也没咋出去玩,主要也是觉得没啥好玩的(笑哭)。看完布莱恩阿瑟的《复杂经济学》后,里面那个酒吧问题勾起我的兴趣,最近空了就花了些时间实现个python版本,顺便搞了篇博文,很享受这种新知识能和已有知识碰撞的感觉。(配张前段时间拍的图片,梧桐山门口前面那条路,挺漂亮的)
  • 盐田港夜景
  • 为啥这猫总喜欢喝杯子里的水
  • 确实开始冷了,在树林里至少要比人类聚集区低个几度,进出入口就能很明显感觉到。看看深圳水库的风景,貌似后面的视野更开阔。
  • 给随笔加了多图的功能,传一传周末拍的风景图,漫无目的的逛也挺好玩的。
  • 逻辑自洽是一套体系的根基,最根本的因素,最吸引人的地方