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

播放音频文件同步音频文本

播放音频同步音频文本 对应单个文本高亮显示
使用audio

音频文件对应音频文本资源

请添加图片描述

音频文本内容(Json)


    [
        {
            "end": 4875,
            "index": 0,
            "speaker": 0,
            "start": 30,
            "text": "70号二啊,",
            "text_length": 5
        },
        {
            "end": 40275,
            "index": 1,
            "speaker": 0,
            "start": 5980,
            "text": "这个你能不能宝宝听不懂本身百分他们你好,",
            "text_length": 19
        },
        {
            "end": 17110,
            "index": 2,
            "speaker": 1,
            "start": 16490,
            "text": "菜办好了,",
            "text_length": 4
        },
        {
            "end": 24790,
            "index": 3,
            "speaker": 1,
            "start": 17110,
            "text": "马上回你大学的没有,",
            "text_length": 9
        },
        {
            "end": 37500,
            "index": 4,
            "speaker": 1,
            "start": 24790,
            "text": "你没有啊,",
            "text_length": 4
        },
        {
            "end": 40950,
            "index": 5,
            "speaker": 0,
            "start": 40809,
            "text": "对,",
            "text_length": 1
        },
        {
            "end": 41225,
            "index": 6,
            "speaker": 0,
            "start": 40950,
            "text": "好的,",
            "text_length": 2
        },
        {
            "end": 44555,
            "index": 7,
            "speaker": 0,
            "start": 43830,
            "text": "还有什么呢?",
            "text_length": 5
        },
        {
            "end": 51175,
            "index": 8,
            "speaker": 0,
            "start": 48820,
            "text": "但是我过来帮你找,",
            "text_length": 8
        },
        {
            "end": 52305,
            "index": 9,
            "speaker": 0,
            "start": 51590,
            "text": "欢迎大家啊,",
            "text_length": 5
        },
        {
            "end": 58815,
            "index": 10,
            "speaker": 0,
            "start": 55400,
            "text": "什么司机司机用车,",
            "text_length": 8
        },
        {
            "end": 65840,
            "index": 11,
            "speaker": 0,
            "start": 60640,
            "text": "然后太好了,",
            "text_length": 5
        },
        {
            "end": 69865,
            "index": 12,
            "speaker": 1,
            "start": 66390,
            "text": "你说我好了吗?",
            "text_length": 6
        },
        {
            "end": 71505,
            "index": 13,
            "speaker": 0,
            "start": 70909,
            "text": "我拖一下。",
            "text_length": 4
        },
        {
            "end": 127095,
            "index": 14,
            "speaker": 0,
            "start": 73180,
            "text": "那这个还有那我们啊啊开车写一个您的手机号码,",
            "text_length": 21
        },
        {
            "end": 82845,
            "index": 15,
            "speaker": 1,
            "start": 82490,
            "text": "呃,",
            "text_length": 1
        },
        {
            "end": 89745,
            "index": 16,
            "speaker": 1,
            "start": 88030,
            "text": "等一下啊,",
            "text_length": 4
        },
        {
            "end": 93375,
            "index": 17,
            "speaker": 1,
            "start": 91969,
            "text": "你什么人啊,",
            "text_length": 5
        },
        {
            "end": 136495,
            "index": 18,
            "speaker": 1,
            "start": 106060,
            "text": "那个啊嗯怎么了?",
            "text_length": 7
        },
        {
            "end": 138300,
            "index": 19,
            "speaker": 0,
            "start": 129340,
            "text": "这个好吧,",
            "text_length": 4
        },
        {
            "end": 161295,
            "index": 20,
            "speaker": 0,
            "start": 151790,
            "text": "这个什么你刚才啊你好,",
            "text_length": 10
        },
        {
            "end": 173709,
            "index": 21,
            "speaker": 0,
            "start": 161870,
            "text": "然后我一个人这个房子是邓静林一个人的名字,",
            "text_length": 20
        },
        {
            "end": 174165,
            "index": 22,
            "speaker": 0,
            "start": 173709,
            "text": "对吧?",
            "text_length": 2
        },
        {
            "end": 198590,
            "index": 23,
            "speaker": 1,
            "start": 174379,
            "text": "这个就是是呃第一段话把它抄下来嘛,",
            "text_length": 16
        },
        {
            "end": 175530,
            "index": 24,
            "speaker": 0,
            "start": 175120,
            "text": "对了,",
            "text_length": 2
        },
        {
            "end": 180830,
            "index": 25,
            "speaker": 0,
            "start": 179870,
            "text": "第一句话,",
            "text_length": 4
        },
        {
            "end": 182230,
            "index": 26,
            "speaker": 0,
            "start": 180830,
            "text": "本不动产属于姓名,",
            "text_length": 8
        },
        {
            "end": 183190,
            "index": 27,
            "speaker": 0,
            "start": 182230,
            "text": "改成你的名字,",
            "text_length": 6
        },
        {
            "end": 185970,
            "index": 28,
            "speaker": 0,
            "start": 183190,
            "text": "单独所有无其他所有人抄在这个地方,",
            "text_length": 16
        },
        {
            "end": 192260,
            "index": 29,
            "speaker": 0,
            "start": 185970,
            "text": "然后这里签名写日期高底,",
            "text_length": 11
        },
        {
            "end": 200100,
            "index": 30,
            "speaker": 0,
            "start": 194370,
            "text": "接下来在吗?",
            "text_length": 5
        },
        {
            "end": 199530,
            "index": 31,
            "speaker": 1,
            "start": 198590,
            "text": "写自己名字吧,",
            "text_length": 6
        },
        {
            "end": 203590,
            "index": 32,
            "speaker": 1,
            "start": 199530,
            "text": "由其他部门嗯在这个位置吧,",
            "text_length": 12
        },
        {
            "end": 201680,
            "index": 33,
            "speaker": 0,
            "start": 201280,
            "text": "对,",
            "text_length": 1
        },
        {
            "end": 202000,
            "index": 34,
            "speaker": 0,
            "start": 201680,
            "text": "是的,",
            "text_length": 2
        },
        {
            "end": 204210,
            "index": 35,
            "speaker": 0,
            "start": 202000,
            "text": "就把它抄这里姓名,",
            "text_length": 8
        },
        {
            "end": 203985,
            "index": 36,
            "speaker": 1,
            "start": 203590,
            "text": "是吧?",
            "text_length": 2
        },
        {
            "end": 206150,
            "index": 37,
            "speaker": 0,
            "start": 204210,
            "text": "改成你的名字啊。",
            "text_length": 7
        },
        {
            "end": 206495,
            "index": 38,
            "speaker": 0,
            "start": 206150,
            "text": "对呀,",
            "text_length": 2
        },
        {
            "end": 220555,
            "index": 39,
            "speaker": 0,
            "start": 210320,
            "text": "领导说为什么?",
            "text_length": 6
        },
        {
            "end": 235625,
            "index": 40,
            "speaker": 1,
            "start": 219380,
            "text": "因为人没有好吧,",
            "text_length": 7
        },
        {
            "end": 250970,
            "index": 41,
            "speaker": 0,
            "start": 227879,
            "text": "那么这加的话可以随时过来加,",
            "text_length": 13
        },
        {
            "end": 248390,
            "index": 42,
            "speaker": 1,
            "start": 247130,
            "text": "老公是可以的噻,",
            "text_length": 7
        },
        {
            "end": 257535,
            "index": 43,
            "speaker": 1,
            "start": 248390,
            "text": "要是以后加的话哦,",
            "text_length": 8
        },
        {
            "end": 252430,
            "index": 44,
            "speaker": 0,
            "start": 250970,
            "text": "只要房子没有贷款,",
            "text_length": 8
        },
        {
            "end": 256765,
            "index": 45,
            "speaker": 0,
            "start": 252490,
            "text": "两个人来一次把结婚证身份证和房证带上啊10块钱的费用,",
            "text_length": 26
        },
        {
            "end": 266880,
            "index": 46,
            "speaker": 0,
            "start": 262380,
            "text": "不看不对,",
            "text_length": 4
        },
        {
            "end": 266645,
            "index": 47,
            "speaker": 1,
            "start": 264890,
            "text": "年月日和新命是吧,",
            "text_length": 8
        },
        {
            "end": 294080,
            "index": 48,
            "speaker": 0,
            "start": 266880,
            "text": "签字写今天日期这个肯定是您本人的。",
            "text_length": 16
        },
        {
            "end": 273135,
            "index": 49,
            "speaker": 1,
            "start": 268790,
            "text": "26号21年12月。",
            "text_length": 9
        },
        {
            "end": 294515,
            "index": 50,
            "speaker": 1,
            "start": 294210,
            "text": "对,",
            "text_length": 1
        },
        {
            "end": 298600,
            "index": 51,
            "speaker": 0,
            "start": 297060,
            "text": "然后现在是已婚有配偶,",
            "text_length": 10
        },
        {
            "end": 299340,
            "index": 52,
            "speaker": 0,
            "start": 298600,
            "text": "对吧?",
            "text_length": 2
        },
        {
            "end": 305030,
            "index": 53,
            "speaker": 1,
            "start": 299130,
            "text": "没有哦,",
            "text_length": 3
        },
        {
            "end": 301840,
            "index": 54,
            "speaker": 0,
            "start": 299520,
            "text": "这里把配偶两个字写在这个地方,",
            "text_length": 14
        },
        {
            "end": 302620,
            "index": 55,
            "speaker": 0,
            "start": 301840,
            "text": "你爱人的名字,",
            "text_length": 6
        },
        {
            "end": 304780,
            "index": 56,
            "speaker": 0,
            "start": 302620,
            "text": "证件号写一下3个,",
            "text_length": 8
        },
        {
            "end": 306250,
            "index": 57,
            "speaker": 1,
            "start": 305030,
            "text": "身份证号码是吧,",
            "text_length": 7
        },
        {
            "end": 307875,
            "index": 58,
            "speaker": 0,
            "start": 305960,
            "text": "但是让他到我修改,",
            "text_length": 8
        },
        {
            "end": 311055,
            "index": 59,
            "speaker": 1,
            "start": 306250,
            "text": "联系人嗯,",
            "text_length": 4
        },
        {
            "end": 308780,
            "index": 60,
            "speaker": 0,
            "start": 308639,
            "text": "对,",
            "text_length": 1
        },
        {
            "end": 310720,
            "index": 61,
            "speaker": 0,
            "start": 308780,
            "text": "把他的信息要补上去,",
            "text_length": 9
        },
        {
            "end": 312199,
            "index": 62,
            "speaker": 0,
            "start": 310800,
            "text": "就是写在这里。",
            "text_length": 6
        },
        {
            "end": 313139,
            "index": 63,
            "speaker": 0,
            "start": 312220,
            "text": "这里写配偶,",
            "text_length": 5
        },
        {
            "end": 314120,
            "index": 64,
            "speaker": 0,
            "start": 313139,
            "text": "你爱人的名字,",
            "text_length": 6
        },
        {
            "end": 315725,
            "index": 65,
            "speaker": 0,
            "start": 314120,
            "text": "他的身份证号码写一下,",
            "text_length": 10
        },
        {
            "end": 319055,
            "index": 66,
            "speaker": 1,
            "start": 317180,
            "text": "这你就写配偶两个字是吧,",
            "text_length": 11
        },
        {
            "end": 319995,
            "index": 67,
            "speaker": 0,
            "start": 319060,
            "text": "这个你写呀,",
            "text_length": 5
        },
        {
            "end": 320410,
            "index": 68,
            "speaker": 1,
            "start": 319990,
            "text": "有,",
            "text_length": 1
        },
        {
            "end": 321470,
            "index": 69,
            "speaker": 1,
            "start": 320410,
            "text": "这是老公的姓名,",
            "text_length": 7
        },
        {
            "end": 325860,
            "index": 70,
            "speaker": 1,
            "start": 321470,
            "text": "身份证电话号码是吧啊,",
            "text_length": 10
        },
        {
            "end": 323750,
            "index": 71,
            "speaker": 0,
            "start": 322690,
            "text": "电话就不用写,",
            "text_length": 6
        },
        {
            "end": 326075,
            "index": 72,
            "speaker": 0,
            "start": 323750,
            "text": "你只用写我说的那几个地方就可以了。",
            "text_length": 16
        },
        {
            "end": 330865,
            "index": 73,
            "speaker": 1,
            "start": 325860,
            "text": "好的啊,",
            "text_length": 3
        },
        {
            "end": 337160,
            "index": 74,
            "speaker": 0,
            "start": 333010,
            "text": "可千的70晚上照到700000上照清楚,",
            "text_length": 19
        },
        {
            "end": 343700,
            "index": 75,
            "speaker": 0,
            "start": 337160,
            "text": "然后他帮我还来找我的那如果说喂,",
            "text_length": 15
        },
        {
            "end": 358925,
            "index": 76,
            "speaker": 0,
            "start": 343700,
            "text": "你们就看这个注意延迟啊,",
            "text_length": 11
        },
        {
            "end": 350145,
            "index": 77,
            "speaker": 1,
            "start": 348840,
            "text": "看一下有没有身份证。",
            "text_length": 9
        },
        {
            "end": 368005,
            "index": 78,
            "speaker": 1,
            "start": 356699,
            "text": "对对对啊,",
            "text_length": 4
        },
        {
            "end": 402785,
            "index": 79,
            "speaker": 0,
            "start": 360320,
            "text": "嗯不知道猪蹄子那走没有就没有你最怕这个大概他们都什么意思?",
            "text_length": 28
        },
        {
            "end": 389160,
            "index": 80,
            "speaker": 1,
            "start": 373680,
            "text": "感谢啊,",
            "text_length": 3
        },
        {
            "end": 406975,
            "index": 81,
            "speaker": 0,
            "start": 405569,
            "text": "这是你们主的权利。",
            "text_length": 8
        },
        {
            "end": 408150,
            "index": 82,
            "speaker": 0,
            "start": 407850,
            "text": "好,",
            "text_length": 1
        },
        {
            "end": 408365,
            "index": 83,
            "speaker": 0,
            "start": 408150,
            "text": "一,",
            "text_length": 1
        },
        {
            "end": 409139,
            "index": 84,
            "speaker": 0,
            "start": 408780,
            "text": "我给你,",
            "text_length": 3
        },
        {
            "end": 409580,
            "index": 85,
            "speaker": 0,
            "start": 409139,
            "text": "你发你的,",
            "text_length": 4
        },
        {
            "end": 410145,
            "index": 86,
            "speaker": 0,
            "start": 409580,
            "text": "你看到吗?",
            "text_length": 4
        },
        {
            "end": 414260,
            "index": 87,
            "speaker": 0,
            "start": 411040,
            "text": "今天啊今天努力拿完了呃,",
            "text_length": 11
        },
        {
            "end": 431675,
            "index": 88,
            "speaker": 1,
            "start": 413590,
            "text": "我想他们你的心。",
            "text_length": 7
        },
        {
            "end": 414800,
            "index": 89,
            "speaker": 0,
            "start": 414260,
            "text": "那个女生,",
            "text_length": 4
        },
        {
            "end": 415165,
            "index": 90,
            "speaker": 0,
            "start": 414800,
            "text": "对呀,",
            "text_length": 2
        },
        {
            "end": 416890,
            "index": 91,
            "speaker": 0,
            "start": 415850,
            "text": "这是什么?",
            "text_length": 4
        },
        {
            "end": 417520,
            "index": 92,
            "speaker": 0,
            "start": 416930,
            "text": "然后呢,",
            "text_length": 3
        },
        {
            "end": 420610,
            "index": 93,
            "speaker": 0,
            "start": 418820,
            "text": "我要给你们可以写的,",
            "text_length": 9
        },
        {
            "end": 421855,
            "index": 94,
            "speaker": 0,
            "start": 420610,
            "text": "你能告诉他们,",
            "text_length": 6
        },
        {
            "end": 423450,
            "index": 95,
            "speaker": 0,
            "start": 423090,
            "text": "嗯,",
            "text_length": 1
        },
        {
            "end": 425465,
            "index": 96,
            "speaker": 0,
            "start": 423450,
            "text": "因为呢不一样,",
            "text_length": 6
        },
        {
            "end": 435535,
            "index": 97,
            "speaker": 0,
            "start": 434660,
            "text": "对不对?",
            "text_length": 3
        },
        {
            "end": 437070,
            "index": 98,
            "speaker": 0,
            "start": 436410,
            "text": "哎呀,",
            "text_length": 2
        },
        {
            "end": 438425,
            "index": 99,
            "speaker": 0,
            "start": 437070,
            "text": "今天想走啊,",
            "text_length": 5
        },
        {
            "end": 444520,
            "index": 100,
            "speaker": 0,
            "start": 443919,
            "text": "找清楚,",
            "text_length": 3
        },
        {
            "end": 450280,
            "index": 101,
            "speaker": 0,
            "start": 444520,
            "text": "他清楚不好找60,",
            "text_length": 8
        },
        {
            "end": 455264,
            "index": 102,
            "speaker": 0,
            "start": 451870,
            "text": "应该呀他的续航大概在333左右,",
            "text_length": 15
        },
        {
            "end": 460224,
            "index": 103,
            "speaker": 0,
            "start": 456640,
            "text": "看到能够大概在这个333左右的样子,",
            "text_length": 17
        },
        {
            "end": 462730,
            "index": 104,
            "speaker": 0,
            "start": 461850,
            "text": "有真的吗?",
            "text_length": 4
        },
        {
            "end": 462930,
            "index": 105,
            "speaker": 0,
            "start": 462730,
            "text": "啊,",
            "text_length": 1
        },
        {
            "end": 464210,
            "index": 106,
            "speaker": 0,
            "start": 462930,
            "text": "我单挑看来,",
            "text_length": 5
        },
        {
            "end": 465975,
            "index": 107,
            "speaker": 0,
            "start": 464210,
            "text": "因为他也是乱的,",
            "text_length": 7
        },
        {
            "end": 472740,
            "index": 108,
            "speaker": 0,
            "start": 467170,
            "text": "有能333都有35栋一单元五。",
            "text_length": 14
        },
        {
            "end": 474890,
            "index": 109,
            "speaker": 0,
            "start": 474390,
            "text": "小金子,",
            "text_length": 3
        },
        {
            "end": 478890,
            "index": 110,
            "speaker": 0,
            "start": 474890,
            "text": "我找到了这个,",
            "text_length": 6
        },
        {
            "end": 479795,
            "index": 111,
            "speaker": 1,
            "start": 478640,
            "text": "然后你们呢,",
            "text_length": 5
        },
        {
            "end": 491615,
            "index": 112,
            "speaker": 0,
            "start": 478890,
            "text": "就那我我真的有一个表在表上面照起来。",
            "text_length": 17
        },
        {
            "end": 495805,
            "index": 113,
            "speaker": 0,
            "start": 494220,
            "text": "那他还有找,",
            "text_length": 5
        },
        {
            "end": 496710,
            "index": 114,
            "speaker": 1,
            "start": 495450,
            "text": "那我找身份证号码,",
            "text_length": 8
        },
        {
            "end": 500840,
            "index": 115,
            "speaker": 1,
            "start": 496710,
            "text": "我没有我老公的身打他,",
            "text_length": 10
        },
        {
            "end": 499870,
            "index": 116,
            "speaker": 0,
            "start": 497970,
            "text": "那你能不能跟你爱爱人打个电话,",
            "text_length": 14
        },
        {
            "end": 507660,
            "index": 117,
            "speaker": 0,
            "start": 499870,
            "text": "直接问他类似没啥吃,",
            "text_length": 9
        },
        {
            "end": 502365,
            "index": 118,
            "speaker": 1,
            "start": 500920,
            "text": "我打他他没接,",
            "text_length": 6
        },
        {
            "end": 512825,
            "index": 119,
            "speaker": 1,
            "start": 507950,
            "text": "不晓得有啊。",
            "text_length": 5
        },
        {
            "end": 523570,
            "index": 120,
            "speaker": 0,
            "start": 508940,
            "text": "有没有未成年的小孩孩子吧,",
            "text_length": 12
        },
        {
            "end": 516045,
            "index": 121,
            "speaker": 1,
            "start": 513840,
            "text": "我们家有两个小孩都未成年,",
            "text_length": 12
        },
        {
            "end": 517450,
            "index": 122,
            "speaker": 1,
            "start": 516830,
            "text": "这3岁,",
            "text_length": 3
        },
        {
            "end": 519785,
            "index": 123,
            "speaker": 1,
            "start": 517450,
            "text": "一个一个1023岁,",
            "text_length": 9
        },
        {
            "end": 526270,
            "index": 124,
            "speaker": 0,
            "start": 523570,
            "text": "去找一下你孩子写你小孩孩的信息,",
            "text_length": 15
        },
        {
            "end": 527790,
            "index": 125,
            "speaker": 0,
            "start": 526530,
            "text": "不用写你爱人的信息了,",
            "text_length": 10
        },
        {
            "end": 528815,
            "index": 126,
            "speaker": 0,
            "start": 527790,
            "text": "不用提出来了。",
            "text_length": 6
        },
        {
            "end": 529510,
            "index": 127,
            "speaker": 1,
            "start": 528610,
            "text": "那就学校学,",
            "text_length": 5
        },
        {
            "end": 532089,
            "index": 128,
            "speaker": 1,
            "start": 529510,
            "text": "我小孩的没有,",
            "text_length": 6
        },
        {
            "end": 532279,
            "index": 129,
            "speaker": 0,
            "start": 532050,
            "text": "嗯,",
            "text_length": 1
        },
        {
            "end": 533690,
            "index": 130,
            "speaker": 1,
            "start": 532470,
            "text": "他才10几岁了,",
            "text_length": 7
        },
        {
            "end": 534810,
            "index": 131,
            "speaker": 1,
            "start": 533690,
            "text": "有已经3岁,",
            "text_length": 5
        },
        {
            "end": 535845,
            "index": 132,
            "speaker": 0,
            "start": 534230,
            "text": "不是七,",
            "text_length": 3
        },
        {
            "end": 536345,
            "index": 133,
            "speaker": 1,
            "start": 534810,
            "text": "也就1012岁。",
            "text_length": 7
        },
        {
            "end": 537839,
            "index": 134,
            "speaker": 0,
            "start": 536480,
            "text": "那也是啊呃,",
            "text_length": 5
        },
        {
            "end": 541500,
            "index": 135,
            "speaker": 0,
            "start": 537839,
            "text": "是直接拍不写了,",
            "text_length": 7
        },
        {
            "end": 541865,
            "index": 136,
            "speaker": 0,
            "start": 541500,
            "text": "不写了,",
            "text_length": 3
        },
        {
            "end": 561225,
            "index": 137,
            "speaker": 0,
            "start": 545740,
            "text": "除了你这来重新拿一下这个手机台钱,",
            "text_length": 16
        },
        {
            "end": 585125,
            "index": 138,
            "speaker": 1,
            "start": 556550,
            "text": "稍等你说最后一个,",
            "text_length": 8
        },
        {
            "end": 569185,
            "index": 139,
            "speaker": 0,
            "start": 566090,
            "text": "没想到这个什么,",
            "text_length": 7
        },
        {
            "end": 581310,
            "index": 140,
            "speaker": 0,
            "start": 574990,
            "text": "我在4541205412哦,",
            "text_length": 13
        },
        {
            "end": 582445,
            "index": 141,
            "speaker": 0,
            "start": 581310,
            "text": "你不要几个案件吗?",
            "text_length": 8
        },
        {
            "end": 591699,
            "index": 142,
            "speaker": 0,
            "start": 585920,
            "text": "12个还有嗯,",
            "text_length": 6
        },
        {
            "end": 591310,
            "index": 143,
            "speaker": 1,
            "start": 590949,
            "text": "嗯,",
            "text_length": 1
        },
        {
            "end": 591730,
            "index": 144,
            "speaker": 1,
            "start": 591310,
            "text": "那没事,",
            "text_length": 3
        },
        {
            "end": 592399,
            "index": 145,
            "speaker": 1,
            "start": 591730,
            "text": "好吧。",
            "text_length": 2
        },
        {
            "end": 593695,
            "index": 146,
            "speaker": 0,
            "start": 593050,
            "text": "我还没写完,",
            "text_length": 5
        },
        {
            "end": 602735,
            "index": 147,
            "speaker": 0,
            "start": 602180,
            "text": "220,",
            "text_length": 3
        },
        {
            "end": 612115,
            "index": 148,
            "speaker": 0,
            "start": 603270,
            "text": "我自己的你好友进来了,",
            "text_length": 10
        },
        {
            "end": 632275,
            "index": 149,
            "speaker": 1,
            "start": 610760,
            "text": "好嗯,",
            "text_length": 2
        },
        {
            "end": 617130,
            "index": 150,
            "speaker": 0,
            "start": 614589,
            "text": "根本就没是黄色。",
            "text_length": 7
        },
        {
            "end": 632365,
            "index": 151,
            "speaker": 0,
            "start": 623630,
            "text": "我他你嗯怎么了?",
            "text_length": 7
        },
        {
            "end": 637420,
            "index": 152,
            "speaker": 1,
            "start": 636579,
            "text": "在哪里?",
            "text_length": 3
        },
        {
            "end": 638595,
            "index": 153,
            "speaker": 1,
            "start": 637420,
            "text": "我有有喝啊,",
            "text_length": 5
        },
        {
            "end": 638540,
            "index": 154,
            "speaker": 0,
            "start": 637530,
            "text": "加上啊,",
            "text_length": 3
        },
        {
            "end": 648975,
            "index": 155,
            "speaker": 0,
            "start": 638540,
            "text": "为什么没有我们嗯,",
            "text_length": 8
        },
        {
            "end": 640710,
            "index": 156,
            "speaker": 1,
            "start": 639370,
            "text": "不晓得是不二11啊,",
            "text_length": 9
        },
        {
            "end": 651550,
            "index": 157,
            "speaker": 1,
            "start": 640710,
            "text": "我跟四季永新五栋一单元有有有嗯,",
            "text_length": 15
        },
        {
            "end": 653845,
            "index": 158,
            "speaker": 0,
            "start": 650700,
            "text": "请重这个,",
            "text_length": 4
        },
        {
            "end": 651945,
            "index": 159,
            "speaker": 1,
            "start": 651550,
            "text": "嗯,",
            "text_length": 1
        },
        {
            "end": 654395,
            "index": 160,
            "speaker": 1,
            "start": 653650,
            "text": "这个没问题,",
            "text_length": 5
        },
        {
            "end": 658654,
            "index": 161,
            "speaker": 0,
            "start": 654360,
            "text": "还有你好好是你们吗?",
            "text_length": 9
        },
        {
            "end": 660995,
            "index": 162,
            "speaker": 1,
            "start": 658460,
            "text": "我那个不对,",
            "text_length": 5
        },
        {
            "end": 664530,
            "index": 163,
            "speaker": 0,
            "start": 661680,
            "text": "小朋友看看很重要,",
            "text_length": 8
        },
        {
            "end": 673699,
            "index": 164,
            "speaker": 0,
            "start": 664530,
            "text": "说什么这里是没有,",
            "text_length": 8
        },
        {
            "end": 671720,
            "index": 165,
            "speaker": 1,
            "start": 671260,
            "text": "在一样,",
            "text_length": 3
        },
        {
            "end": 673500,
            "index": 166,
            "speaker": 1,
            "start": 671720,
            "text": "没有来了。",
            "text_length": 4
        },
        {
            "end": 686830,
            "index": 167,
            "speaker": 1,
            "start": 673500,
            "text": "宝贝嗯啊嗯,",
            "text_length": 5
        },
        {
            "end": 678829,
            "index": 168,
            "speaker": 0,
            "start": 675370,
            "text": "自然是没有,",
            "text_length": 5
        },
        {
            "end": 681225,
            "index": 169,
            "speaker": 0,
            "start": 680690,
            "text": "为什么?",
            "text_length": 3
        },
        {
            "end": 685900,
            "index": 170,
            "speaker": 0,
            "start": 685520,
            "text": "对呀,",
            "text_length": 2
        },
        {
            "end": 686160,
            "index": 171,
            "speaker": 0,
            "start": 685900,
            "text": "好,",
            "text_length": 1
        },
        {
            "end": 686920,
            "index": 172,
            "speaker": 0,
            "start": 686160,
            "text": "行好,",
            "text_length": 2
        },
        {
            "end": 687145,
            "index": 173,
            "speaker": 1,
            "start": 686830,
            "text": "是吧?",
            "text_length": 2
        },
        {
            "end": 695635,
            "index": 174,
            "speaker": 0,
            "start": 686920,
            "text": "后东西拿出来看这里。",
            "text_length": 9
        },
        {
            "end": 698139,
            "index": 175,
            "speaker": 0,
            "start": 696570,
            "text": "好啊,",
            "text_length": 2
        },
        {
            "end": 700005,
            "index": 176,
            "speaker": 0,
            "start": 699090,
            "text": "看这里拍个照,",
            "text_length": 6
        },
        {
            "end": 717940,
            "index": 177,
            "speaker": 0,
            "start": 703580,
            "text": "他们在说对的呃,",
            "text_length": 7
        },
        {
            "end": 719264,
            "index": 178,
            "speaker": 0,
            "start": 717940,
            "text": "12号加班是吧?",
            "text_length": 7
        },
        {
            "end": 723259,
            "index": 179,
            "speaker": 0,
            "start": 721220,
            "text": "在这里排队等着加班,",
            "text_length": 9
        },
        {
            "end": 724660,
            "index": 180,
            "speaker": 0,
            "start": 723259,
            "text": "要去和税缴税啊,",
            "text_length": 7
        },
        {
            "end": 725720,
            "index": 181,
            "speaker": 0,
            "start": 724660,
            "text": "收到短信去核税,",
            "text_length": 7
        },
        {
            "end": 726930,
            "index": 182,
            "speaker": 0,
            "start": 725720,
            "text": "缴税8~2十分。",
            "text_length": 7
        },
        {
            "end": 728810,
            "index": 183,
            "speaker": 1,
            "start": 728110,
            "text": "小费呀,",
            "text_length": 3
        },
        {
            "end": 728855,
            "index": 184,
            "speaker": 0,
            "start": 728150,
            "text": "小王雀,",
            "text_length": 3
        },
        {
            "end": 730005,
            "index": 185,
            "speaker": 1,
            "start": 728810,
            "text": "上午不是交了吗?",
            "text_length": 7
        },
        {
            "end": 730850,
            "index": 186,
            "speaker": 0,
            "start": 729810,
            "text": "不管要不要缴钱,",
            "text_length": 7
        },
        {
            "end": 732110,
            "index": 187,
            "speaker": 0,
            "start": 730850,
            "text": "都要去那边签字确认,",
            "text_length": 9
        },
        {
            "end": 733129,
            "index": 188,
            "speaker": 0,
            "start": 732110,
            "text": "不然这里出不来啊,",
            "text_length": 8
        },
        {
            "end": 733769,
            "index": 189,
            "speaker": 0,
            "start": 733129,
            "text": "具体缴不缴,",
            "text_length": 5
        },
        {
            "end": 735490,
            "index": 190,
            "speaker": 0,
            "start": 733769,
            "text": "以税务人员跟您核的为准。",
            "text_length": 11
        },
        {
            "end": 736589,
            "index": 191,
            "speaker": 0,
            "start": 735529,
            "text": "税核完了之后,",
            "text_length": 6
        },
        {
            "end": 737709,
            "index": 192,
            "speaker": 0,
            "start": 736589,
            "text": "一个工作日出证,",
            "text_length": 7
        },
        {
            "end": 738670,
            "index": 193,
            "speaker": 0,
            "start": 737709,
            "text": "明天可以过来拿。",
            "text_length": 7
        },
        {
            "end": 739550,
            "index": 194,
            "speaker": 0,
            "start": 738670,
            "text": "您是自己过来拿,",
            "text_length": 7
        },
        {
            "end": 740819,
            "index": 195,
            "speaker": 0,
            "start": 739550,
            "text": "还是半个电费。",
            "text_length": 6
        },
        {
            "end": 741060,
            "index": 196,
            "speaker": 1,
            "start": 740790,
            "text": "啊,",
            "text_length": 1
        },
        {
            "end": 743884,
            "index": 197,
            "speaker": 0,
            "start": 741279,
            "text": "那你就这个呀把身份证带上啊,",
            "text_length": 13
        },
        {
            "end": 748240,
            "index": 198,
            "speaker": 0,
            "start": 744660,
            "text": "把这个单子也带上到五拿证拿证的时候,",
            "text_length": 17
        },
        {
            "end": 752255,
            "index": 199,
            "speaker": 1,
            "start": 746100,
            "text": "对的啊,",
            "text_length": 3
        },
        {
            "end": 750440,
            "index": 200,
            "speaker": 0,
            "start": 748240,
            "text": "再把这个80块钱办证的费用交一下就行了。",
            "text_length": 19
        },
        {
            "end": 753649,
            "index": 201,
            "speaker": 0,
            "start": 750440,
            "text": "今天先不交这个80把水喝完就可以回去了。",
            "text_length": 19
        },
        {
            "end": 754524,
            "index": 202,
            "speaker": 0,
            "start": 753649,
            "text": "在这边排队啊,",
            "text_length": 6
        },
        {
            "end": 756130,
            "index": 203,
            "speaker": 1,
            "start": 754870,
            "text": "就是把水月喝完就回去,",
            "text_length": 10
        },
        {
            "end": 757410,
            "index": 204,
            "speaker": 1,
            "start": 756130,
            "text": "明天交这个80块钱,",
            "text_length": 9
        },
        {
            "end": 758300,
            "index": 205,
            "speaker": 0,
            "start": 757300,
            "text": "先过来拿证的时候,",
            "text_length": 8
        },
        {
            "end": 758290,
            "index": 206,
            "speaker": 1,
            "start": 757410,
            "text": "把身份证带到,",
            "text_length": 6
        },
        {
            "end": 761585,
            "index": 207,
            "speaker": 1,
            "start": 758290,
            "text": "把这个单子带到啊,",
            "text_length": 8
        },
        {
            "end": 770285,
            "index": 208,
            "speaker": 0,
            "start": 758300,
            "text": "交对明天过拿证的时候过来交八,",
            "text_length": 14
        },
        {
            "end": 777825,
            "index": 209,
            "speaker": 0,
            "start": 771210,
            "text": "然后呢嗯不行啊,",
            "text_length": 7
        },
        {
            "end": 814625,
            "index": 210,
            "speaker": 0,
            "start": 791350,
            "text": "好嗯,",
            "text_length": 2
        },
        {
            "end": 827329,
            "index": 211,
            "speaker": 1,
            "start": 792500,
            "text": "你的那我那就等交费了吧啊,",
            "text_length": 12
        },
        {
            "end": 859255,
            "index": 212,
            "speaker": 0,
            "start": 820740,
            "text": "走嗯打电话还有啊喂什么。",
            "text_length": 11
        },
        {
            "end": 837035,
            "index": 213,
            "speaker": 1,
            "start": 836600,
            "text": "一样的,",
            "text_length": 3
        },
        {
            "end": 856750,
            "index": 214,
            "speaker": 1,
            "start": 851490,
            "text": "天使欢迎嗯,",
            "text_length": 5
        },
        {
            "end": 861540,
            "index": 215,
            "speaker": 1,
            "start": 857740,
            "text": "那么对了。",
            "text_length": 4
        }
    ]

