花潮论坛

搜索
热搜: 活动 交友 discuz
查看: 147|回复: 29

带进度条+歌词同步的canvas画布音频播放器

[复制链接]
  • TA的每日心情
    慵懒
    2025-12-16 08:52
  • 签到天数: 1671 天

    [LV.Master]伴坛终老

    3050

    主题

    13万

    回帖

    28万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮帅哥鼠牛虎兔龙蛇马羊猴鸡狗猪多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫相遇之美鹰傲苍穹花好月圆紫色情节飞龙在天王者至尊大将风范音画大师天籁妙音共看流星风雨同行我心永远幸福快乐喜乐安康侠骨柔肠心想事成开朗大方花潮管理

    发表于 2022-8-26 12:53 | 显示全部楼层 |阅读模式

    请马上登录,朋友们都在花潮里等着你哦:)

    您需要 登录 才可以下载或查看,没有账号?立即注册

    x
    带进度条+歌词同步的canvas画布音频播放器 | 马黑黑

    做童安格的《耶利亚女郎》帖子时,一时兴起用canvas画布做了一个进度条加歌词同步的音频播放器,感觉基本功能、外观都还可以,就是可定制性不够强。想想还是认为将播放器作为一个实例对象加以操作,使用时方能拥有更方便的自定义设定。

    实例化对象适合做音频播放器,属性、方法可以无序化存在,需要什么不需要什么可以随意增删,无需因为一个属性或方法的变化四处去找寻和修改关联的代码语句,基于对象的变动所涉及修改范围基本就在对象代码块之内。

    所以,建立了一个 mplayer 对象,它是实例化的,因为无需克隆:

    let mplayer = {
            属性1: 值,
            属性2: 值,
            属性N: 值,
            方法1: function() { ... },
            方法2: function() { ... },
            方法M: function() { ... },
    }

    每一个属性和方法都是以键值对的形式存在,每一个属性和方法之间用逗号隔开。分行不是必须的,分行只是为了方便组织和阅读代码。

    我们的 mplayer 对象的最终任务是描述播放器界面及其行为。实现手段是,对象给出各种组成播放器所需的“零件”即属性并提供这些零件的组装方法。比方说,播放器的按钮是个圆形的小东东,它上面还有一个表示播放的三角形图案或是表示暂停的两道杠,圆形、三角形、两道杠这些部件,通过对象的方法实现,而圆形等的尺寸、位置以及颜色啥的,是对象提供的“零件”即属性。具体说,圆形的按钮,圆心xy坐标及其半径,还有它要上什么颜色,都是 mplayer 对象以键值对的形式一一提供的属性,而圆形按钮画在哪、怎么画,则是通过 mplayer 对象提供的方法去完成。mplayer 提供的所有属性与方法,都是基于一个播放器的基本样式和功能,换言之,我们把实现一个播放器所需的“零件”和“组装”方法全部封装在了一个叫做 mplayer 的对象里。

    对象的方法其实就是函数,函数是可以接收“第三方”提供的参数的。例如,mplayer 要绘制出歌词,它并不知道歌词是什么,这时,就由 audio 控件的播放进度机制来处理歌词,并一句一句地传递给 mplayer 对象,mplayer 则将歌词给绘制出来。就是说,针对lrc同步,mplayer 只管处理一个歌词变量 text,text 的内容传递过来了它就绘制这些文本。

    具体实现过程请在播放器源码中体会:
    1. <canvas id="player" style="position: absolute; left: 10px; top: 10px; border: 1px solid;"></canvas>

    2. <script>
    3. let ctx = player.getContext('2d'),
    4.         w = player.width = 350,
    5.         h = player.height = 100,
    6.         flag, //鼠标滑过按钮标识
    7.          aud = new Audio();
    8. let mplayer = {
    9.         startX: 30, //圆形按钮圆心x
    10.         startY: 70, //圆形按钮圆心y
    11.         radius: 16, //圆形按钮半径
    12.         c_lrc: 'teal', //lrc歌词颜色
    13.         c_time: 'teal', //时间信息颜色
    14.         c_track: '#eee', //进度轨线颜色
    15.         c_prg: 'red', //进度条颜色
    16.         c_circle: 'lightblue', //圆圈颜色
    17.         c_btn: 'snow', //按钮标识颜色
    18.         c_btnhover: 'pink', //按钮标识鼠标滑过颜色
    19.         lineLen: 200, //进度条长度
    20.         drawLrc: function(text) { //lrc同步
    21.                 ctx.clearRect(0, 0, w, 50);
    22.                 ctx.fillStyle = this.c_lrc;
    23.                 ctx.textAlign = 'center';
    24.                 ctx.beginPath();
    25.                 ctx.font = '1.2em sans-serif';
    26.                 ctx.fillText(text, w/2, 30);
    27.                 ctx.fill();
    28.         },
    29.         drawProgress: function(prog, text) { //进度
    30.                 ctx.clearRect(this.startX + this.radius, this.startY - 10, w - this.startX + this.radius, 40);
    31.                 ctx.beginPath();
    32.                 ctx.font = '14px sans-serif';
    33.                 ctx.textBaseline = 'middle';
    34.                 ctx.strokeStyle = this.c_track;
    35.                 ctx.moveTo(this.startX + this.radius + 4, this.startY);
    36.                 ctx.lineTo(this.startX + this.radius + 4 + this.lineLen, this.startY); //底线
    37.                 ctx.stroke();
    38.                 ctx.beginPath();
    39.                 ctx.strokeStyle = this.c_prg;
    40.                 ctx.moveTo(this.startX + this.radius + 4, this.startY);
    41.                 ctx.lineTo(this.startX + this.radius + 4 + prog, this.startY); //进度线
    42.                 ctx.stroke();
    43.                 ctx.fillStyle = this.c_time;
    44.                 ctx.textAlign = 'left';
    45.                 ctx.fillText(text, this.startX + this.radius + 8 + this.lineLen, this.startY); //数字进度
    46.                 ctx.fill();
    47.         },
    48.         drawBtn: function(id) { //绘制播放+暂停按钮
    49.                 ctx.clearRect(this.startX - this.radius, this.startY - this.radius, this.radius *2, this.radius*2);
    50.                 ctx.fillStyle = this.c_circle;
    51.                 ctx.beginPath();
    52.                 ctx.arc(this.startX, this.startY, this.radius, 0, 2*Math.PI);
    53.                 ctx.fill();
    54.                 ctx.fillStyle = flag ? this.c_btnhover : this.c_btn;
    55.                 ctx.beginPath();
    56.                 if (id) { //播放图标
    57.                         ctx.moveTo(this.startX - this.radius / 2 + 1, this.startY - this.radius / 2);
    58.                         ctx.lineTo(this.startX - this.radius / 2 + 1, this.startY + this.radius / 2);
    59.                         ctx.lineTo(this.startX + this.radius / 2 + 1, this.startY);
    60.                         ctx.fill();
    61.                 } else { //暂停图标
    62.                         ctx.fillRect(this.startX - this.radius / 2 + 5, this.startY - this.radius / 2, 2, this.radius);
    63.                         ctx.fillRect(this.startX - this.radius / 2 + 10, this.startY - this.radius / 2, 2, this.radius);
    64.                 }
    65.         },
    66.         isHover: function (x, y) {
    67.                 return Math.pow(x - this.startX, 2) + Math.pow(y - this.startY, 2) <= Math.pow(this.radius, 2);
    68.         },
    69. }
    70. let lrcAr = [
    71.         ['0.01','童安格  耶利亚女郎'],
    72.         ['34.10','很远的地方有个女郎  名字叫做耶利亚'],
    73.         ['42.33','有人在传说她的眼睛  看了使人更年轻'],
    74.         ['50.62','如果你得到她的拥抱  你就永远不会老'],
    75.         ['59.15','为了这个神奇的传说  我要努力去寻找'],
    76.         ['66.42','耶利亚神秘耶利亚  耶利耶利亚'],
    77.         ['74.77','耶利亚神秘耶利亚  我一定要找到她'],
    78.         ['101.12','很远的地方有个女郎  名字叫做耶利亚'],
    79.         ['109.32','有人在传说她的眼睛  看了使人更年轻'],
    80.         ['117.90','如果你得到她的拥抱  你就永远不会老'],
    81.         ['126.22','为了这个神奇的传说  我要努力去寻找'],
    82.         ['133.57','耶利亚神秘耶利亚  耶利耶利亚'],
    83.         ['141.90','耶利亚神秘耶利亚  我一定要找到她'],
    84.         ['150.29','耶利亚神秘耶利亚  耶利耶利亚'],
    85.         ['158.76','耶利亚神秘耶利亚  我一定要找到她'],
    86.         ['198.70','耶利亚神秘耶利亚  耶利耶利亚'],
    87.         ['207.11','耶利亚神秘耶利亚  我一定要找到她'],
    88.         ['215.28','耶利亚神秘耶利亚  耶利耶利亚'],
    89.         ['223.72','耶利亚神秘耶利亚  我一定要找到她']
    90. ];
    91. //audio控件设置
    92. aud.src = '耶利亚女郎.mp3';
    93. aud.autoplay = true;
    94. aud.loop = true;
    95. //初始化按钮
    96. mplayer.drawBtn(aud.paused);
    97. mplayer.drawProgress(1, '00:00 | 00:00');
    98. mplayer.drawLrc('等待播放 ...');
    99. //监听鼠标经过
    100. player.addEventListener('mousemove', (e) => {
    101.         flag = mplayer.isHover(e.offsetX, e.offsetY);
    102.         if (flag) {
    103.                 player.style.cursor = 'pointer';
    104.                 mplayer.drawBtn(aud.paused);
    105.         } else {
    106.                 player.style.cursor = 'default';
    107.                 mplayer.drawBtn(aud.paused);
    108.         }
    109. });
    110. player.addEventListener('click', (e) => { if(flag) aud.paused ? aud.play() : aud.pause(); }); //画布点击事件
    111. aud.addEventListener('playing', ()  => mplayer.drawBtn(false)); //监听播放状态
    112. aud.addEventListener('pause', ()  => mplayer.drawBtn(true)); //监听暂停状态
    113. //进度监听
    114. aud.addEventListener('timeupdate', () => {
    115.         let prg = mplayer.lineLen * aud.currentTime / aud.duration, tMsg = toMin(aud.duration) + ' | ' + toMin(aud.currentTime);
    116.         mplayer.drawProgress(prg, tMsg);
    117.         for(j = 0; j < lrcAr.length;  j ++) {
    118.                 if(aud.currentTime >= lrcAr[j][0]) mplayer.drawLrc(lrcAr[j][1]);
    119.         }
    120. });
    121. //格式化时间信息 → 00:00
    122. function toMin(val) {
    123.         if (!val) return '00:00';
    124.         val = Math.floor(val);
    125.         let min = parseInt(val / 60);
    126.         let sec = parseFloat(val % 60);
    127.         if(min < 10) min = '0' + min;
    128.         if(sec < 10) sec = '0' + sec;
    129.         return min + ':' + sec;
    130. }
    131. </script>
    复制代码
    播放器演示在二楼。

    评分

    参与人数 3威望 +130 金钱 +260 经验 +130 收起 理由
    加林森 + 30 + 60 + 30 很给力!
    红影 + 50 + 100 + 50 赞一个!
    小辣椒 + 50 + 100 + 50 赞一个!

    查看全部评分

  • TA的每日心情
    慵懒
    2025-12-16 08:52
  • 签到天数: 1671 天

    [LV.Master]伴坛终老

    3050

    主题

    13万

    回帖

    28万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮帅哥鼠牛虎兔龙蛇马羊猴鸡狗猪多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫相遇之美鹰傲苍穹花好月圆紫色情节飞龙在天王者至尊大将风范音画大师天籁妙音共看流星风雨同行我心永远幸福快乐喜乐安康侠骨柔肠心想事成开朗大方花潮管理

     楼主| 发表于 2022-8-26 12:55 | 显示全部楼层
    本帖最后由 马黑黑 于 2022-8-26 12:57 编辑

    评分

    参与人数 1威望 +50 金钱 +100 经验 +50 收起 理由
    小辣椒 + 50 + 100 + 50 很给力!

    查看全部评分

    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2025-12-16 08:52
  • 签到天数: 1671 天

    [LV.Master]伴坛终老

    3050

    主题

    13万

    回帖

    28万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮帅哥鼠牛虎兔龙蛇马羊猴鸡狗猪多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫相遇之美鹰傲苍穹花好月圆紫色情节飞龙在天王者至尊大将风范音画大师天籁妙音共看流星风雨同行我心永远幸福快乐喜乐安康侠骨柔肠心想事成开朗大方花潮管理

     楼主| 发表于 2022-8-26 13:11 | 显示全部楼层
    播放器总共有四个地方需要反复重绘:

    一、lrc歌词

    由audio控件的timeupdate监听事件驱动,每一句歌词,按currentTime步进刷新,每次刷新先区域性擦除再重绘。

    二和三、进度条和播放数字信息

    这两样何在一处处理,也是由 timeupdate 事件驱动,每次刷新所擦除的区域从圆形按钮之后到画布的最右边,擦除区域的高度在行内。

    四、播放暂停按钮

    有鼠标指针在画布上的移动事件驱动,每次刷新的擦除区域圆形自身区域。
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2019-11-25 21:11
  • 签到天数: 1 天

    [LV.1]初来乍到

    1421

    主题

    6万

    回帖

    12万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮美女多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫缤纷心情草莓情怀青草情怀蝴蝶情怀心曲飞扬星星情怀七彩绚丽活泼开朗女儿情怀男儿情怀鹰傲苍穹心香一瓣音画大师天籁妙音风雨同行我心永远喜乐安康中秋征文指尖上的流年花潮管理

    发表于 2022-8-26 15:01 | 显示全部楼层
    黒黑这个是播放器分享啊
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2019-11-25 21:11
  • 签到天数: 1 天

    [LV.1]初来乍到

    1421

    主题

    6万

    回帖

    12万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮美女多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫缤纷心情草莓情怀青草情怀蝴蝶情怀心曲飞扬星星情怀七彩绚丽活泼开朗女儿情怀男儿情怀鹰傲苍穹心香一瓣音画大师天籁妙音风雨同行我心永远喜乐安康中秋征文指尖上的流年花潮管理

    发表于 2022-8-26 15:03 | 显示全部楼层
    今天周末我可以玩的,黑黑辛苦又分享新的教程了
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2025-12-1 20:32
  • 签到天数: 1052 天

    [LV.10]以坛为家III

    1881

    主题

    32万

    回帖

    37万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮美女虎龙狗猪多彩人生星月交辉海样胸怀火热情怀优雅迷人神秘浪漫缤纷心情草莓情怀蝴蝶情怀心曲飞扬星星情怀七彩绚丽活泼开朗女儿情怀相遇之美一往情深花好月圆心香一瓣紫色情节飞龙在天金剪刀天籁妙音妙笔生花风雨同行我心永远天长地久幸福快乐绚丽缤纷喜乐安康中秋征文周年庆指尖上的流年舞会之星分析(喊冤)章总结章杀人王小强章最佳杀刺临屏写诗七夕诗钟活动第五届风云第六届风云情人节花潮管理

    发表于 2022-8-26 17:10 | 显示全部楼层
    这个好,把别的都拿掉了,单纯讲画布播放器。这个真不容易,所有的东东都是画出来的,厉害
     
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2025-12-16 08:52
  • 签到天数: 1671 天

    [LV.Master]伴坛终老

    3050

    主题

    13万

    回帖

    28万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮帅哥鼠牛虎兔龙蛇马羊猴鸡狗猪多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫相遇之美鹰傲苍穹花好月圆紫色情节飞龙在天王者至尊大将风范音画大师天籁妙音共看流星风雨同行我心永远幸福快乐喜乐安康侠骨柔肠心想事成开朗大方花潮管理

     楼主| 发表于 2022-8-26 19:21 | 显示全部楼层
    小辣椒 发表于 2022-8-26 15:01
    黒黑这个是播放器分享啊

    是的
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2025-12-16 08:52
  • 签到天数: 1671 天

    [LV.Master]伴坛终老

    3050

    主题

    13万

    回帖

    28万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮帅哥鼠牛虎兔龙蛇马羊猴鸡狗猪多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫相遇之美鹰傲苍穹花好月圆紫色情节飞龙在天王者至尊大将风范音画大师天籁妙音共看流星风雨同行我心永远幸福快乐喜乐安康侠骨柔肠心想事成开朗大方花潮管理

     楼主| 发表于 2022-8-26 19:22 | 显示全部楼层
    红影 发表于 2022-8-26 17:10
    这个好,把别的都拿掉了,单纯讲画布播放器。这个真不容易,所有的东东都是画出来的,厉害

    画布是一个不同寻常的画家
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2025-12-16 08:52
  • 签到天数: 1671 天

    [LV.Master]伴坛终老

    3050

    主题

    13万

    回帖

    28万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮帅哥鼠牛虎兔龙蛇马羊猴鸡狗猪多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫相遇之美鹰傲苍穹花好月圆紫色情节飞龙在天王者至尊大将风范音画大师天籁妙音共看流星风雨同行我心永远幸福快乐喜乐安康侠骨柔肠心想事成开朗大方花潮管理

     楼主| 发表于 2022-8-26 19:22 | 显示全部楼层
    小辣椒 发表于 2022-8-26 15:03
    今天周末我可以玩的,黑黑辛苦又分享新的教程了

    过一下子还有一个,在现在这个的基础上加入可控进度功能
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2025-12-1 20:32
  • 签到天数: 1052 天

    [LV.10]以坛为家III

    1881

    主题

    32万

    回帖

    37万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮美女虎龙狗猪多彩人生星月交辉海样胸怀火热情怀优雅迷人神秘浪漫缤纷心情草莓情怀蝴蝶情怀心曲飞扬星星情怀七彩绚丽活泼开朗女儿情怀相遇之美一往情深花好月圆心香一瓣紫色情节飞龙在天金剪刀天籁妙音妙笔生花风雨同行我心永远天长地久幸福快乐绚丽缤纷喜乐安康中秋征文周年庆指尖上的流年舞会之星分析(喊冤)章总结章杀人王小强章最佳杀刺临屏写诗七夕诗钟活动第五届风云第六届风云情人节花潮管理

    发表于 2022-8-26 20:19 | 显示全部楼层
    马黑黑 发表于 2022-8-26 19:22
    画布是一个不同寻常的画家

    黑黑才是最出类拔萃的画家呢
     
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2025-12-16 08:52
  • 签到天数: 1671 天

    [LV.Master]伴坛终老

    3050

    主题

    13万

    回帖

    28万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮帅哥鼠牛虎兔龙蛇马羊猴鸡狗猪多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫相遇之美鹰傲苍穹花好月圆紫色情节飞龙在天王者至尊大将风范音画大师天籁妙音共看流星风雨同行我心永远幸福快乐喜乐安康侠骨柔肠心想事成开朗大方花潮管理

     楼主| 发表于 2022-8-26 20:20 | 显示全部楼层
    红影 发表于 2022-8-26 20:19
    黑黑才是最出类拔萃的画家呢

    我画盲
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2019-11-25 21:11
  • 签到天数: 1 天

    [LV.1]初来乍到

    1421

    主题

    6万

    回帖

    12万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮美女多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫缤纷心情草莓情怀青草情怀蝴蝶情怀心曲飞扬星星情怀七彩绚丽活泼开朗女儿情怀男儿情怀鹰傲苍穹心香一瓣音画大师天籁妙音风雨同行我心永远喜乐安康中秋征文指尖上的流年花潮管理

    发表于 2022-8-26 20:46 | 显示全部楼层
    马黑黑 发表于 2022-8-26 19:22
    过一下子还有一个,在现在这个的基础上加入可控进度功能

    是今天吗
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2025-12-16 08:52
  • 签到天数: 1671 天

    [LV.Master]伴坛终老

    3050

    主题

    13万

    回帖

    28万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮帅哥鼠牛虎兔龙蛇马羊猴鸡狗猪多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫相遇之美鹰傲苍穹花好月圆紫色情节飞龙在天王者至尊大将风范音画大师天籁妙音共看流星风雨同行我心永远幸福快乐喜乐安康侠骨柔肠心想事成开朗大方花潮管理

     楼主| 发表于 2022-8-26 21:15 | 显示全部楼层
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2025-12-1 20:32
  • 签到天数: 1052 天

    [LV.10]以坛为家III

    1881

    主题

    32万

    回帖

    37万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮美女虎龙狗猪多彩人生星月交辉海样胸怀火热情怀优雅迷人神秘浪漫缤纷心情草莓情怀蝴蝶情怀心曲飞扬星星情怀七彩绚丽活泼开朗女儿情怀相遇之美一往情深花好月圆心香一瓣紫色情节飞龙在天金剪刀天籁妙音妙笔生花风雨同行我心永远天长地久幸福快乐绚丽缤纷喜乐安康中秋征文周年庆指尖上的流年舞会之星分析(喊冤)章总结章杀人王小强章最佳杀刺临屏写诗七夕诗钟活动第五届风云第六届风云情人节花潮管理

    发表于 2022-8-27 19:38 | 显示全部楼层

    你可以用代码画的呢,在画布上描绘所有的梦
     
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2025-12-16 08:52
  • 签到天数: 1671 天

    [LV.Master]伴坛终老

    3050

    主题

    13万

    回帖

    28万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮帅哥鼠牛虎兔龙蛇马羊猴鸡狗猪多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫相遇之美鹰傲苍穹花好月圆紫色情节飞龙在天王者至尊大将风范音画大师天籁妙音共看流星风雨同行我心永远幸福快乐喜乐安康侠骨柔肠心想事成开朗大方花潮管理

     楼主| 发表于 2022-8-27 20:20 | 显示全部楼层
    红影 发表于 2022-8-27 19:38
    你可以用代码画的呢,在画布上描绘所有的梦

    没那么夸张
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2025-12-1 20:32
  • 签到天数: 1052 天

    [LV.10]以坛为家III

    1881

    主题

    32万

    回帖

    37万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮美女虎龙狗猪多彩人生星月交辉海样胸怀火热情怀优雅迷人神秘浪漫缤纷心情草莓情怀蝴蝶情怀心曲飞扬星星情怀七彩绚丽活泼开朗女儿情怀相遇之美一往情深花好月圆心香一瓣紫色情节飞龙在天金剪刀天籁妙音妙笔生花风雨同行我心永远天长地久幸福快乐绚丽缤纷喜乐安康中秋征文周年庆指尖上的流年舞会之星分析(喊冤)章总结章杀人王小强章最佳杀刺临屏写诗七夕诗钟活动第五届风云第六届风云情人节花潮管理

    发表于 2022-8-27 20:49 | 显示全部楼层

    反正我在心目中你无所不能
     
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2025-12-16 08:52
  • 签到天数: 1671 天

    [LV.Master]伴坛终老

    3050

    主题

    13万

    回帖

    28万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮帅哥鼠牛虎兔龙蛇马羊猴鸡狗猪多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫相遇之美鹰傲苍穹花好月圆紫色情节飞龙在天王者至尊大将风范音画大师天籁妙音共看流星风雨同行我心永远幸福快乐喜乐安康侠骨柔肠心想事成开朗大方花潮管理

     楼主| 发表于 2022-8-27 21:15 | 显示全部楼层
    红影 发表于 2022-8-27 20:49
    反正我在心目中你无所不能

    这是少见多怪的原因
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2025-12-1 20:32
  • 签到天数: 1052 天

    [LV.10]以坛为家III

    1881

    主题

    32万

    回帖

    37万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮美女虎龙狗猪多彩人生星月交辉海样胸怀火热情怀优雅迷人神秘浪漫缤纷心情草莓情怀蝴蝶情怀心曲飞扬星星情怀七彩绚丽活泼开朗女儿情怀相遇之美一往情深花好月圆心香一瓣紫色情节飞龙在天金剪刀天籁妙音妙笔生花风雨同行我心永远天长地久幸福快乐绚丽缤纷喜乐安康中秋征文周年庆指尖上的流年舞会之星分析(喊冤)章总结章杀人王小强章最佳杀刺临屏写诗七夕诗钟活动第五届风云第六届风云情人节花潮管理

    发表于 2022-8-28 11:02 | 显示全部楼层
    马黑黑 发表于 2022-8-27 21:15
    这是少见多怪的原因

    论坛里就你一个会代码的,你是孤勇者
     
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2025-12-16 08:52
  • 签到天数: 1671 天

    [LV.Master]伴坛终老

    3050

    主题

    13万

    回帖

    28万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮帅哥鼠牛虎兔龙蛇马羊猴鸡狗猪多彩人生星月交辉奔放热烈海样胸怀春风拂面火热情怀优雅迷人神秘浪漫相遇之美鹰傲苍穹花好月圆紫色情节飞龙在天王者至尊大将风范音画大师天籁妙音共看流星风雨同行我心永远幸福快乐喜乐安康侠骨柔肠心想事成开朗大方花潮管理

     楼主| 发表于 2022-8-28 11:07 | 显示全部楼层
    红影 发表于 2022-8-28 11:02
    论坛里就你一个会代码的,你是孤勇者

    不是的。会代码的人,根据观察,有一些的
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2025-12-1 20:32
  • 签到天数: 1052 天

    [LV.10]以坛为家III

    1881

    主题

    32万

    回帖

    37万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9Rank: 9

    花潮美女虎龙狗猪多彩人生星月交辉海样胸怀火热情怀优雅迷人神秘浪漫缤纷心情草莓情怀蝴蝶情怀心曲飞扬星星情怀七彩绚丽活泼开朗女儿情怀相遇之美一往情深花好月圆心香一瓣紫色情节飞龙在天金剪刀天籁妙音妙笔生花风雨同行我心永远天长地久幸福快乐绚丽缤纷喜乐安康中秋征文周年庆指尖上的流年舞会之星分析(喊冤)章总结章杀人王小强章最佳杀刺临屏写诗七夕诗钟活动第五届风云第六届风云情人节花潮管理

    发表于 2022-8-28 13:58 | 显示全部楼层
    马黑黑 发表于 2022-8-28 11:07
    不是的。会代码的人,根据观察,有一些的

    哦哦,反正我知道的就你一个
     
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    小黑屋|手机版|Archiver|服务支持:DZ动力|huachaowang.com Inc. ( 蜀ICP备17032287号-1 )

    GMT+8, 2025-12-16 21:46 , Processed in 0.101197 second(s), 26 queries .

    Powered by Discuz! X3.4

    © 2001-2013 Comsenz Inc.

    快速回复 返回顶部 返回列表