同步音频文本高亮

播放音频同步音频文本 对应单个文本高亮显示
使用audio

请添加图片描述

<template>
  <div class="dialog-container">
    <div> 
    <!-- 音频播放控件 -->
    <audio ref="audioPlayer" @loadedmetadata="onLoadedMetadata" @timeupdate="onTimeUpdate" controls></audio></div>
    <!-- 文本列表 -->
    <ul class="sentence-list" style="overflow-y: auto;">
      <li v-for="(sentence, index) in sentences" :key="index"
          :class="['sentence', { 'highlight': isActiveSentence(index) }, sentence.speaker === 0 ? 'customer' : 'employee']"
          @click="seekToSentence(sentence)">
        <div class="sentence-wrapper">
          <span class="speaker-label">{{ sentence.speaker === 0 ? '客户' : '员工' }}</span>
          <span class="timestamp">[{{ formatTime(sentence.start) }} - {{ formatTime(sentence.end) }}]</span>
          <span>时间差{{formatTime(sentence.end-sentence.start) }}</span>
          <p>{{ sentence.text }}</p>
        </div>
      </li>
    </ul>
  </div>
</template>
<script>
export default {
  data() {
    return {
      currentSentenceIndex: -1,
      sentences:[]
    };
  },
  mounted() {
    const audioElement = this.$refs.audioPlayer;
    audioElement.src = '../20250109.wav'; // 确保路径正确
    audioElement.preload = 'auto'; // 提前加载音频资源
    audioElement.load(); // 手动触发加载
  },
  methods: {
    seekToSentence(sentence) {
      const audioElement = this.$refs.audioPlayer;
      if (!audioElement.paused) {
        audioElement.pause();
      }
      audioElement.currentTime = sentence.start / 1000; // 将毫秒转换为秒
      this.currentSentenceIndex = this.sentences.findIndex(s => s.start === sentence.start && s.end === sentence.end);
      audioElement.play().catch(error => {
        console.error('无法播放音频:', error);
      });
    },
    onLoadedMetadata(event) {
      console.log('音频元数据已加载');
    },
    onTimeUpdate(event) {
      const currentTime = event.target.currentTime * 1000; // 将秒转换为毫秒
      let activeIndex = -1;

      for (let i = 0; i < this.sentences.length; i++) {
        if (currentTime >= this.sentences[i].start && currentTime < this.sentences[i].end) {
          activeIndex = i;
          break;
        }
      }

      if (activeIndex !== this.currentSentenceIndex) {
        this.currentSentenceIndex = activeIndex;
      }
    },
    isActiveSentence(index) {
      return this.currentSentenceIndex === index;
    },
    formatTime(ms) {
      const totalSeconds = Math.floor(ms / 1000);
      const minutes = Math.floor(totalSeconds / 60).toString().padStart(2, '0');
      const seconds = (totalSeconds % 60).toString().padStart(2, '0');
      return `${minutes}:${seconds}`;
    }
  }
};
</script>
<style scoped>
.dialog-container {
  border:1px solid red;
  padding:20px;
  display: flex;
  flex-direction: column;
  height: 400px; /* 固定高度 */
}

.sentence-list {
  list-style-type: none;
  padding: 0;
  margin: 0;
  flex-grow: 1;
  overflow-y: auto;
}

.sentence {
  cursor: pointer;
  margin: 5px 0;
  width: 100%;
  display: flex;
  justify-content: flex-start;
}

.customer {
  justify-content: flex-start;
}

.employee {
  justify-content: flex-end;
}

.sentence-wrapper {
  display: inline-block;
  max-width: 45%;
  padding: 10px;
  border-radius: 8px;
  background-color: #f0f0f0;
}

.sentence.highlight .sentence-wrapper {
  background-color: #ffeb3b; /* 或者您喜欢的其他颜色 */
}

.speaker-label {
  font-weight: bold;
}

.timestamp {
  color: #777;
}

.sentence-wrapper p {
  margin: 0;
}
</style>

文本高亮点击可播放可暂停

音频文件播放同步对应音频文本 点击对应文本可播放可暂停 进行同步音频文件播放时间点
音频同步文本 对应音频文本高亮显示

请添加图片描述

<template>
  <div class="dialog-container">
    <div>
      <!-- 音频播放控件 -->
    <audio ref="audioPlayer" @loadedmetadata="onLoadedMetadata" @timeupdate="onTimeUpdate" controls></audio>
    </div>
    <!-- 文本列表 -->
    <ul class="sentence-list" style="overflow-y: auto;">
      <li v-for="(sentence, index) in sentences" :key="index"
          :class="['sentence', { 'highlight': isActiveSentence(index), 'loading': isLoadingSentence(index) }, sentence.speaker === 0 ? 'customer' : 'employee']"
          @click="handleSentenceClick(sentence)">
        <div class="sentence-wrapper">
          <span class="speaker-label">{{ sentence.speaker === 0 ? '客户' : '员工' }}</span>
          <span class="timestamp">[{{ formatTime(sentence.start) }} - {{ formatTime(sentence.end) }}]</span>
          <p>{{ sentence.text }}</p>
          <!-- 以进度条形式展示 -->
          <!-- <div class="progress-indicator" :style="{ width: getProgressWidth(sentence) }"></div> -->
        </div>
      </li>
    </ul>
  </div>
</template>
<script>
export default {
  data() {
    return {
      currentSentenceIndex: -1,
      loadingSentenceIndex: null,
      sentences:     [],
      audioLoaded: false // 新增状态,用于跟踪音频是否已加载
    };
  },
  mounted() {
    const audioElement = this.$refs.audioPlayer;
    if (audioElement) {
      audioElement.src = '../20250109.wav'; // 确保路径正确
      audioElement.preload = 'auto';
      audioElement.load();
      
      // 监听 loadedmetadata 事件以设置 audioLoaded 为 true
      audioElement.addEventListener('loadedmetadata', () => {
        this.audioLoaded = true;
      });
    }
  },
  methods: {
    handleSentenceClick(sentence) {
      const audioElement = this.$refs.audioPlayer;
      if (!audioElement) return;

      const index = this.sentences.findIndex(s => s.start === sentence.start && s.end === sentence.end);

      if (this.currentSentenceIndex === index && !audioElement.paused) {
        audioElement.pause();
        this.loadingSentenceIndex = null;
      } else {
        this.scrollToSentence(index);
        this.loadingSentenceIndex = index;
        this.seekToSentence(sentence);
      }
    },
    seekToSentence(sentence) {
      const audioElement = this.$refs.audioPlayer;
      if (!audioElement) return;

      audioElement.currentTime = sentence.start / 1000; // 将毫秒转换为秒
      this.currentSentenceIndex = this.sentences.indexOf(sentence);
      audioElement.play().then(() => {
        this.loadingSentenceIndex = null;
      }).catch(error => {
        console.error('无法播放音频:', error);
        this.loadingSentenceIndex = null;
      });
    },
    onLoadedMetadata(event) {
      console.log('音频元数据已加载');
      this.audioLoaded = true; // 当元数据加载完成后设置为 true
    },
    onTimeUpdate(event) {
      const audioElement = this.$refs.audioPlayer;
      if (!audioElement) return;

      const currentTime = event.target.currentTime * 1000; // 将秒转换为毫秒
      let activeIndex = -1;

      for (let i = 0; i < this.sentences.length; i++) {
        if (currentTime >= this.sentences[i].start && currentTime < this.sentences[i].end) {
          activeIndex = i;
          break;
        }
      }

      if (activeIndex !== this.currentSentenceIndex) {
        this.currentSentenceIndex = activeIndex;
        this.scrollToSentence(activeIndex);
      }
    },
    isActiveSentence(index) {
      return this.currentSentenceIndex === index;
    },
    isLoadingSentence(index) {
      return this.loadingSentenceIndex === index;
    },
    formatTime(ms) {
      const totalSeconds = Math.floor(ms / 1000);
      const minutes = Math.floor(totalSeconds / 60).toString().padStart(2, '0');
      const seconds = (totalSeconds % 60).toString().padStart(2, '0');
      return `${minutes}:${seconds}`;
    },
    getProgressWidth(sentence) {
      const audioElement = this.$refs.audioPlayer;
      if (!audioElement || !this.audioLoaded) return '0%';

      const currentTime = audioElement.currentTime * 1000;
      if (currentTime >= sentence.start && currentTime < sentence.end) {
        const progress = ((currentTime - sentence.start) / (sentence.end - sentence.start)) * 100;
        return `${progress}%`;
      } else {
        return '0%';
      }
    },
    scrollToSentence(index) {
      const container = this.$el.querySelector('.sentence-list');
      const sentenceEl = this.$el.querySelectorAll('.sentence')[index];
      if (container && sentenceEl) {
        container.scrollTop = sentenceEl.offsetTop - container.offsetTop;
      }
    }
  }
};
</script>
<style scoped>
.dialog-container {
  border:1px solid red;
  padding:20px;
  display: flex;
  flex-direction: column;
  height: 400px; /* 固定高度 */
}

.sentence-list {
  list-style-type: none;
  padding: 0;
  margin: 0;
  flex-grow: 1;
  overflow-y: auto;
}

.sentence {
  cursor: pointer;
  margin: 5px 0;
  width: 100%;
  display: flex;
  justify-content: flex-start;
}

.customer {
  justify-content: flex-start;
}

.employee {
  justify-content: flex-end;
}

.sentence-wrapper {
  display: inline-block;
  max-width: 45%;
  padding: 10px;
  border-radius: 8px;
  background-color: #f0f0f0;
}

.sentence.highlight .sentence-wrapper {
  background-color: #ffeb3b; /* 或者您喜欢的其他颜色 */
}

.speaker-label {
  font-weight: bold;
}

.timestamp {
  color: #777;
}

.sentence-wrapper p {
  margin: 0;
}
.sentence-wrapper {
  position: relative;
}

.progress-indicator {
  position: absolute;
  left: 0;
  bottom: 0;
  height: 4px;
  background-color: #4CAF50;
  transition: width 0.3s ease-in-out;
  z-index: 1;
}

.sentence.loading .sentence-wrapper {
  background-color: #d4edda; /* 加载中的背景颜色 */
}

.sentence.highlight .sentence-wrapper {
  background-color: #ffeb3b; /* 或者您喜欢的其他颜色 */
}

.sentence.loading .sentence-wrapper::before {
  content: "加载中...";
  font-size: 0.8em;
  color: #777;
  display: block;
  margin-bottom: 5px;
}
</style>

同步音频文本模拟动画播放

使用 CSS 动画和 JavaScript 来模拟一个渐变填充的效果。
这个效果将从左到右逐渐填充句子背景,以模仿音频播放的过程。
实现步骤:
1 添加 CSS 动画:创建一个 CSS 动画,用于模拟背景颜色的渐进变化。
2 动态设置动画持续时间:根据每个句子的长度(即结束时间减去开始时间),计算出动画应该持续的时间。
3 触发动画:当用户点击某个句子并开始播放时,
4 为对应的 <li> 元素添加特定的类来启动动画;在播放结束或暂停时移除该类。
效果:
音频文件播放同步对应音频文本 点击对应文本可播放可暂停 进行同步音频文件播放时间点
音频同步文本 对应音频文件不仅高亮显示 并且动画模仿音频播放过程

请添加图片描述

<template>
  <div class="dialog-container">
   <div>
     <!-- 音频播放控件 -->
    <audio ref="audioPlayer" @loadedmetadata="onLoadedMetadata" @timeupdate="onTimeUpdate" @play="onPlay" @pause="onPause" @ended="onEnded" controls></audio>
   </div>
    <!-- 文本列表 -->
    <ul class="sentence-list" style="overflow-y: auto;">
      <li v-for="(sentence, index) in sentences" :key="index"
          :class="['sentence', { 'highlight': isActiveSentence(index), 'loading': isLoadingSentence(index), 'playing': isPlayingSentence(index) }, sentence.speaker === 0 ? 'customer' : 'employee']"
          @click="handleSentenceClick(sentence)">
        <div class="sentence-wrapper" :style="getAnimationDuration(sentence)">
          <div class="background-fill"></div> <!-- 新增的 div 用于背景填充 -->
          <span class="speaker-label">{{ sentence.speaker === 0 ? '客户' : '员工' }}</span>
          <span class="timestamp">[{{ formatTime(sentence.start) }} - {{ formatTime(sentence.end) }}]</span>
          <p>{{ sentence.text }}</p>
        </div>
      </li>
    </ul>
  </div>
</template>
<script>
export default {
  data() {
    return {
      currentSentenceIndex: -1,
      loadingSentenceIndex: null,
      playingSentenceIndex: null,
      sentences:[],//对应音频文本数据
      audioLoaded: false // 新增状态,用于跟踪音频是否已加载
    };
  },
  mounted() {
    const audioElement = this.$refs.audioPlayer;
    if (audioElement) {
      audioElement.src = '../20250109.wav'; // 确保路径正确
      audioElement.preload = 'auto';
      audioElement.load();
      
      // 监听 loadedmetadata 事件以设置 audioLoaded 为 true
      audioElement.addEventListener('loadedmetadata', () => {
        this.audioLoaded = true;
      });
    }
  },
  methods: {
    handleSentenceClick(sentence) {
      const audioElement = this.$refs.audioPlayer;
      if (!audioElement) return;

      const index = this.sentences.findIndex(s => s.start === sentence.start && s.end === sentence.end);

      if (this.currentSentenceIndex === index && !audioElement.paused) {
        audioElement.pause();
      } else {
        this.scrollToSentence(index);
        this.loadingSentenceIndex = index;
        this.seekToSentence(sentence);
      }
    },
    seekToSentence(sentence) {
      const audioElement = this.$refs.audioPlayer;
      if (!audioElement) return;

      audioElement.currentTime = sentence.start / 1000; // 将毫秒转换为秒
      this.currentSentenceIndex = this.sentences.indexOf(sentence);
      this.playingSentenceIndex = this.currentSentenceIndex;
      audioElement.play().then(() => {
        this.loadingSentenceIndex = null;
      }).catch(error => {
        console.error('无法播放音频:', error);
        this.loadingSentenceIndex = null;
        this.playingSentenceIndex = null;
      });
    },
    onLoadedMetadata(event) {
      console.log('音频元数据已加载');
      this.audioLoaded = true; // 当元数据加载完成后设置为 true
    },
    onTimeUpdate(event) {
      const currentTime = event.target.currentTime * 1000; // 将秒转换为毫秒
      let activeIndex = -1;

      for (let i = 0; i < this.sentences.length; i++) {
        if (currentTime >= this.sentences[i].start && currentTime < this.sentences[i].end) {
          activeIndex = i;
          break;
        }
      }

      if (activeIndex !== this.currentSentenceIndex) {
        this.currentSentenceIndex = activeIndex;
        this.playingSentenceIndex = activeIndex;
        this.scrollToSentence(activeIndex);
      }
    },
    onPlay(event) {
      this.playingSentenceIndex = this.currentSentenceIndex;
    },
    onPause(event) {
      this.playingSentenceIndex = null;
    },
    onEnded(event) {
      this.playingSentenceIndex = null;
    },
    isActiveSentence(index) {
      return this.currentSentenceIndex === index;
    },
    isLoadingSentence(index) {
      return this.loadingSentenceIndex === index;
    },
    isPlayingSentence(index) {
      return this.playingSentenceIndex === index;
    },
    formatTime(ms) {
      const totalSeconds = Math.floor(ms / 1000);
      const minutes = Math.floor(totalSeconds / 60).toString().padStart(2, '0');
      const seconds = (totalSeconds % 60).toString().padStart(2, '0');
      return `${minutes}:${seconds}`;
    },
    getAnimationDuration(sentence) {
      if (!this.isPlayingSentence(this.sentences.indexOf(sentence))) return {};
      const duration = (sentence.end - sentence.start) / 1000; // 转换为秒
      return {
        '--animation-duration': `${duration}s`
      };
    },
    scrollToSentence(index) {
      const container = this.$el.querySelector('.sentence-list');
      const sentenceEl = this.$el.querySelectorAll('.sentence')[index];
      if (container && sentenceEl) {
        container.scrollTop = sentenceEl.offsetTop - container.offsetTop;
      }
    }
  }
};
</script>
<style scoped>
/*-- */
.dialog-container {
  border:1px solid red;
  padding:20px;
  display: flex;
  flex-direction: column;
  height: 400px; /* 固定高度 */
}

.sentence-list {
  list-style-type: none;
  padding: 0;
  margin: 0;
  flex-grow: 1;
  overflow-y: auto;
}

.sentence {
  cursor: pointer;
  margin: 5px 0;
  width: 100%;
  display: flex;
  justify-content: flex-start;
}

.customer {
  justify-content: flex-start;
}

.employee {
  justify-content: flex-end;
}

.sentence-wrapper {
  display: inline-block;
  max-width: 45%;
  padding: 10px;
  border-radius: 8px;
  background-color: #f0f0f0;
}

.sentence.highlight .sentence-wrapper {
  background-color: #ffeb3b; /* 或者您喜欢的其他颜色 */
}

.speaker-label {
  font-weight: bold;
}

.timestamp {
  color: #777;
}

.sentence-wrapper p {
  margin: 0;
}
/*-- */

.sentence-wrapper {
  position: relative;
  overflow: hidden;
}

.background-fill {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 0;
  background-color: #4CAF50;
  z-index: 1; /* 提高 z-index */
  animation: loadBackground var(--animation-duration) linear forwards;
}

@keyframes loadBackground {
  from {
    width: 0;
  }
  to {
    width: 100%;
  }
}

.sentence.loading .sentence-wrapper {
  background-color: #d4edda; /* 加载中的背景颜色 */
}

.sentence.highlight .sentence-wrapper {
  background-color: #ffeb3b; /* 或者您喜欢的其他颜色 */
}

.sentence.loading .sentence-wrapper::before {
  content: "加载中...";
  font-size: 0.8em;
  color: #777;
  display: block;
  margin-bottom: 5px;
}

.sentence.playing .sentence-wrapper > *:not(.background-fill) {
  position: relative;
  z-index: 2; /* 确保文本内容在背景之上 */
}
</style>

http://www.kler.cn/a/504230.html

相关文章:

  • 离线docker安装数据库(无法访问互联网),那么直接使用 docker pull mysql:latest
  • STORM:从多时间点2D图像中快速重建动态3D场景的技术突破
  • 网络基础知识指南|1-20个
  • 蓝牙BT04-A的使用与相关AT指令
  • C++内存泄露排查
  • Java内存与缓存
  • [mysql]日志
  • vscode 扩展Cline、Continue的差别?
  • fpga 的时钟管理模块pll 跟 dcm
  • J.U.C(2)
  • JSON简介与使用
  • golang 环境变量配置
  • CSS语言的计算机基础
  • 在 Azure 100 学生订阅中新建 Ubuntu VPS 并通过 Docker 部署 Mastodon 服务器
  • C#委托(Delegate)基本用法
  • GD32F470Z外部晶振不起振
  • 【Hive】新增字段(column)后,旧分区无法更新数据问题
  • 1.13 多线程编程
  • 社群团购项目运营策略的深度剖析:融合链动2+1模式、AI智能名片与S2B2C商城小程序的综合应用
  • EasyExcel - 行合并策略(二级列表)
  • Elasticsearch:向量数据库基础设施类别的兴衰
  • 易我视频照片修复EaseUS Fixo Technician
  • 简聊MySQL并发事务中幻读、虚读问题的解决方案
  • GPU算力平台|在GPU算力平台部署Qwen-2通义千问大模型的教程
  • sniffer 日志分析吞吐问题
  • 结合night compute分析 利用tensor core 优化K值较大的矩阵乘(超过cublas50%)