// ==UserScript==
// @name Bilibili 404 刷视频
// @namespace http://tampermonkey.net/
// @version 2025.01.03.0
// @description 在 Bilibili 404页面刷视频
// @author HBcao233
// @match http*://*.bilibili.com/*
// @icon https://www.google.com/s2/favicons?sz=64&domain=bilibili.com
// @grant none
// @run-at document-start
// @require https://cdnjs.cloudflare.com/ajax/libs/lottie-web/5.12.2/lottie_svg.min.js
// @license MIT
// ==/UserScript==
(async function () {
'use strict';
let styles = `
@keyframes opacity-gradient
{
0%, 100% {opacity: 0}
50% {opacity: 1}
}
@keyframes bpx-animation-loading {
0% { background-position: 0 0; }
6.25% { background-position: -320px 0; }
12.5% { background-position: -640px 0; }
18.75% { background-position: -960px 0; }
25% { background-position: -1280px 0; }
31.25% { background-position: -1600px 0; }
37.5% { background-position: -1920px 0; }
43.75% { background-position: -2240px 0; }
50% { background-position: -2560px 0; }
56.25% { background-position: -2880px 0; }
62.5% { background-position: -3200px 0; }
68.75% { background-position: -3520px 0; }
75% { background-position: -3840px 0; }
81.25% { background-position: -4160px 0; }
87.5% { background-position: -4480px 0; }
93.75% { background-position: 0 -184px; }
100% { background-position: -320px -184px; }
}
@keyframes circle-spread {
0% { clip-path: none }
66.666666% { clip-path: none }
66.666667% { clip-path: polygon(50% 0, 50% 0, 50% 50%) }
73.333333% { clip-path: polygon(0 0, 50% 0, 50% 50%) }
73.333334% { clip-path: polygon(0 0, 50% 0, 50% 50%, 0 0) }
80.000000% { clip-path: polygon(0 0, 50% 0, 50% 50%, 0 100%) }
80.000001% { clip-path: polygon(0 0, 50% 0, 50% 50%, 0% 100%, 0 100%) }
86.666666% { clip-path: polygon(0 0, 50% 0, 50% 50%, 100% 100%, 0 100%) }
86.666667% { clip-path: polygon(0 0, 50% 0, 50% 50%, 100% 100%, 100% 100%, 0 100%) }
93.333333% { clip-path: polygon(0 0, 50% 0, 50% 50%, 100% 0, 100% 100%, 0 100%) }
93.333334% { clip-path: polygon(0 0, 50% 0, 50% 50%, 100% 0, 100% 0, 100% 100%, 0 100%) }
100% { clip-path: polygon(0 0, 50% 0, 50% 50%, 50% 0, 100% 0, 100% 100%, 0 100%) }
}
@media screen and (max-width: 500px) {
.h5-container, #biliMainHeader {
display: none;
}
.error-container {
display: block;
}
}
img[src=""], img:not([src]) {
opacity: 0;
}
.up-info-container {
display: flex
}
.up-info-container .up-avatar-wrap {
width: 48px;
height: 48px;
border-radius: 50%;
overflow: hidden;
}
.up-info-container .up-avatar-wrap .up-avatar {
width: 100%;
height: 100%;
}
.up-info-container .up-detail {
margin-left: 12px;
padding-top: 4px;
}
.up-info-container .up-detail .up-detail-top {
color: #FB7299;
font-size: 15px;
font-weight: 500;
}
.up-info-container .up-detail .up-detail-down {
margin-top: 4px;
color: #9499a0;
font-size: 13px;
}
.video-info-container {
margin-top: 12px;
}
.video-info-container .video-info-title {
display: inline-flex;
font-size: 20px;
font-weight: 500;
color: #18191C;
line-height: 28px;
max-width: 700px;
}
.video-info-title:before {
content: '';
display: block;
width: 700px;
height: 28px;
}
.video-info-title .video-title {
position: absolute;
background: #fff;
border-radius: 7px;
z-index: 100;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
max-width: 700px;
}
.video-info-title:hover .video-title, .video-title:hover {
white-space: normal;
}
.video-info-container .video-meta {
margin-top: 6px;
display: flex;
color: #9499a0;
font-size: 13px;
}
.video-info-container .video-meta > .item {
display: inline-flex;
flex-shrink: 0;
margin-right: 12px;
overflow: hidden;
}
.video-info-container .video-meta > .item .icon{
flex-shrink: 0;
margin-right: 4px;
}
.player-wrap {
margin-top: 10px;
display: flex;
}
.bpx-player-video-wrap video {
width: 700px;
height: 400px;
background: black;
}
#bilibili-player {
position: relative;
}
.bpx-player-video-area {
position: relative;
}
.bpx-player-tooltip-incenter {
position: absolute;
top: 0;
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
pointer-events: none;
}
.bpx-player-top-wrap {
display: none;
left: 0;
pointer-events: none;
position: absolute;
top: 0;
color: #fff;
transition: all .2s ease-in-out;
width: 100%;
z-index: 45;
}
#bilibili-player.hover .bpx-player-top-wrap {
display: flex;
}
.bpx-player-top-left {
left: 12px;
margin-top: 18px;
position: absolute;
}
.bpx-player-top-left-title {
display: none;
font-size: 16px;
font-weight: 500;
line-height: 24px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
width: 100%!important;
z-index: 2;
}
#bilibili-player.bpx-state-fullscreen .bpx-player-top-left-title {
display: block;
}
.bpx-player-follow {
-webkit-box-align: center;
-ms-flex-align: center;
-webkit-box-flex: 0;
align-items: center;
background-color: rgba(0,0,0,.4);
border-radius: 26px;
cursor: pointer;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-ms-flex: 0;
flex: 0;
font-size: 12px;
font-weight: 400;
width: fit-content;
height: 32px;
line-height: 32px;
margin-top: 5px;
pointer-events: all;
text-align: center;
z-index: 2;
padding-right: 5px;
}
.bpx-player-follow-face {
-webkit-box-flex: 0;
border-radius: 50%;
-ms-flex: none;
flex: none;
height: 24px;
margin-left: 4px;
vertical-align: bottom;
width: 24px;
}
.bpx-player-follow-text {
-webkit-box-flex: 0;
-ms-flex: none;
flex: none;
margin-left: 5px;
}
.bpx-player-state-wrap {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
z-index: 48;
cursor: pointer;
pointer-events: none;
}
#bilibili-player.bpx-state-paused .bpx-player-state-play {
display: block;
position: absolute;
right: 34px;
bottom: 62px;
background: url(//s1.hdslb.com/bfs/static/player/img/play.svg) 50% no-repeat;
height: 64px;
width: 64px;
}
.bpx-player-state-buff-icon {
display: none;
width: 24px;
height: 24px;
}
.bpx-player-state-buff-text {
display: none;
color: #fff;
font-size: 14px;
line-height: 1;
margin-top: 8px;
text-shadow: 0 1px 2px rgba(0,0,0,.7);
}
.bpx-player-state-buff-icon svg > g:nth-child(1) > g { animation: opacity-gradient 1s ease-in-out infinite }
.bpx-player-state-buff-icon svg > g:nth-child(1) > g:nth-child(2) { animation-delay: 0.1s }
.bpx-player-state-buff-icon svg > g:nth-child(1) > g:nth-child(3) { animation-delay: 0.2s }
.bpx-player-state-buff-icon svg > g:nth-child(2) {
animation: circle-spread 3s ease-in-out infinite;
}
#bilibili-player.bpx-state-buff .bpx-player-state-buff-icon, #bilibili-player.bpx-state-buff .bpx-player-state-buff-text {
display: block;
}
.bpx-player-loading-panel {
background-color: #000;
display: none;
height: 100%;
left: 0;
position: absolute;
top: 0;
width: 100%;
z-index: 57;
}
.bpx-player-loading-panel.bpx-state-loading {
display: block;
}
.bpx-player-loading-panel-blur {
-webkit-box-align: center;
-ms-flex-align: center;
-webkit-box-pack: center;
-ms-flex-pack: center;
align-items: center;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
height: 100%;
justify-content: center;
pointer-events: none;
position: relative;
width: 100%;
}
.bpx-player-loading-panel-blur-detail {
-webkit-animation: bpx-animation-loading .94s steps(1) infinite;
animation: bpx-animation-loading .94s steps(1) infinite;
background: url(//s1.hdslb.com/bfs/static/player/img/ploading.png) no-repeat;
height: 184px;
-webkit-transform: scale(.5);
transform: scale(.5);
width: 320px;
}
.bpx-player-control {
bottom: 0;
left: 0;
position: absolute;
width: 100%;
z-index: 75;
}
.bpx-player-control-mask {
background: url() repeat-x bottom;
bottom: 0;
height: 100px;
left: 0;
pointer-events: none;
position: absolute;
width: 100%;
z-index: -1;
opacity: 0;
transition: opacity .2s ease-in;
}
#bilibili-player.hover .bpx-player-control-mask,
#bilibili-player:has(.control-btn:hover) .bpx-player-control-mask,
#bilibili-player:has(.bpx-player-progress:hover) .bpx-player-control-mask,
#bilibili-player.hover .bpx-player-control-bottom,
#bilibili-player:has(.control-btn:hover) .bpx-player-control-bottom,
#bilibili-player:has(.bpx-player-progress:hover) .bpx-player-control-bottom {
opacity: 1;
}
.bpx-player-control-top {
position: absolute;
left: 0;
right: 0;
bottom: 44px;
box-sizing: border-box;
padding: 0 12px;
}
#bilibili-player:not(.hover) .bpx-player-control-top {
bottom: 0;
}
.bpx-player-progress {
margin-bottom: 6px;
align-items: center;
display: flex;
height: 4px;
position: relative;
transition: transform .1s cubic-bezier(0,0,.2,1);
width: 100%;
}
.bpx-player-progress.active, .bpx-player-progress:hover {
height: 6px;
}
.bpx-player-progress .schedule {
width: 100%;
height: 100%;
position: absolute;
left: 0;
right: 0;
top: 0;
bottom: 0;
background-color: hsla(0, 0%, 100%, .2);
border-radius: 1.5px;
overflow: hidden;
position: absolute;
pointer-events: none;
}
.bpx-player-progress .buffer, .bpx-player-progress .current {
bottom: 0;
left: 0;
position: absolute;
right: 0;
top: 0;
-webkit-transform: scaleX(0);
transform: scaleX(0);
-webkit-transform-origin: 0 0;
transform-origin: 0 0;
}
.bpx-player-progress .buffer {
background-color: hsla(0, 0%, 100%, .3);
}
.bpx-player-progress .current {
background-color: var(--bpx-primary-color, #00AEEC);
}
.bpx-player-progress .thumb {
height: 20px;
width: 20px;
line-height: 12px;
}
.bpx-player-progress .thumb-icon {
transform: translateX(-50%) scale(0);
transition: transform .2s;
}
.bpx-player-progress.active .thumb-icon {
transform: translateX(-50%) scale(1);
}
.bpx-player-progress .move-indicator {
height: 16px;
margin-left: -4px;
overflow: hidden;
opacity: 0;
position: absolute;
width: 8px;
pointer-events: none;
}
.bpx-player-progress.active .move-indicator {
opacity: 1;
}
.bpx-player-progress .move-indicator > div {
position: relative;
border-style: solid;
width: 0;
height: 0;
}
.bpx-player-progress .move-indicator > .down {
border-color: var(--bpx-primary-color, #00AEEC) transparent transparent;
border-width: 4px 4px 0;
}
.bpx-player-progress .move-indicator > .up {
border-color: transparent transparent var(--bpx-primary-color, #00a1d6);
border-width: 0 4px 4px;
margin-top: 8px;
}
.bpx-player-progress .popup {
display: none;
width: 160px;
position: absolute;
bottom: 22px;
border-radius: 2px;
line-height: 36px;
pointer-events: none;
}
.bpx-player-progress.active .popup {
display: block;
}
.bpx-player-progress .popup .preview {
background-color: transparent;
position: relative;
width: 160px;
height: 90px;
transform: translateX(-50%);
pointer-events: none;
}
.bpx-player-progress .popup .preview-image {
background-color: black;
height: 100%;
margin: 0 auto;
position: relative;
width: 100%;
object-fit: scale-down;
pointer-events: none;
user-select: none;
}
.bpx-player-progress .popup .preview-time {
display: inline-block;
position: absolute;
left: 50%;
bottom: 0;
color: #fff;
height: 18px;
padding: 0 5px;
background-color: hsla(0, 0%, 8%, .9);
border-radius: 2px;
font-size: 12px;
line-height: 18px;
transform: translateX(-50%);
pointer-events: none;
user-select: none;
}
.bpx-player-control-bottom {
box-sizing: border-box;
display: flex;
height: 35px;
justify-content: space-between;
line-height: 22px;
margin: 20px 0 0;
padding: 0 12px;
width: 100%;
opacity: 0;
transition: opacity .2s ease-in;
}
.bpx-player-control-bottom-left {
display: inline-flex;
flex: none;
}
.bpx-player-control-bottom-right {
display: flex;
justify-content: flex-end;
}
.bpx-player-control-bottom .control-btn {
width: 36px;
height: 22px;
fill: hsla(0, 0%, 100%, .8);
color: hsla(0, 0%, 100%, .8);
font-size: 0;
line-height: 22px;
outline: 0;
position: relative;
text-align: center;
z-index: 2;
}
.bpx-player-control-bottom .control-btn:hover {
fill: #fff;
color: #fff;
}
.bpx-player-control-bottom .control-btn > .icon {
width: 100%;
height: 22px;
cursor: pointer;
}
.bpx-player-control-bottom .control-btn > .icon > svg {
width: 100%;
height: 100%;
transition: fill .15s ease-in-out, opacity .15s ease-in-out;
opacity: 1;
}
.bpx-player-playrate-hint {
-webkit-box-pack: center;
-ms-flex-pack: center;
background-color: rgba(33, 33, 33, .9);
border-radius: 4px;
color: #fff;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
height: 34px;
justify-content: center;
left: 50%;
line-height: 34px;
margin-left: -65px;
position: absolute;
top: 18px;
width: 130px;
z-index: 77;
}
.bpx-player-playrate-hint .icon {
display: flex;
margin-right: 8px;
width: 30px;
}
.bpx-player-playrate-hint .icon >svg > g > g { animation: opacity-gradient 1s ease-in-out infinite }
.bpx-player-playrate-hint .icon >svg > g > g:nth-child(2) { animation-delay: 0.1s }
.bpx-player-playrate-hint .icon >svg > g > g:nth-child(3) { animation-delay: 0.2s }
.control-btn.play > .icon > svg:nth-child(1) {
position: absolute;
}
.control-btn.play > .icon > svg:nth-child(2) {
opacity: 0;
}
#bilibili-player.bpx-state-paused .control-btn.play> .icon > svg:nth-child(1) {
opacity: 0;
}
#bilibili-player.bpx-state-paused .control-btn.play> .icon > svg:nth-child(2) {
opacity: 1;
}
.control-btn.time {
font-size: 12px;
margin-right: 10px;
min-width: 90px;
}
.control-btn.time .seek {
outline: none;
text-decoration: none;
}
.control-btn.time .label {
position: absolute;
width: 100%;
height: 100%;
text-align: center;
white-space: nowrap;
}
.control-btn.time .divide {
padding: 0 2px;
}
.control-btn.volume .volume-box {
display: none;
background: hsla(0, 0%, 8%, .9);
border-radius: 2px;
bottom: 41px;
height: 100px;
left: 50%;
margin-left: -16px;
position: absolute;
width: 32px;
}
.control-btn.volume .volume-number {
color: #e5e9ef;
font-size: 12px;
height: 28px;
line-height: 28px;
margin-bottom: 2px;
text-align: center;
width: 100%;
}
.control-btn.volume .volume-slider {
height: 60px;
margin: 0 auto;
cursor: pointer;
display: flex;
justify-content: center;
}
.control-btn.volume .track {
position: relative;
display: flex;
width: 2px;
height: 100%;
align-items: flex-end;
pointer-events: none;
}
.control-btn.volume .bar-wrap {
background: #e7e7e7;
border-radius: 1.5px;
bottom: 0;
left: 0;
overflow: hidden;
position: absolute;
right: 0;
top: 0;
pointer-events: none;
}
.control-btn.volume .bar {
background: var(--bpx-fn-color, #00a1d6);
transform-origin: 0 100%;
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
pointer-events: none;
}
.control-btn.volume .thumb {
position: absolute;
top: 0;
border-radius: 50%;
pointer-events: none;
}
.control-btn.volume .thumb-dot {
width: var(--bpx-ui-font-size, 12px);
height: var(--bpx-ui-font-size, 12px);
background-color: var(--bpx-fn-color, #00a1d6);
border-radius: 50%;
display: flex;
transition: all .2s;
vertical-align: middle;
align-items: flex-end;
pointer-events: none;
transform: translate(-47%, -50%);
}
.control-btn.volume.hover .volume-box,
.control-btn.volume:hover .volume-box,
.volume-box:hover {
display: block;
}
.control-btn.playbackrate {
cursor: pointer;
font-size: 14px;
font-weight: 600;
}
.control-btn .playbackrate-menu {
list-style: none;
outline: none;
background-color: hsla(0, 0%, 8%, .9);
border-radius: 2px;
bottom: 41px;
-webkit-box-sizing: border-box;
box-sizing: border-box;
display: none;
left: 50%;
margin: 0;
padding: 0;
position: absolute;
text-align: center;
-webkit-transform: translateX(-50%);
transform: translateX(-50%);
width: 70px;
}
.control-btn.playbackrate.hover .playbackrate-menu,
.control-btn.playbackrate:hover .playbackrate-menu,
.playbackrate-menu:hover {
display: block;
}
.control-btn .playbackrate-menu > .item {
font-size: 12px;
cursor: pointer;
height: 36px;
line-height: 36px;
position: relative;
}
.control-btn .playbackrate-menu > .item:hover {
background-color: rgba(255, 255, 255, .1);
}
.control-btn .playbackrate-menu > .item.active {
color: var(--bpx-primary-color, #00a1d6);
}
.player-wrap .video-controls {
display: flex;
position: relative;
flex-direction: column;
justify-content: center;
margin-left: 5px;
}
.player-wrap .video-controls > .item {
position: relative;
transform: rotate(90deg);
border-radius: 5px;
background: var(--text2, #61666D);
width: 28px;
height: 28px;
font-size: 20px;
font-weight: 1000;
display: flex;
justify-content: center;
color: white;
margin-bottom: 5px;
user-select: none !important;
}
.player-wrap .video-controls > .item:hover {
background: var(--brand_blue, #00AEEC);
}
.player-wrap .video-controls > .item.goto {
position: absolute;
top: 0;
transform: unset;
}
.player-wrap .video-controls > .item.goto .goto-form {
display: none;
position: absolute;
left: 35px;
transform: translateY(-7px);
}
.video-controls .item.goto:hover .goto-form,
.video-controls .item.goto.hover .goto-form,
.goto-form:hover {
display: block;
}
.goto-form .goto-input {
display: block;
width: 120px;
}
.goto-form .goto-confirm {
margin-top: 3px;
}
.goto-form .goto-tip {
font-size: 12px;
color: black;
font-weight: normal;
margin-left: 5px;
}
.bpx-player-tooltip-area {
position: relative;
}
.bpx-player-tooltip-item {
background-color: #000;
border-radius: 2px;
color: #fff;
cursor: default;
font-size: 12px;
line-height: 1.5;
max-width: 18em;
opacity: 0;
padding: 6px 8px;
pointer-events: none;
position: absolute;
user-select: none;
width: fit-content;
word-wrap: break-word;
word-break: break-all;
z-index: 12000;
transform: translateY(5px);
transition: opacity .15s ease-in-out, transform .15s ease-in-out;
}
#bilibili-player:has(.control-btn.previous:hover) .bpx-player-tooltip-item.previous,
#bilibili-player:has(.control-btn.next:hover) .bpx-player-tooltip-item.next,
#bilibili-player:has(.control-btn.fullscreen:hover) .bpx-player-tooltip-item.fullscreen {
opacity: 1;
transform: translateY(0);
}
#arc_toolbar_report {
width: 700px;
border-bottom: 1px solid #E3E5E7;
}
#arc_toolbar_report .video-toolbar {
display: flex;
padding-top: 16px;
padding-bottom: 12px;
}
#arc_toolbar_report .video-toolbar > .item {
position: relative;
margin-right: 8px;
display: flex;
align-items: center;
width: 92px;
height: 28px;
transition: all .3s;
font-size: 13px;
font-weight: 500;
color: var(--text2, #61666D);
cursor: pointer;
}
#arc_toolbar_report .video-toolbar > .item.on,
#arc_toolbar_report .video-toolbar > .item:hover {
color: var(--brand_blue, #00AEEC);
}
#arc_toolbar_report .video-toolbar > .item > .icon {
flex-shrink: 0;
width: 28px;
height: 28px;
margin-right: 8px;
}
#arc_toolbar_report .video-toolbar > .item.share > .text {
opacity: 1;
transform: translateY(0px);
transition: all .3s;
color: var(--text2, #61666D);
}
#arc_toolbar_report .video-toolbar > .item.share > .copy-tip {
position: absolute;
left: 36px;
opacity: 0;
transform: translateY(15px);
transition: transform .3s, opacity .3s;
color: var(--brand_blue, #00AEEC);
}
#arc_toolbar_report .video-toolbar > .item.share:hover > .text {
opacity: 0;
transform: translateY(-15px);
color: var(--brand_blue, #00AEEC);
}
#arc_toolbar_report .video-toolbar > .item.share:hover > .copy-tip {
opacity: 1;
transform: translateY(0px);
}
.video-desc-container {
margin: 16px 0;
}
.video-desc-container .basic-desc-info {
white-space: pre-line;
letter-spacing: 0;
color: var(--text1, #18191c);
font-size: 15px;
line-height: 24px;
overflow: hidden;
word-break: break-all;
line-break: anywhere;
}
.video-desc-container .basic-desc-info a {
color: var(--brand_blue, #00aeec);
}
@media screen and (max-width: 500px) {
.video-info-container, .up-info-container, #arc_toolbar_report, .video-desc-container {
display: none;
}
.player-wrap {
position: absolute;
top: 0;
left: 0;
margin-top: 0;
}
.video-controls {
position: fixed;
top: 50%;
right: 5px;
z-index: 100;
}
}
@keyframes roll {
0% { transform: translateX(0) translateZ(0); }
100% { transform: translateX(var(--translateX)) translateZ(0); }
}
@keyframes disappear {
0% { opacity: 1; }
99% { opacity: 1; }
100% { opacity: 0; }
}
.bpx-player-row-dm-wrap {
cursor: pointer;
height: 100%;
left: 0;
-webkit-mask-position: center;
mask-position: center;
overflow: hidden;
pointer-events: none;
position: absolute;
top: 0;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
width: 100%;
z-index: 2;
-webkit-box-pack: center;
-ms-flex-pack: center;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
justify-content: center;
z-index: 11;
}
.bili-danmaku-x-dm {
user-select: none;
white-space: pre;
position: absolute;
line-height: 1.125;
perspective: 500px;
transform: translate(-50%, var(--translateY, 0));
font-family: SimHei, 'Microsoft JhengHei', Arial, Helvetica, sans-serif;
font-weight: bold;
font-size: var(--fontSize, 25px);
left: var(--offset, -10px);
color: var(--color, #ffffff);
text-shadow: 1px 0 1px #000000,0 1px 1px #000000,0 -1px 1px #000000,-1px 0 1px #000000;
transform: translateZ(0);
top: var(--top, 0);
z-index: var(--zIndex, 200);
will-change: transform, opacity, top, left;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
}
.bili-danmaku-x-dm.bili-danmaku-x-center {
top: 0;
left: 50%;
transform: translate(-50%, var(--translateY, 0));
animation: disappear linear var(--duration, 8.5s) forwards;
}
.bili-danmaku-x-dm.bili-danmaku-x-roll {
left: 100%;
animation: roll linear var(--duration, 8.5s) forwards;
}
.bpx-state-paused .bili-danmaku-x-dm {
animation-play-state: paused !important;
}
`
/**
* 去TM b站各种乱七八糟的报错和后台脚本
*/
for (const e of document.querySelectorAll('script')) {
e.remove();
}
navigator.sendBeacon = function () { };
for (const i of ["visibilitychange", "webkitvisibilitychange", "blur"]) {
window.addEventListener(i, function (e) {
e.stopImmediatePropagation();
}, true);
}
String.prototype.rsplit = function (sep, maxsplit) {
let split = this.split(sep);
return maxsplit ? [split.slice(0, -maxsplit).join(sep)].concat(split.slice(-maxsplit)) : split;
}
const md5sum = function (d) { let r = M(V(Y(X(d), 8 * d.length))); return r.toLowerCase() }; function M(d) { for (var _, m = "0123456789ABCDEF", f = "", r = 0; r < d.length; r++)_ = d.charCodeAt(r), f += m.charAt(_ >>> 4 & 15) + m.charAt(15 & _); return f } function X(d) { for (var _ = Array(d.length >> 2), m = 0; m < _.length; m++)_[m] = 0; for (m = 0; m < 8 * d.length; m += 8)_[m >> 5] |= (255 & d.charCodeAt(m / 8)) << m % 32; return _ } function V(d) { for (var _ = "", m = 0; m < 32 * d.length; m += 8)_ += String.fromCharCode(d[m >> 5] >>> m % 32 & 255); return _ } function Y(d, _) { d[_ >> 5] |= 128 << _ % 32, d[14 + (_ + 64 >>> 9 << 4)] = _; for (var m = 1732584193, f = -271733879, r = -1732584194, i = 271733878, n = 0; n < d.length; n += 16) { var h = m, t = f, g = r, e = i; f = md5_ii(f = md5_ii(f = md5_ii(f = md5_ii(f = md5_hh(f = md5_hh(f = md5_hh(f = md5_hh(f = md5_gg(f = md5_gg(f = md5_gg(f = md5_gg(f = md5_ff(f = md5_ff(f = md5_ff(f = md5_ff(f, r = md5_ff(r, i = md5_ff(i, m = md5_ff(m, f, r, i, d[n + 0], 7, -680876936), f, r, d[n + 1], 12, -389564586), m, f, d[n + 2], 17, 606105819), i, m, d[n + 3], 22, -1044525330), r = md5_ff(r, i = md5_ff(i, m = md5_ff(m, f, r, i, d[n + 4], 7, -176418897), f, r, d[n + 5], 12, 1200080426), m, f, d[n + 6], 17, -1473231341), i, m, d[n + 7], 22, -45705983), r = md5_ff(r, i = md5_ff(i, m = md5_ff(m, f, r, i, d[n + 8], 7, 1770035416), f, r, d[n + 9], 12, -1958414417), m, f, d[n + 10], 17, -42063), i, m, d[n + 11], 22, -1990404162), r = md5_ff(r, i = md5_ff(i, m = md5_ff(m, f, r, i, d[n + 12], 7, 1804603682), f, r, d[n + 13], 12, -40341101), m, f, d[n + 14], 17, -1502002290), i, m, d[n + 15], 22, 1236535329), r = md5_gg(r, i = md5_gg(i, m = md5_gg(m, f, r, i, d[n + 1], 5, -165796510), f, r, d[n + 6], 9, -1069501632), m, f, d[n + 11], 14, 643717713), i, m, d[n + 0], 20, -373897302), r = md5_gg(r, i = md5_gg(i, m = md5_gg(m, f, r, i, d[n + 5], 5, -701558691), f, r, d[n + 10], 9, 38016083), m, f, d[n + 15], 14, -660478335), i, m, d[n + 4], 20, -405537848), r = md5_gg(r, i = md5_gg(i, m = md5_gg(m, f, r, i, d[n + 9], 5, 568446438), f, r, d[n + 14], 9, -1019803690), m, f, d[n + 3], 14, -187363961), i, m, d[n + 8], 20, 1163531501), r = md5_gg(r, i = md5_gg(i, m = md5_gg(m, f, r, i, d[n + 13], 5, -1444681467), f, r, d[n + 2], 9, -51403784), m, f, d[n + 7], 14, 1735328473), i, m, d[n + 12], 20, -1926607734), r = md5_hh(r, i = md5_hh(i, m = md5_hh(m, f, r, i, d[n + 5], 4, -378558), f, r, d[n + 8], 11, -2022574463), m, f, d[n + 11], 16, 1839030562), i, m, d[n + 14], 23, -35309556), r = md5_hh(r, i = md5_hh(i, m = md5_hh(m, f, r, i, d[n + 1], 4, -1530992060), f, r, d[n + 4], 11, 1272893353), m, f, d[n + 7], 16, -155497632), i, m, d[n + 10], 23, -1094730640), r = md5_hh(r, i = md5_hh(i, m = md5_hh(m, f, r, i, d[n + 13], 4, 681279174), f, r, d[n + 0], 11, -358537222), m, f, d[n + 3], 16, -722521979), i, m, d[n + 6], 23, 76029189), r = md5_hh(r, i = md5_hh(i, m = md5_hh(m, f, r, i, d[n + 9], 4, -640364487), f, r, d[n + 12], 11, -421815835), m, f, d[n + 15], 16, 530742520), i, m, d[n + 2], 23, -995338651), r = md5_ii(r, i = md5_ii(i, m = md5_ii(m, f, r, i, d[n + 0], 6, -198630844), f, r, d[n + 7], 10, 1126891415), m, f, d[n + 14], 15, -1416354905), i, m, d[n + 5], 21, -57434055), r = md5_ii(r, i = md5_ii(i, m = md5_ii(m, f, r, i, d[n + 12], 6, 1700485571), f, r, d[n + 3], 10, -1894986606), m, f, d[n + 10], 15, -1051523), i, m, d[n + 1], 21, -2054922799), r = md5_ii(r, i = md5_ii(i, m = md5_ii(m, f, r, i, d[n + 8], 6, 1873313359), f, r, d[n + 15], 10, -30611744), m, f, d[n + 6], 15, -1560198380), i, m, d[n + 13], 21, 1309151649), r = md5_ii(r, i = md5_ii(i, m = md5_ii(m, f, r, i, d[n + 4], 6, -145523070), f, r, d[n + 11], 10, -1120210379), m, f, d[n + 2], 15, 718787259), i, m, d[n + 9], 21, -343485551), m = safe_add(m, h), f = safe_add(f, t), r = safe_add(r, g), i = safe_add(i, e) } return Array(m, f, r, i) } function md5_cmn(d, _, m, f, r, i) { return safe_add(bit_rol(safe_add(safe_add(_, d), safe_add(f, i)), r), m) } function md5_ff(d, _, m, f, r, i, n) { return md5_cmn(_ & m | ~_ & f, d, _, r, i, n) } function md5_gg(d, _, m, f, r, i, n) { return md5_cmn(_ & f | m & ~f, d, _, r, i, n) } function md5_hh(d, _, m, f, r, i, n) { return md5_cmn(_ ^ m ^ f, d, _, r, i, n) } function md5_ii(d, _, m, f, r, i, n) { return md5_cmn(m ^ (_ | ~f), d, _, r, i, n) } function safe_add(d, _) { var m = (65535 & d) + (65535 & _); return (d >> 16) + (_ >> 16) + (m >> 16) << 16 | 65535 & m } function bit_rol(d, _) { return d << _ | d >>> 32 - _ }
const isNumber = s => Object.prototype.toString.call(s) === "[object Number]";
const isString = s => Object.prototype.toString.call(s) === "[object String]";
const isArrayLike = s => s != null && typeof s[Symbol.iterator] === 'function';
function formatDateTime(d) {
const formatter = new Intl.DateTimeFormat("zh-CN", {
timeZone: "Asia/Shanghai",
year: "numeric",
month: "2-digit",
day: "2-digit",
hour: "2-digit",
minute: "2-digit",
second: "2-digit",
})
return formatter.format(d).replaceAll('/', '-')
}
function formatTime(t) {
let s = Math.floor(t % 60);
if (s < 10) s = '0' + s;
let m = Math.floor(t / 60 % 60);
if (m < 10) m = '0' + m;
let h = Math.floor(t / 3600);
if (h < 10) h = '0' + h;
if (h > 0) return h + ':' + m + ':' + s;
return m + ':' + s;
}
function getCookie(name) {
var match = document.cookie.match(new RegExp('(^| )' + name + '=([^;]+)'));
if (match) return match[2];
}
function isMobile() {
return window.screen.width < 500;
}
async function getMixinKey(img_key, sub_key) {
const mixinKeyEncTab = [46, 47, 18, 2, 53, 8, 23, 32, 15, 50, 10, 31, 58, 3, 45, 35, 27, 43, 5, 49, 33, 9, 42, 19, 29, 28, 14, 39, 12, 38, 41, 13, 37, 48, 7, 16, 24, 55, 40, 61, 26, 17, 0, 1, 60, 51, 30, 4, 22, 25, 54, 21, 56, 59, 6, 63, 57, 62, 11, 36, 20, 34, 44, 52];
if (!img_key || !sub_key) {
const r = await fetch('https://api.bilibili.com/x/web-interface/nav', {
credentials: 'include'
})
const res = (await r.json()).data.wbi_img;
img_key = res['img_url'].rsplit('/', 1)[1].split('.')[0];
sub_key = res['sub_url'].rsplit('/', 1)[1].split('.')[0];
}
const orig = img_key + sub_key;
return mixinKeyEncTab.reduce((s, i) => s + orig[i],).slice(0, 32);
}
function wbi(params, mkey) {
mkey = mkey || mixin_key;
params['wts'] = Math.round(Date.now() / 1000);
// 按照 key 重排参数, 并过滤 value 中的 "!'()*" 字符
const query = Object.keys(params).sort().map(k => {
return k + '=' + String(params[k]).replace(/[!'()*]/g, '');
}).join('&');
params['w_rid'] = md5sum(query + mkey);
return params;
}
async function getPlayerInfo(aid, cid) {
const params = wbi({
aid: aid,
cid: cid,
isGaiaAvoided: true,
web_location: 1315873,
});
const r = await fetch('https://api.bilibili.com/x/player/wbi/v2?' + (new URLSearchParams(params)).toString(), {
credentials: 'include',
});
const res = await r.json();
if (r.status != 200 || !res) return;
if (!inited && res.data.player_icon) {
for (const [k, v] of Object.entries(res.data.player_icon)) {
player_icon[k] = v
}
}
return res.data;
}
async function getRcmd() {
const arr = videos.length > 0 ? videos.map(v => { return v.goto + '_' + v.id }) : JSON.parse(window.localStorage.getItem('last_showlist') || '[]');
let last_showlist = arr.splice(0, 10).join(',');
while (arr.length > 0) {
last_showlist += ';' + arr.splice(0, 12).join(',');
}
const params = wbi({
web_location: 1430650,
y_num: 3,
fresh_type: 4,
feed_version: 'V8',
fresh_idx_1h: 1,
fetch_row: 4,
fresh_idx: 1,
brush: 1,
homepage_ver: 1,
ps: inited ? 12 : 10,
last_y_num: 4,
screen: '1050-703',
seo_info: '',
last_showlist: last_showlist,
uniq_id: (new Date()).getTime(),
});
const r = await fetch('https://api.bilibili.com/x/web-interface/wbi/index/top/feed/rcmd?' + (new URLSearchParams(params)).toString(), {
credentials: 'include',
});
const res = await r.json();
return res.data.item.map(v => { return { goto: v.goto, id: v.id, cid: v.cid } });
}
async function getPlayUrl(bvid, cid) {
const params = wbi({
qn: 64,
fnver: 0,
fnval: 16,
fourk: 1,
voice_balance: 1,
bvid: bvid,
cid: cid,
web_location: 1315873,
})
const r = await fetch('https://api.bilibili.com/x/player/wbi/playurl?' + (new URLSearchParams(params)).toString(), {
credentials: 'include',
});
const res = await r.json();
return res.data;
}
async function getRelation(aid) {
const r = await fetch('https://api.bilibili.com/x/web-interface/archive/relation?aid=' + aid, {
credentials: 'include',
});
const res = await r.json();
if (r.status != 200 || !res) return {};
return res.data;
}
function chooseQuality(video) {
const ve = video.video_error_times || 0;
const ae = video.audio_error_times || 0;
let qn = 64;
const sorted_video = video.dash.video.sort((x, y) => {
if (x.id > qn) return 1;
if (y.id > qn) return -1;
return y.id - x.id;
});
const v_info = sorted_video[0];
const audios = video.dash.audio;
let v = v_info.baseUrl;
let a = null;
if (ve) {
if (ve <= sorted_video[0].backupUrl.length) {
v = sorted_video[0].backupUrl[ve - 1];
} else if (ve == sorted_video[0].backupUrl.length + 1) {
v = sorted_video[1].baseUrl;
} else {
v = sorted_video[1].backupUrl[ve - sorted_video[0].backupUrl.length - 2];
}
}
if (audios) {
a = audios[0].baseUrl
if (ae) {
if (ae <= audios[0].backupUrl.length) {
a = audios[0].backupUrl[ae - 1];
} else if (ae == audios[0].backupUrl.length + 1) {
a = audios[1].baseUrl;
} else {
a = audios[1].backupUrl[ae - audios[0].backupUrl.length - 2];
}
}
}
return [v, a];
}
/**
* @typedef {Object} Desc
* @property {Number} type 1 为普通文本 2 为 @ 用户
* @property {String} raw_text 文本
* @property {Number} biz_id type=2 时 @ 的用户id
*
* @typedef {Object} VideoInfo 视频信息
* @property {String} aid 视频id
* @property {String} bvid BV id
* @property {Number} cid 分P id
* @property {String} title 视频标题
* @property {String} pic 视频封面url
* @property {Number} pubdate 视频发布时间戳
* @property {Array<Desc>} desc_v2 视频简介
* @property {Object} owner 视频作者信息
* @property {Number} owner.mid 用户id
* @property {String} owner.name 昵称
* @property {String} owner.face 头像url
* @property {Object} pages 分P信息
* @property {Object} stat 视频统计信息
* @property {Number} stat.view 浏览量
* @property {Number} stat.like 点赞数
* @property {Number} stat.coin 投币数
* @property {Number} stat.favorite 收藏数
* @property {Number} stat.share 分享数
* @property {Number} stat.danmaku 弹幕数
* @property {Number} stat.reply 评论数
* @property {Number} stat.dislike 不喜欢数
* @property {Object} dimension 视频宽高
* @property {Number} dimension.width 视频宽度
* @property {Number} dimension.height 视频高度
* @property {Number} duration 视频时长 (s)
* @property {Number} timelength 视频时长 (ms)
* @property {Object} relation 是否点赞投币信息
* @property {Bool} relation.like 是否点赞
* @property {Number} relation.coin 投币数量
* @property {Bool} relation.favorite 是否点赞
* @property {Bool} relation.dislike 是否不喜欢
* @property {Bool} relation.attention
* @property {Object} subtitle 视频字幕信息
* @property {Object} dash 视频播放信息
* @property {Number} dash.duration 视频时长
* @property {Object} dash.video 视频信息
* @property {Object} dash.video 音频信息
* @property {Object} dash.support_formats 支持格式
* @property {Number} last_play_time 上次播放时长
*
* b站视频信息
* @param {String} aid
* @param {String} [cid]
* @return {Promise<VideoInfo>} 视频信息
*/
async function getInfo(aid, cid) {
aid = aid + '';
const params = {};
if (!aid.startsWith('BV') && !aid.startsWith('bv')) {
if (aid.startsWith('av') || aid.startsWith('AV')) {
aid = aid.substring(2);
}
params['aid'] = aid;
} else {
params['bvid'] = aid;
}
const r = await fetch('https://api.bilibili.com/x/web-interface/wbi/view?' + (new URLSearchParams(wbi(params))).toString(), {
credentials: 'include',
});
const res = await r.json();
const result = res.data;
cid = cid || result.cid;
if (!result) return;
result.relation = await getRelation(result.aid);
const playinfo = await getPlayUrl(result.bvid, cid);
result.dash = playinfo.dash;
result.timelength = playinfo.timelength;
result.support_formats = playinfo.support_formats;
const res1 = await getPlayerInfo(result.aid, cid);
if (res1) result.last_play_time = res1.last_play_time;
const urls = chooseQuality(result);
result.video_url = urls[0];
result.audio_url = urls[1];
return result;
}
async function _likeVideo(aid, like) {
const params = {
aid: aid,
like: like,
csrf: getCookie('bili_jct'),
}
const r = await fetch('https://api.bilibili.com/x/web-interface/archive/like?' + (new URLSearchParams(params)).toString(), {
method: 'POST',
credentials: 'include',
});
return await r.json();
}
async function likeVideo(aid) {
return await _likeVideo(aid, 1);
}
async function unlikeVideo(aid) {
return await _likeVideo(aid, 2);
}
async function shareVideo(aid) {
const params = {
aid: aid,
csrf: getCookie('bili_jct'),
eab_x: 2,
ramval: 0,
source: 'web_normal',
ga: 1
}
const r = await fetch('https://api.bilibili.com/x/web-interface/share/add?' + (new URLSearchParams(params)).toString(), {
method: 'POST',
credentials: 'include',
});
return await r.json();
}
/**
* 记录播放历史
* @param {Number} aid
* @param {Number} cid
* @param {Number} progress
* @returns
*/
async function record_history(aid, cid, progress) {
progress = parseInt(progress)
const r = await fetch('https://api.bilibili.com/x/v2/history/report', {
method: 'POST',
credentials: 'include',
withCredentials: true,
responseType: "arraybuffer",
body: new URLSearchParams({
aid: aid,
cid: cid,
csrf: getCookie('bili_jct'),
progress: progress,
platform: 'pc',
}),
headers: {
'content-type': 'application/x-www-form-urlencoded',
}
});
return await r.json();
}
async function get_danmaku(aid, cid, segment_index, time) {
const params = {
type: 1,
oid: cid,
pid: aid,
segment_index: segment_index + 1,
web_location: 1315873,
}
// if (segment_index == 0) {
// params['pull_mode'] = 1;
// params['ps'] = 0;
// params['pe'] = 120000;
// }
const r = await fetch('https://api.bilibili.com/x/v2/dm/web/seg.so?' + (new URLSearchParams(wbi(params))).toString(), {
credentials: 'include',
})
if (r.status != 200) {
return r;
}
try {
const res = await (r.clone()).json();
console.warn(`弹幕包 ${segment_index} 加载失败`)
return res;
} catch (e) {
return { code: 0, data: decodeDmSegMobileReply(new Uint8Array(await r.arrayBuffer())) };
}
}
class Player {
static instance
#video_url = '';
#audio_url = '';
#lastPauseTimer = null;
#danmaku_offset = 0;
#danmaku_rolls = [-1, -1, -1, -1, -1, -1, -1, -1];
#danmaku_tops = [-1, -1, -1, -1, -1, -1, -1, -1];
// 进度条被按下
progress_is_mousedown = false;
// 鼠标指向进度条 新时间
#newTime;
// 是否正在缓冲
waiting = false;
// 是否不显示正在缓冲
no_buffing = false;
// 鼠标不动计时器
leave_timer = null;
// 当前播放速率
currentRate = 1;
/**
* 视频播放器
* @constructor
* @author HBcao233
*/
constructor() {
// Singleton
if (Player.instance) {
return Player.instance;
}
Player.instance = this;
this.config = JSON.parse(window.localStorage.getItem('bpx_player_profile') || '{"media":{"volume":"1","nonzeroVol":"1","autoplay":true}}');
this.createElements();
if (isMobile()) {
this.playerElement.style.width = window.innerWidth;
this.playerElement.style.height = window.innerHeight;
this.videoElement.style.width = window.innerWidth;
this.videoElement.style.height = window.innerHeight;
}
this.progressElement = this.playerElement.querySelector('.bpx-player-progress');
this.canvas = tag('canvas');
this.videoElementPreview = tag('video', {
attrs: {
preload: "metadata",
crossOrigin: 'anonymous',
}
});
this.startListening();
}
createElements() {
this.playerElement = tag('div', {
id: 'bilibili-player',
children: [
tag('div', {
class: 'bpx-player-video-area', children: [
tag('div', {
class: 'bpx-player-video-wrap', children: [
(this.videoElement = tag('video', { attrs: { preload: 'auto' } })),
(this.audioElement = tag('audio', { attrs: { preload: 'auto' } })),
],
}),
tag('div', {
class: 'bpx-player-row-dm-wrap',
}),
tag('div', {
class: 'bpx-player-top-wrap', children: [
tag('div', {
class: 'bpx-player-top-left', children: [
tag('div', { class: 'bpx-player-top-left-title' }),
tag('div', {
class: 'bpx-player-follow', children: [
tag('img', { class: 'bpx-player-follow-face' }),
tag('span', { class: 'bpx-player-follow-text' }),
]
}),
]
})
]
}),
tag('div', {
class: 'bpx-player-state-wrap', children: [
tag('div', { class: 'bpx-player-state-play' }),
tag('div', {
class: 'bpx-player-state-buff-icon', children: tag('svg', {
attrs: { viewBox: '0 0 24 24' },
innerHTML: '<g transform="matrix(1,0,0,1,0,0)"><g transform="matrix(1,0,0,1,9.875,11.25)"opacity="1"style=""><g opacity="1"transform="matrix(1,0,0,1,-2.2850000858306885,2.7149999141693115)"><path fill="rgb(0,161,214)"fill-opacity="1"d=" M0,-1.4019999504089355 C-0.7739999890327454,-1.4019999504089355 -1.4019999504089355,-0.7739999890327454 -1.4019999504089355,0 C-1.4019999504089355,0.7739999890327454 -0.7739999890327454,1.4019999504089355 0,1.4019999504089355 C0.7739999890327454,1.4019999504089355 1.4019999504089355,0.7739999890327454 1.4019999504089355,0 C1.4019999504089355,-0.7739999890327454 0.7739999890327454,-1.4019999504089355 0,-1.4019999504089355z"></path><path stroke-linecap="butt"stroke-linejoin="miter"fill-opacity="0"stroke-miterlimit="4"stroke="rgb(69,69,69)"stroke-opacity="1"stroke-width="0"d=" M0,-1.4019999504089355 C-0.7739999890327454,-1.4019999504089355 -1.4019999504089355,-0.7739999890327454 -1.4019999504089355,0 C-1.4019999504089355,0.7739999890327454 -0.7739999890327454,1.4019999504089355 0,1.4019999504089355 C0.7739999890327454,1.4019999504089355 1.4019999504089355,0.7739999890327454 1.4019999504089355,0 C1.4019999504089355,-0.7739999890327454 0.7739999890327454,-1.4019999504089355 0,-1.4019999504089355z"></path></g></g><g transform="matrix(1,0,0,1,14.406000137329102,11.25)"opacity="1"><g opacity="1"transform="matrix(1,0,0,1,-2.2850000858306885,2.7149999141693115)"><path fill="rgb(0,161,214)"fill-opacity="1"d=" M0,-1.4019999504089355 C-0.7739999890327454,-1.4019999504089355 -1.4019999504089355,-0.7739999890327454 -1.4019999504089355,0 C-1.4019999504089355,0.7739999890327454 -0.7739999890327454,1.4019999504089355 0,1.4019999504089355 C0.7739999890327454,1.4019999504089355 1.4019999504089355,0.7739999890327454 1.4019999504089355,0 C1.4019999504089355,-0.7739999890327454 0.7739999890327454,-1.4019999504089355 0,-1.4019999504089355z"></path><path stroke-linecap="butt"stroke-linejoin="miter"fill-opacity="0"stroke-miterlimit="4"stroke="rgb(69,69,69)"stroke-opacity="1"stroke-width="0"d=" M0,-1.4019999504089355 C-0.7739999890327454,-1.4019999504089355 -1.4019999504089355,-0.7739999890327454 -1.4019999504089355,0 C-1.4019999504089355,0.7739999890327454 -0.7739999890327454,1.4019999504089355 0,1.4019999504089355 C0.7739999890327454,1.4019999504089355 1.4019999504089355,0.7739999890327454 1.4019999504089355,0 C1.4019999504089355,-0.7739999890327454 0.7739999890327454,-1.4019999504089355 0,-1.4019999504089355z"></path></g></g><g transform="matrix(1,0,0,1,19.0939998626709,11.25)"opacity="1"><g opacity="1"transform="matrix(1,0,0,1,-2.2850000858306885,2.7149999141693115)"><path fill="rgb(0,161,214)"fill-opacity="1"d=" M0,-1.4019999504089355 C-0.7739999890327454,-1.4019999504089355 -1.4019999504089355,-0.7739999890327454 -1.4019999504089355,0 C-1.4019999504089355,0.7739999890327454 -0.7739999890327454,1.4019999504089355 0,1.4019999504089355 C0.7739999890327454,1.4019999504089355 1.4019999504089355,0.7739999890327454 1.4019999504089355,0 C1.4019999504089355,-0.7739999890327454 0.7739999890327454,-1.4019999504089355 0,-1.4019999504089355z"></path><path stroke-linecap="butt"stroke-linejoin="miter"fill-opacity="0"stroke-miterlimit="4"stroke="rgb(69,69,69)"stroke-opacity="1"stroke-width="0"d=" M0,-1.4019999504089355 C-0.7739999890327454,-1.4019999504089355 -1.4019999504089355,-0.7739999890327454 -1.4019999504089355,0 C-1.4019999504089355,0.7739999890327454 -0.7739999890327454,1.4019999504089355 0,1.4019999504089355 C0.7739999890327454,1.4019999504089355 1.4019999504089355,0.7739999890327454 1.4019999504089355,0 C1.4019999504089355,-0.7739999890327454 0.7739999890327454,-1.4019999504089355 0,-1.4019999504089355z"></path></g></g></g><g><g transform="matrix(0.7071067690849304,0.7071067690849304,-0.7071067690849304,0.7071067690849304,9.609993934631348,8.918749809265137)"opacity="1"><g opacity="1"transform="matrix(1,0,0,1,-0.25999999046325684,-6.370999813079834)"><path fill="rgb(0,161,214)"fill-opacity="1"d=" M0,-3.388000011444092 C-0.40799999237060547,-3.388000011444092 -0.7390000224113464,-3.056999921798706 -0.7390000224113464,-2.6489999294281006 C-0.7390000224113464,-2.6489999294281006 -0.7390000224113464,2.6489999294281006 -0.7390000224113464,2.6489999294281006 C-0.7390000224113464,3.056999921798706 -0.40799999237060547,3.388000011444092 0,3.388000011444092 C0.40799999237060547,3.388000011444092 0.7390000224113464,3.056999921798706 0.7390000224113464,2.6489999294281006 C0.7390000224113464,2.6489999294281006 0.7390000224113464,-2.6489999294281006 0.7390000224113464,-2.6489999294281006 C0.7390000224113464,-3.056999921798706 0.40799999237060547,-3.388000011444092 0,-3.388000011444092z"></path><path stroke-linecap="butt"stroke-linejoin="miter"fill-opacity="0"stroke-miterlimit="4"stroke="rgb(69,69,69)"stroke-opacity="1"stroke-width="0"d=" M0,-3.388000011444092 C-0.40799999237060547,-3.388000011444092 -0.7390000224113464,-3.056999921798706 -0.7390000224113464,-2.6489999294281006 C-0.7390000224113464,-2.6489999294281006 -0.7390000224113464,2.6489999294281006 -0.7390000224113464,2.6489999294281006 C-0.7390000224113464,3.056999921798706 -0.40799999237060547,3.388000011444092 0,3.388000011444092 C0.40799999237060547,3.388000011444092 0.7390000224113464,3.056999921798706 0.7390000224113464,2.6489999294281006 C0.7390000224113464,2.6489999294281006 0.7390000224113464,-2.6489999294281006 0.7390000224113464,-2.6489999294281006 C0.7390000224113464,-3.056999921798706 0.40799999237060547,-3.388000011444092 0,-3.388000011444092z"></path></g></g><g transform="matrix(0.9840099811553955,0,0,1.070970058441162,12,13.75)"opacity="1"><g opacity="1"transform="matrix(1,0,0,1,0,0)"><path fill="rgb(11,163,149)"fill-opacity="0"d=" M-0.05000000074505806,-6.757999897003174 C-0.05000000074505806,-6.757999897003174 -3.0820000171661377,-6.72599983215332 -6.130000114440918,-6.72599983215332 C-9.178000450134277,-6.72599983215332 -10.121000289916992,-4.785999774932861 -10.121000289916992,-2.5850000381469727 C-10.121000289916992,-0.5540000200271606 -10.13700008392334,1.4800000190734863 -10.13700008392334,3.078000068664551 C-10.13700008392334,5.164999961853027 -9.178000450134277,6.815999984741211 -6.1620001792907715,6.815999984741211 C-4.13100004196167,6.815999984741211 3.609999895095825,6.822000026702881 6.0920000076293945,6.822000026702881 C9.145999908447266,6.822000026702881 10.270000457763672,5.164999961853027 10.270000457763672,3.072999954223633 C10.270000457763672,1.1979999542236328 10.28499984741211,-0.8349999785423279 10.28499984741211,-2.634999990463257 C10.28499984741211,-4.784999847412109 9.145999908447266,-6.7179999351501465 6.091000080108643,-6.7179999351501465 C4.247000217437744,-6.7179999351501465 -0.05000000074505806,-6.757999897003174 -0.05000000074505806,-6.757999897003174z"></path><path stroke-linecap="round"stroke-linejoin="round"fill-opacity="0"stroke="rgb(0,161,214)"stroke-opacity="1"stroke-width="1.5"d=" M-0.05000000074505806,-6.757999897003174 C-0.05000000074505806,-6.757999897003174 -3.0820000171661377,-6.72599983215332 -6.130000114440918,-6.72599983215332 C-9.178000450134277,-6.72599983215332 -10.121000289916992,-4.785999774932861 -10.121000289916992,-2.5850000381469727 C-10.121000289916992,-0.5540000200271606 -10.13700008392334,1.4800000190734863 -10.13700008392334,3.078000068664551 C-10.13700008392334,5.164999961853027 -9.178000450134277,6.815999984741211 -6.1620001792907715,6.815999984741211 C-4.13100004196167,6.815999984741211 3.609999895095825,6.822000026702881 6.0920000076293945,6.822000026702881 C9.145999908447266,6.822000026702881 10.270000457763672,5.164999961853027 10.270000457763672,3.072999954223633 C10.270000457763672,1.1979999542236328 10.28499984741211,-0.8349999785423279 10.28499984741211,-2.634999990463257 C10.28499984741211,-4.784999847412109 9.145999908447266,-6.7179999351501465 6.091000080108643,-6.7179999351501465 C4.247000217437744,-6.7179999351501465 -0.05000000074505806,-6.757999897003174 -0.05000000074505806,-6.757999897003174z"></path></g></g><g transform="matrix(0.7071067690849304,-0.7071067690849304,0.7071067690849304,0.7071067690849304,14.453581809997559,8.441146850585938)"opacity="1"><g opacity="1"transform="matrix(1,0,0,1,-0.25999999046325684,-6.370999813079834)"><path fill="rgb(0,161,214)"fill-opacity="1"d=" M0,-3.388000011444092 C-0.40799999237060547,-3.388000011444092 -0.7390000224113464,-3.056999921798706 -0.7390000224113464,-2.6489999294281006 C-0.7390000224113464,-2.6489999294281006 -0.7390000224113464,2.6489999294281006 -0.7390000224113464,2.6489999294281006 C-0.7390000224113464,3.056999921798706 -0.40799999237060547,3.388000011444092 0,3.388000011444092 C0.40799999237060547,3.388000011444092 0.7390000224113464,3.056999921798706 0.7390000224113464,2.6489999294281006 C0.7390000224113464,2.6489999294281006 0.7390000224113464,-2.6489999294281006 0.7390000224113464,-2.6489999294281006 C0.7390000224113464,-3.056999921798706 0.40799999237060547,-3.388000011444092 0,-3.388000011444092z"></path><path stroke-linecap="butt"stroke-linejoin="miter"fill-opacity="0"stroke-miterlimit="4"stroke="rgb(69,69,69)"stroke-opacity="1"stroke-width="0"d=" M0,-3.388000011444092 C-0.40799999237060547,-3.388000011444092 -0.7390000224113464,-3.056999921798706 -0.7390000224113464,-2.6489999294281006 C-0.7390000224113464,-2.6489999294281006 -0.7390000224113464,2.6489999294281006 -0.7390000224113464,2.6489999294281006 C-0.7390000224113464,3.056999921798706 -0.40799999237060547,3.388000011444092 0,3.388000011444092 C0.40799999237060547,3.388000011444092 0.7390000224113464,3.056999921798706 0.7390000224113464,2.6489999294281006 C0.7390000224113464,2.6489999294281006 0.7390000224113464,-2.6489999294281006 0.7390000224113464,-2.6489999294281006 C0.7390000224113464,-3.056999921798706 0.40799999237060547,-3.388000011444092 0,-3.388000011444092z"></path></g></g></g>'
})
}),
tag('div', {
class: 'bpx-player-state-buff-text', children: [
tag('span', { class: 'title', innerHTML: '正在缓冲...' }),
tag('span', { class: 'speed' }),
]
})
]
}),
tag('div', {
class: 'bpx-player-loading-panel bpx-state-loading', children: tag('div', {
class: 'bpx-player-loading-panel-blur',
children: tag('div', { class: 'bpx-player-loading-panel-blur-detail' }),
})
}),
tag('div', {
class: 'bpx-player-control', children: [
tag('div', { class: 'bpx-player-control-mask' }),
tag('div', {
class: 'bpx-player-control-top',
children: [
tag('div', {
class: 'bpx-player-progress',
children: [
tag('div', {
class: 'schedule', children: [
tag('div', { class: 'buffer' }),
tag('div', { class: 'current' })
]
}),
tag('div', {
class: 'thumb',
children: tag('div', {
class: 'thumb-icon',
}, (t) => {
const opts = {
container: t,
renderer: "svg",
loop: true,
autoplay: true,
}
if (player_icon.url2) {
opts.path = player_icon.url2;
} else {
opts.animationData = player_icon.animationData;
}
const animation = lottie.loadAnimation(opts);
animation.addEventListener('DOMLoaded', () => {
if (opts.path) {
t.parentNode.style.width = '28px';
t.parentNode.style.height = '28px';
}
})
})
}),
tag('div', {
class: 'move-indicator',
style: 'left: 0',
children: [
tag('div', { class: 'down' }),
tag('div', { class: 'up' })
]
}),
tag('div', {
class: 'popup',
style: 'left: 0',
children: [
tag('div', {
class: 'preview', children: [
tag('img', { class: 'preview-image' }),
tag('div', { class: 'preview-time' })
]
}),
]
}),
]
}),
]
}),
tag('div', {
class: 'bpx-player-control-bottom',
children: [
tag('div', {
class: 'bpx-player-control-bottom-left',
children: [
/**
* 上一个
*/
tag('div', {
class: 'previous control-btn',
attrs: { 'aria-label': '上一个' },
children: tag('div', {
class: 'icon',
style: 'transform: rotate(180deg);',
children: [
tag('svg', {
attrs: { viewBox: '0 0 22 22' },
innerHTML: '<path d="M16 5a1 1 0 0 0-1 1v4.615a1.431 1.431 0 0 0-.615-.829L7.21 5.23A1.439 1.439 0 0 0 5 6.445v9.11a1.44 1.44 0 0 0 2.21 1.215l7.175-4.555a1.436 1.436 0 0 0 .616-.828V16a1 1 0 0 0 2 0V6C17 5.448 16.552 5 16 5z"></path>'
}),
]
})
}, (t) => t.addEventListener('click', previousVideo)),
/**
* 播放/暂停
*/
tag('div', {
class: 'play control-btn',
attrs: { 'aria-label': '播放/暂停' },
children: tag('div', {
class: 'icon', children: [
tag('svg', {
attrs: { viewBox: '0 0 28 28' },
innerHTML: '<defs><clipPath id="__lottie_element_873"><rect width="28" height="28" x="0" y="0"></rect></clipPath></defs><g clip-path="url(#__lottie_element_873)"><g style="display: block;" transform="matrix(1,0,0,1,14,14)" opacity="1"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill-opacity="1" d=" M-5.484000205993652,-10 C-7.953000068664551,-10 -8,-7.984000205993652 -8,-7.984000205993652 C-8,-7.984000205993652 -8.008000373840332,7.984000205993652 -8.008000373840332,7.984000205993652 C-8.008000373840332,7.984000205993652 -7.984000205993652,9.991999626159668 -5.5,9.991999626159668 C-3.0160000324249268,9.991999626159668 -3.003999948501587,7.995999813079834 -3.003999948501587,7.995999813079834 C-3.003999948501587,7.995999813079834 -2.9839999675750732,-8 -2.9839999675750732,-8 C-2.9839999675750732,-8 -3.015000104904175,-10 -5.484000205993652,-10z"></path><path stroke-linecap="butt" stroke-linejoin="miter" fill-opacity="0" stroke-miterlimit="4" stroke="rgb(255,255,255)" stroke-opacity="1" stroke-width="0" d=" M-5.484000205993652,-10 C-7.953000068664551,-10 -8,-7.984000205993652 -8,-7.984000205993652 C-8,-7.984000205993652 -8.008000373840332,7.984000205993652 -8.008000373840332,7.984000205993652 C-8.008000373840332,7.984000205993652 -7.984000205993652,9.991999626159668 -5.5,9.991999626159668 C-3.0160000324249268,9.991999626159668 -3.003999948501587,7.995999813079834 -3.003999948501587,7.995999813079834 C-3.003999948501587,7.995999813079834 -2.9839999675750732,-8 -2.9839999675750732,-8 C-2.9839999675750732,-8 -3.015000104904175,-10 -5.484000205993652,-10z"></path></g></g><g style="display: block;" transform="matrix(1,0,0,1,24.812000274658203,14)" opacity="1"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill-opacity="1" d=" M-5.484000205993652,-10 C-7.953000068664551,-10 -8,-7.984000205993652 -8,-7.984000205993652 C-8,-7.984000205993652 -8.008000373840332,7.984000205993652 -8.008000373840332,7.984000205993652 C-8.008000373840332,7.984000205993652 -7.984000205993652,9.991999626159668 -5.5,9.991999626159668 C-3.0160000324249268,9.991999626159668 -3.003999948501587,7.995999813079834 -3.003999948501587,7.995999813079834 C-3.003999948501587,7.995999813079834 -2.9839999675750732,-8 -2.9839999675750732,-8 C-2.9839999675750732,-8 -3.015000104904175,-10 -5.484000205993652,-10z"></path><path stroke-linecap="butt" stroke-linejoin="miter" fill-opacity="0" stroke-miterlimit="4" stroke="rgb(255,255,255)" stroke-opacity="1" stroke-width="0" d=" M-5.484000205993652,-10 C-7.953000068664551,-10 -8,-7.984000205993652 -8,-7.984000205993652 C-8,-7.984000205993652 -8.008000373840332,7.984000205993652 -8.008000373840332,7.984000205993652 C-8.008000373840332,7.984000205993652 -7.984000205993652,9.991999626159668 -5.5,9.991999626159668 C-3.0160000324249268,9.991999626159668 -3.003999948501587,7.995999813079834 -3.003999948501587,7.995999813079834 C-3.003999948501587,7.995999813079834 -2.9839999675750732,-8 -2.9839999675750732,-8 C-2.9839999675750732,-8 -3.015000104904175,-10 -5.484000205993652,-10z"></path></g></g><g transform="matrix(1,0,0,1,6.69746208190918,14)" opacity="0.0008731750582263942" style="display: none;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill-opacity="1" d="M0 0"></path><path stroke-linecap="butt" stroke-linejoin="miter" fill-opacity="0" stroke-miterlimit="4" stroke="rgb(255,255,255)" stroke-opacity="1" stroke-width="0" d="M0 0"></path></g><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill-opacity="1" d=" M-7.031000137329102,-10.875 C-7.031000137329102,-10.875 -8.32800006866455,-11.25 -9.42199993133545,-10.468999862670898 C-10.109999656677246,-9.906999588012695 -10,-7.992000102996826 -10,-7.992000102996826 C-10,-7.992000102996826 -10,8.015999794006348 -10,8.015999794006348 C-10,8.015999794006348 -10.125,10.241999626159668 -9,10.991999626159668 C-7.875,11.741999626159668 -5,10.031000137329102 -5,10.031000137329102 C-5,10.031000137329102 7.968999862670898,1.875 7.968999862670898,1.875 C7.968999862670898,1.875 9,1.062000036239624 9,0 C9,-1.062000036239624 7.968999862670898,-1.937999963760376 7.968999862670898,-1.937999963760376 C7.968999862670898,-1.937999963760376 -7.031000137329102,-10.875 -7.031000137329102,-10.875z"></path><path stroke-linecap="butt" stroke-linejoin="miter" fill-opacity="0" stroke-miterlimit="4" stroke="rgb(255,255,255)" stroke-opacity="1" stroke-width="0" d=" M-7.031000137329102,-10.875 C-7.031000137329102,-10.875 -8.32800006866455,-11.25 -9.42199993133545,-10.468999862670898 C-10.109999656677246,-9.906999588012695 -10,-7.992000102996826 -10,-7.992000102996826 C-10,-7.992000102996826 -10,8.015999794006348 -10,8.015999794006348 C-10,8.015999794006348 -10.125,10.241999626159668 -9,10.991999626159668 C-7.875,11.741999626159668 -5,10.031000137329102 -5,10.031000137329102 C-5,10.031000137329102 7.968999862670898,1.875 7.968999862670898,1.875 C7.968999862670898,1.875 9,1.062000036239624 9,0 C9,-1.062000036239624 7.968999862670898,-1.937999963760376 7.968999862670898,-1.937999963760376 C7.968999862670898,-1.937999963760376 -7.031000137329102,-10.875 -7.031000137329102,-10.875z"></path></g></g></g>'
}),
tag('svg', {
attrs: { viewBox: '0 0 28 28' },
innerHTML: '<defs><clipPath id="__lottie_element_818"><rect width="28" height="28" x="0" y="0"></rect></clipPath></defs><g clip-path="url(#__lottie_element_818)"><g transform="matrix(0.22383984923362732,0,0,0.22383984923362732,20.641138076782227,14.097020149230957)" opacity="0.002394794788598773" style="display: none;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill-opacity="1" d=" M-5.484000205993652,-10 C-7.953000068664551,-10 -8,-7.984000205993652 -8,-7.984000205993652 C-8,-7.984000205993652 -8.008000373840332,7.984000205993652 -8.008000373840332,7.984000205993652 C-8.008000373840332,7.984000205993652 -7.984000205993652,9.991999626159668 -5.5,9.991999626159668 C-3.0160000324249268,9.991999626159668 -3.003999948501587,7.995999813079834 -3.003999948501587,7.995999813079834 C-3.003999948501587,7.995999813079834 -2.9839999675750732,-8 -2.9839999675750732,-8 C-2.9839999675750732,-8 -3.015000104904175,-10 -5.484000205993652,-10z"></path><path stroke-linecap="butt" stroke-linejoin="miter" fill-opacity="0" stroke-miterlimit="4" stroke="rgb(255,255,255)" stroke-opacity="1" stroke-width="0" d=" M-5.484000205993652,-10 C-7.953000068664551,-10 -8,-7.984000205993652 -8,-7.984000205993652 C-8,-7.984000205993652 -8.008000373840332,7.984000205993652 -8.008000373840332,7.984000205993652 C-8.008000373840332,7.984000205993652 -7.984000205993652,9.991999626159668 -5.5,9.991999626159668 C-3.0160000324249268,9.991999626159668 -3.003999948501587,7.995999813079834 -3.003999948501587,7.995999813079834 C-3.003999948501587,7.995999813079834 -2.9839999675750732,-8 -2.9839999675750732,-8 C-2.9839999675750732,-8 -3.015000104904175,-10 -5.484000205993652,-10z"></path></g></g><g transform="matrix(0.6509166955947876,0,0,0.6509166955947876,22.417274475097656,14)" opacity="0.0024594099834516214" style="display: none;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill-opacity="1" d=" M-5.484000205993652,-10 C-7.953000068664551,-10 -8,-7.984000205993652 -8,-7.984000205993652 C-8,-7.984000205993652 -8.008000373840332,7.984000205993652 -8.008000373840332,7.984000205993652 C-8.008000373840332,7.984000205993652 -7.984000205993652,9.991999626159668 -5.5,9.991999626159668 C-3.0160000324249268,9.991999626159668 -3.003999948501587,7.995999813079834 -3.003999948501587,7.995999813079834 C-3.003999948501587,7.995999813079834 -2.9839999675750732,-8 -2.9839999675750732,-8 C-2.9839999675750732,-8 -3.015000104904175,-10 -5.484000205993652,-10z"></path><path stroke-linecap="butt" stroke-linejoin="miter" fill-opacity="0" stroke-miterlimit="4" stroke="rgb(255,255,255)" stroke-opacity="1" stroke-width="0" d=" M-5.484000205993652,-10 C-7.953000068664551,-10 -8,-7.984000205993652 -8,-7.984000205993652 C-8,-7.984000205993652 -8.008000373840332,7.984000205993652 -8.008000373840332,7.984000205993652 C-8.008000373840332,7.984000205993652 -7.984000205993652,9.991999626159668 -5.5,9.991999626159668 C-3.0160000324249268,9.991999626159668 -3.003999948501587,7.995999813079834 -3.003999948501587,7.995999813079834 C-3.003999948501587,7.995999813079834 -2.9839999675750732,-8 -2.9839999675750732,-8 C-2.9839999675750732,-8 -3.015000104904175,-10 -5.484000205993652,-10z"></path></g></g><g style="display: block;" transform="matrix(1,0,0,1,14,14)" opacity="1"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill-opacity="1" d="M0 0"></path><path stroke-linecap="butt" stroke-linejoin="miter" fill-opacity="0" stroke-miterlimit="4" stroke="rgb(255,255,255)" stroke-opacity="1" stroke-width="0" d="M0 0"></path></g><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill-opacity="1" d=" M-7.031000137329102,-10.875 C-7.031000137329102,-10.875 -8.32800006866455,-11.25 -9.42199993133545,-10.468999862670898 C-10.109999656677246,-9.906999588012695 -10,-7.992000102996826 -10,-7.992000102996826 C-10,-7.992000102996826 -10,8.015999794006348 -10,8.015999794006348 C-10,8.015999794006348 -10.125,10.241999626159668 -9,10.991999626159668 C-7.875,11.741999626159668 -5,10.031000137329102 -5,10.031000137329102 C-5,10.031000137329102 7.968999862670898,1.875 7.968999862670898,1.875 C7.968999862670898,1.875 9,1.062000036239624 9,0 C9,-1.062000036239624 7.968999862670898,-1.937999963760376 7.968999862670898,-1.937999963760376 C7.968999862670898,-1.937999963760376 -7.031000137329102,-10.875 -7.031000137329102,-10.875z"></path><path stroke-linecap="butt" stroke-linejoin="miter" fill-opacity="0" stroke-miterlimit="4" stroke="rgb(255,255,255)" stroke-opacity="1" stroke-width="0" d=" M-7.031000137329102,-10.875 C-7.031000137329102,-10.875 -8.32800006866455,-11.25 -9.42199993133545,-10.468999862670898 C-10.109999656677246,-9.906999588012695 -10,-7.992000102996826 -10,-7.992000102996826 C-10,-7.992000102996826 -10,8.015999794006348 -10,8.015999794006348 C-10,8.015999794006348 -10.125,10.241999626159668 -9,10.991999626159668 C-7.875,11.741999626159668 -5,10.031000137329102 -5,10.031000137329102 C-5,10.031000137329102 7.968999862670898,1.875 7.968999862670898,1.875 C7.968999862670898,1.875 9,1.062000036239624 9,0 C9,-1.062000036239624 7.968999862670898,-1.937999963760376 7.968999862670898,-1.937999963760376 C7.968999862670898,-1.937999963760376 -7.031000137329102,-10.875 -7.031000137329102,-10.875z"></path></g></g></g>'
}),
]
})
}),
/**
* 下一个
*/
tag('div', {
class: 'next control-btn',
attrs: { 'aria-label': '下一个' },
children: tag('div', {
class: 'icon', children: tag('svg', {
attrs: { viewBox: '0 0 22 22' },
innerHTML: '<path d="M16 5a1 1 0 0 0-1 1v4.615a1.431 1.431 0 0 0-.615-.829L7.21 5.23A1.439 1.439 0 0 0 5 6.445v9.11a1.44 1.44 0 0 0 2.21 1.215l7.175-4.555a1.436 1.436 0 0 0 .616-.828V16a1 1 0 0 0 2 0V6C17 5.448 16.552 5 16 5z"></path>'
})
})
}, (t) => t.addEventListener('click', nextVideo)),
/**
* 时间显示
*/
tag('div', {
class: 'time control-btn',
children: [
tag('input', {
class: 'seek', style: 'display: none',
}),
tag('div', {
class: 'label', children: [
tag('span', { class: 'current', innerHTML: '00:00' }),
tag('span', { class: 'divide', innerHTML: '/' }),
tag('span', { class: 'duration', innerHTML: '00:00' }),
]
})
]
}),
]
}),
tag('div', {
class: 'bpx-player-control-bottom-right',
children: [
/**
* 倍速
*/
tag('div', {
class: 'playbackrate control-btn',
attrs: { 'aria-label': '倍速' },
children: [
tag('div', { class: 'text', innerText: '倍速' }),
tag('ul', {
class: 'playbackrate-menu',
children: [2, 1.5, 1.25, 1, 0.75, 0.5].map(i => tag('li', {
class: 'item' + (i === 1 ? ' active' : ''),
attrs: { 'data-value': i },
innerText: i + 'x',
}))
}),
]
}, (t) => {
let idx;
t.addEventListener('mouseenter', () => {
clearTimeout(idx);
t.classList.add('hover');
})
t.addEventListener('mouseleave', () => {
idx = setTimeout(() => { t.classList.remove('hover') }, 200);
})
t.addEventListener('click', (e) => {
if (e.target.closest('.playbackrate-menu .item')) {
const x = e.target.getAttribute('data-value');
if (x < 0) return;
this.playbackRate = parseFloat(x);
this.currentRate = parseFloat(x);
for (const i of t.querySelectorAll('.playbackrate-menu .item')) {
i.classList.remove('active');
}
e.target.classList.add('active');
t.querySelector('.text').innerText = (x === '1' ? '倍速' : x + 'x');
}
});
}),
/**
* 音量
*/
tag('div', {
class: 'volume control-btn',
attrs: { 'aria-label': '音量' },
children: [
tag('div', {
class: 'icon volume-icon',
children: tag('svg', {
attrs: { viewBox: '0 0 88 88' },
innerHTML: '<g clip-path="url(#__lottie_element_745)"><g clip-path="url(#__lottie_element_747)" transform="matrix(1,0,0,1,0,0)" opacity="1" style="display: block;"><g transform="matrix(1,0,0,1,28,44)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M15.5600004196167,-25.089000701904297 C15.850000381469727,-24.729000091552734 16,-24.288999557495117 16,-23.839000701904297 C16,-23.839000701904297 16,23.840999603271484 16,23.840999603271484 C16,24.94099998474121 15.100000381469727,25.840999603271484 14,25.840999603271484 C13.550000190734863,25.840999603271484 13.109999656677246,25.680999755859375 12.75,25.400999069213867 C12.75,25.400999069213867 -4,12.00100040435791 -4,12.00100040435791 C-4,12.00100040435791 -8,12.00100040435791 -8,12.00100040435791 C-12.420000076293945,12.00100040435791 -16,8.420999526977539 -16,4.000999927520752 C-16,4.000999927520752 -16,-3.999000072479248 -16,-3.999000072479248 C-16,-8.418999671936035 -12.420000076293945,-11.99899959564209 -8,-11.99899959564209 C-8,-11.99899959564209 -4,-11.99899959564209 -4,-11.99899959564209 C-4,-11.99899959564209 12.75,-25.39900016784668 12.75,-25.39900016784668 C13.609999656677246,-26.089000701904297 14.869999885559082,-25.948999404907227 15.5600004196167,-25.089000701904297z"></path></g></g><g style="display: none;" transform="matrix(1.005157470703125,0,0,1.005157470703125,56.00225067138672,44.0004997253418)" opacity="0.194217437118555"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M-4,-13.859000205993652 C0.7799999713897705,-11.08899974822998 4,-5.919000148773193 4,0.0010000000474974513 C4,5.921000003814697 0.7799999713897705,11.090999603271484 -4,13.861000061035156 C-4,13.861000061035156 -4,-13.859000205993652 -4,-13.859000205993652z"></path></g></g><g style="display: none;" transform="matrix(1.0126574039459229,0,0,1.0126574039459229,64.37825012207031,44.0057487487793)" opacity="0.002830605068398171"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M-6.236000061035156,-28.895999908447266 C4.803999900817871,-23.615999221801758 11.984000205993652,-12.456000328063965 11.984000205993652,-0.006000000052154064 C11.984000205993652,12.454000473022461 4.794000148773193,23.624000549316406 -6.265999794006348,28.893999099731445 C-8.255999565124512,29.8439998626709 -10.645999908447266,29.003999710083008 -11.595999717712402,27.003999710083008 C-12.545999526977539,25.013999938964844 -11.696000099182129,22.624000549316406 -9.706000328063965,21.673999786376953 C-1.406000018119812,17.724000930786133 3.9839999675750732,9.343999862670898 3.9839999675750732,-0.006000000052154064 C3.9839999675750732,-9.345999717712402 -1.3960000276565552,-17.715999603271484 -9.675999641418457,-21.676000595092773 C-11.675999641418457,-22.625999450683594 -12.515999794006348,-25.016000747680664 -11.565999984741211,-27.006000518798828 C-10.616000175476074,-29.006000518798828 -8.22599983215332,-29.84600067138672 -6.236000061035156,-28.895999908447266z"></path></g></g><g style="display: none;" transform="matrix(1.0002121925354004,0,0,1.0002121925354004,56.00299072265625,44)" opacity="1"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M-4,-13.859000205993652 C0.7799999713897705,-11.08899974822998 4,-5.919000148773193 4,0.0010000000474974513 C4,5.921000003814697 0.7799999713897705,11.090999603271484 -4,13.861000061035156 C-4,13.861000061035156 -4,-13.859000205993652 -4,-13.859000205993652z"></path></g></g><g style="display: none;" transform="matrix(1.0002012252807617,0,0,1.0002012252807617,64.00399780273438,44.00699996948242)" opacity="1"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M-6.236000061035156,-28.895999908447266 C4.803999900817871,-23.615999221801758 11.984000205993652,-12.456000328063965 11.984000205993652,-0.006000000052154064 C11.984000205993652,12.454000473022461 4.794000148773193,23.624000549316406 -6.265999794006348,28.893999099731445 C-8.255999565124512,29.8439998626709 -10.645999908447266,29.003999710083008 -11.595999717712402,27.003999710083008 C-12.545999526977539,25.013999938964844 -11.696000099182129,22.624000549316406 -9.706000328063965,21.673999786376953 C-1.406000018119812,17.724000930786133 3.9839999675750732,9.343999862670898 3.9839999675750732,-0.006000000052154064 C3.9839999675750732,-9.345999717712402 -1.3960000276565552,-17.715999603271484 -9.675999641418457,-21.676000595092773 C-11.675999641418457,-22.625999450683594 -12.515999794006348,-25.016000747680664 -11.565999984741211,-27.006000518798828 C-10.616000175476074,-29.006000518798828 -8.22599983215332,-29.84600067138672 -6.236000061035156,-28.895999908447266z"></path></g></g><g transform="matrix(1,0,0,1,56,44)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M-4,-13.859000205993652 C0.7799999713897705,-11.08899974822998 4,-5.919000148773193 4,0.0010000000474974513 C4,5.921000003814697 0.7799999713897705,11.090999603271484 -4,13.861000061035156 C-4,13.861000061035156 -4,-13.859000205993652 -4,-13.859000205993652z"></path></g></g><g transform="matrix(1,0,0,1,64.01399993896484,44.00699996948242)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M-6.236000061035156,-28.895999908447266 C4.803999900817871,-23.615999221801758 11.984000205993652,-12.456000328063965 11.984000205993652,-0.006000000052154064 C11.984000205993652,12.454000473022461 4.794000148773193,23.624000549316406 -6.265999794006348,28.893999099731445 C-8.255999565124512,29.8439998626709 -10.645999908447266,29.003999710083008 -11.595999717712402,27.003999710083008 C-12.545999526977539,25.013999938964844 -11.696000099182129,22.624000549316406 -9.706000328063965,21.673999786376953 C-1.406000018119812,17.724000930786133 3.9839999675750732,9.343999862670898 3.9839999675750732,-0.006000000052154064 C3.9839999675750732,-9.345999717712402 -1.3960000276565552,-17.715999603271484 -9.675999641418457,-21.676000595092773 C-11.675999641418457,-22.625999450683594 -12.515999794006348,-25.016000747680664 -11.565999984741211,-27.006000518798828 C-10.616000175476074,-29.006000518798828 -8.22599983215332,-29.84600067138672 -6.236000061035156,-28.895999908447266z"></path></g></g></g></g>'
})
}),
tag('div', {
class: 'icon muted-icon',
style: 'display: none',
children: tag('svg', {
attrs: { viewBox: '0 0 88 88' },
innerHTML: '<g clip-path="url(#__lottie_element_773)"><g mask="url(#__lottie_element_777)" style="display: block;"><g transform="matrix(1,0,0,1,44,44)" opacity="1"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M-0.4399999976158142,-25.09600067138672 C-0.15000000596046448,-24.736000061035156 0,-24.29599952697754 0,-23.84600067138672 C0,-23.84600067138672 0,23.833999633789062 0,23.833999633789062 C0,24.93400001525879 -0.8999999761581421,25.833999633789062 -2,25.833999633789062 C-2.450000047683716,25.833999633789062 -2.890000104904175,25.673999786376953 -3.25,25.393999099731445 C-3.25,25.393999099731445 -20,11.994000434875488 -20,11.994000434875488 C-20,11.994000434875488 -24,11.994000434875488 -24,11.994000434875488 C-28.420000076293945,11.994000434875488 -32,8.413999557495117 -32,3.99399995803833 C-32,3.99399995803833 -32,-4.00600004196167 -32,-4.00600004196167 C-32,-8.425999641418457 -28.420000076293945,-12.005999565124512 -24,-12.005999565124512 C-24,-12.005999565124512 -20,-12.005999565124512 -20,-12.005999565124512 C-20,-12.005999565124512 -3.25,-25.4060001373291 -3.25,-25.4060001373291 C-2.390000104904175,-26.09600067138672 -1.1299999952316284,-25.95599937438965 -0.4399999976158142,-25.09600067138672z M13.777999877929688,-28.895999908447266 C24.81800079345703,-23.615999221801758 31.99799919128418,-12.456000328063965 31.99799919128418,-0.006000000052154064 C31.99799919128418,12.454000473022461 24.808000564575195,23.624000549316406 13.748000144958496,28.893999099731445 C11.758000373840332,29.8439998626709 9.368000030517578,29.003999710083008 8.418000221252441,27.003999710083008 C7.4679999351501465,25.013999938964844 8.317999839782715,22.624000549316406 10.307999610900879,21.673999786376953 C18.607999801635742,17.724000930786133 23.99799919128418,9.343999862670898 23.99799919128418,-0.006000000052154064 C23.99799919128418,-9.345999717712402 18.618000030517578,-17.715999603271484 10.338000297546387,-21.676000595092773 C8.338000297546387,-22.625999450683594 7.498000144958496,-25.016000747680664 8.447999954223633,-27.006000518798828 C9.39799976348877,-29.006000518798828 11.788000106811523,-29.84600067138672 13.777999877929688,-28.895999908447266z M8,-13.866000175476074 C12.779999732971191,-11.095999717712402 16,-5.926000118255615 16,-0.006000000052154064 C16,5.914000034332275 12.779999732971191,11.083999633789062 8,13.854000091552734 C8,13.854000091552734 8,-13.866000175476074 8,-13.866000175476074z"></path></g></g></g><g transform="matrix(1,0,0,1,41.172000885009766,46.827999114990234)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,-0.5,-0.5)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M-33.94157409667969,-28.281574249267578 C-35.50258255004883,-29.84258270263672 -35.50258255004883,-32.377418518066406 -33.94157409667969,-33.93842697143555 C-33.94157409667969,-33.93842697143555 -33.93842697143555,-33.94157409667969 -33.93842697143555,-33.94157409667969 C-32.377418518066406,-35.50258255004883 -29.84258270263672,-35.50258255004883 -28.281574249267578,-33.94157409667969 C-28.281574249267578,-33.94157409667969 33.94157409667969,28.281574249267578 33.94157409667969,28.281574249267578 C35.50258255004883,29.84258270263672 35.50258255004883,32.377418518066406 33.94157409667969,33.93842697143555 C33.94157409667969,33.93842697143555 33.93842697143555,33.94157409667969 33.93842697143555,33.94157409667969 C32.377418518066406,35.50258255004883 29.84258270263672,35.50258255004883 28.281574249267578,33.94157409667969 C28.281574249267578,33.94157409667969 -33.94157409667969,-28.281574249267578 -33.94157409667969,-28.281574249267578z"></path></g></g></g>'
})
}),
tag('div', {
class: 'volume-box',
children: [
tag('div', {
class: 'volume-number',
innerText: '100',
}),
tag('div', {
class: 'volume-slider',
children: tag('div', {
class: 'track', children: [
tag('div', { class: 'bar-wrap', children: tag('div', { class: 'bar' }) }),
tag('div', { class: 'thumb', children: tag('div', { class: 'thumb-dot' }) }),
]
})
})
]
})
]
}, (t) => {
let idx;
let slider_mousedown = false;
const mouseleave = () => { if (!slider_mousedown) t.classList.remove('hover') };
const slider = t.querySelector('.volume-slider');
const sliderUpdateVolume = (x) => {
if (x > 0 && x <= 1) {
t.querySelector('.volume-icon').style.display = 'block';
t.querySelector('.muted-icon').style.display = 'none';
t.querySelector('.volume-slider .bar-wrap .bar').style.transform = 'translateY(' + (1 - x) * slider.clientHeight + 'px)';
t.querySelector('.volume-slider .thumb').style.transform = 'translateY(' + (1 - x) * slider.clientHeight + 'px)';
t.querySelector('.volume-number').innerHTML = Math.round(x * 100);
} else if (x <= 0) {
t.querySelector('.volume-icon').style.display = 'none';
t.querySelector('.muted-icon').style.display = 'block';
t.querySelector('.volume-slider .bar-wrap .bar').style.transform = 'translateY(' + slider.clientHeight + 'px)';
t.querySelector('.volume-slider .thumb').style.transform = 'translateY(' + slider.clientHeight + 'px)';
t.querySelector('.volume-number').innerHTML = 0;
}
}
t.addEventListener('mouseenter', () => {
clearTimeout(idx);
t.classList.add('hover');
sliderUpdateVolume(this.config.media.volume);
})
t.addEventListener('mouseleave', () => {
idx = setTimeout(mouseleave, 200);
})
t.addEventListener('click', () => {
if (this.config.media.volume == 0) {
t.querySelector('.volume-icon').style.display = 'block';
t.querySelector('.muted-icon').style.display = 'none';
this.config.media.volume = this.config.media.nonzeroVol;
} else {
t.querySelector('.volume-icon').style.display = 'none';
t.querySelector('.muted-icon').style.display = 'block';
this.config.media.volume = 0;
}
this.volume = this.config.media.volume;
localStorage.setItem('bpx_player_profile', JSON.stringify(this.config));
});
t.querySelector('.volume-box').addEventListener('mouseenter', () => {
clearTimeout(idx);
});
t.querySelector('.volume-box').addEventListener('mouseleave', () => {
idx = setTimeout(mouseleave, 200);
});
t.querySelector('.volume-box').addEventListener('click', e => e.stopPropagation());
/**
* 音量滑条
*/
t.querySelector('.volume-box .volume-slider').addEventListener('mousedown', () => {
slider_mousedown = true;
t.classList.add('hover');
clearTimeout(idx);
});
document.addEventListener('mouseup', () => {
slider_mousedown = false;
t.classList.remove('hover');
});
document.addEventListener('mousemove', e => {
if (slider_mousedown) clearTimeout(idx);
if (slider_mousedown) {
const x = 1 - (e.clientY - slider.getBoundingClientRect().top) / slider.clientHeight;
sliderUpdateVolume(x);
if (x > 0 && x <= 1) {
this.config.media.volume = x;
this.config.media.nonzeroVol = x;
} else if (x <= 0) {
this.config.media.volume = 0;
}
this.volume = this.config.media.volume;
localStorage.setItem('bpx_player_profile', JSON.stringify(this.config));
}
});
}),
/**
* 设置
*/
tag('div', {
class: 'settings control-btn',
attrs: { 'aria-label': '设置' },
children: tag('div', {
class: 'icon', children: tag('svg', {
attrs: { viewBox: '0 0 88 88' },
innerHTML: '<g clip-path="url(#__lottie_element_100)"><g transform="matrix(1,0,0,1,44,43.875)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M0,8.125 C-4.420000076293945,8.125 -8,4.545000076293945 -8,0.125 C-8,-4.295000076293945 -4.420000076293945,-7.875 0,-7.875 C4.420000076293945,-7.875 8,-4.295000076293945 8,0.125 C8,4.545000076293945 4.420000076293945,8.125 0,8.125z M0,16.125 C8.84000015258789,16.125 16,8.96500015258789 16,0.125 C16,-8.71500015258789 8.84000015258789,-15.875 0,-15.875 C-8.84000015258789,-15.875 -16,-8.71500015258789 -16,0.125 C-16,8.96500015258789 -8.84000015258789,16.125 0,16.125z M4.539999961853027,27.51099967956543 C3.059999942779541,27.750999450683594 1.5499999523162842,27.871000289916992 0,27.871000289916992 C-1.5499999523162842,27.871000289916992 -3.059999942779541,27.750999450683594 -4.539999961853027,27.51099967956543 C-4.539999961853027,27.51099967956543 -8.699999809265137,32.56100082397461 -8.699999809265137,32.56100082397461 C-9.9399995803833,34.07099914550781 -12.100000381469727,34.46099853515625 -13.789999961853027,33.48099899291992 C-13.789999961853027,33.48099899291992 -21.780000686645508,28.871000289916992 -21.780000686645508,28.871000289916992 C-23.469999313354492,27.891000747680664 -24.209999084472656,25.83099937438965 -23.520000457763672,24.000999450683594 C-23.520000457763672,24.000999450683594 -21.290000915527344,18.06100082397461 -21.290000915527344,18.06100082397461 C-23.3799991607666,15.621000289916992 -25.049999237060547,12.810999870300293 -26.209999084472656,9.76099967956543 C-26.209999084472656,9.76099967956543 -32.65999984741211,8.680999755859375 -32.65999984741211,8.680999755859375 C-34.59000015258789,8.361000061035156 -36,6.690999984741211 -36,4.741000175476074 C-36,4.741000175476074 -36,-4.488999843597412 -36,-4.488999843597412 C-36,-6.439000129699707 -34.59000015258789,-8.109000205993652 -32.65999984741211,-8.428999900817871 C-32.65999984741211,-8.428999900817871 -26.399999618530273,-9.479000091552734 -26.399999618530273,-9.479000091552734 C-25.309999465942383,-12.559000015258789 -23.690000534057617,-15.388999938964844 -21.65999984741211,-17.868999481201172 C-21.65999984741211,-17.868999481201172 -23.959999084472656,-23.999000549316406 -23.959999084472656,-23.999000549316406 C-24.639999389648438,-25.839000701904297 -23.899999618530273,-27.888999938964844 -22.209999084472656,-28.868999481201172 C-22.209999084472656,-28.868999481201172 -14.220000267028809,-33.479000091552734 -14.220000267028809,-33.479000091552734 C-12.529999732971191,-34.45899963378906 -10.380000114440918,-34.069000244140625 -9.130000114440918,-32.558998107910156 C-9.130000114440918,-32.558998107910156 -5.099999904632568,-27.659000396728516 -5.099999904632568,-27.659000396728516 C-3.450000047683716,-27.9689998626709 -1.7400000095367432,-28.128999710083008 0,-28.128999710083008 C1.7400000095367432,-28.128999710083008 3.450000047683716,-27.9689998626709 5.099999904632568,-27.659000396728516 C5.099999904632568,-27.659000396728516 9.130000114440918,-32.558998107910156 9.130000114440918,-32.558998107910156 C10.380000114440918,-34.069000244140625 12.529999732971191,-34.45899963378906 14.220000267028809,-33.479000091552734 C14.220000267028809,-33.479000091552734 22.209999084472656,-28.868999481201172 22.209999084472656,-28.868999481201172 C23.899999618530273,-27.888999938964844 24.639999389648438,-25.839000701904297 23.959999084472656,-23.999000549316406 C23.959999084472656,-23.999000549316406 21.65999984741211,-17.868999481201172 21.65999984741211,-17.868999481201172 C23.690000534057617,-15.388999938964844 25.309999465942383,-12.559000015258789 26.399999618530273,-9.479000091552734 C26.399999618530273,-9.479000091552734 32.65999984741211,-8.428999900817871 32.65999984741211,-8.428999900817871 C34.59000015258789,-8.109000205993652 36,-6.439000129699707 36,-4.488999843597412 C36,-4.488999843597412 36,4.741000175476074 36,4.741000175476074 C36,6.690999984741211 34.59000015258789,8.361000061035156 32.65999984741211,8.680999755859375 C32.65999984741211,8.680999755859375 26.209999084472656,9.76099967956543 26.209999084472656,9.76099967956543 C25.049999237060547,12.810999870300293 23.3799991607666,15.621000289916992 21.290000915527344,18.06100082397461 C21.290000915527344,18.06100082397461 23.520000457763672,24.000999450683594 23.520000457763672,24.000999450683594 C24.209999084472656,25.83099937438965 23.469999313354492,27.891000747680664 21.780000686645508,28.871000289916992 C21.780000686645508,28.871000289916992 13.789999961853027,33.48099899291992 13.789999961853027,33.48099899291992 C12.100000381469727,34.46099853515625 9.9399995803833,34.07099914550781 8.699999809265137,32.56100082397461 C8.699999809265137,32.56100082397461 4.539999961853027,27.51099967956543 4.539999961853027,27.51099967956543z"></path></g></g></g>'
})
})
}, (t) => {
// t.addEventListener('click', );
}),
/**
* 全屏
*/
tag('div', {
class: 'fullscreen control-btn',
attrs: { 'aria-label': '全屏' },
children: tag('div', {
class: 'icon', children: tag('svg', {
attrs: { viewBox: '0 0 88 88' },
innerHTML: '<g clip-path="url(#__lottie_element_148)"><g transform="matrix(1,0,0,1,44,74.22000122070312)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M19.219999313354492,0.2199999988079071 C7.480000019073486,7.630000114440918 -7.480000019073486,7.630000114440918 -19.219999313354492,0.2199999988079071 C-19.219999313354492,0.2199999988079071 -16.219999313354492,-5.78000020980835 -16.219999313354492,-5.78000020980835 C-6.389999866485596,0.75 6.409999847412109,0.75 16.239999771118164,-5.78000020980835 C16.239999771118164,-5.78000020980835 19.219999313354492,0.2199999988079071 19.219999313354492,0.2199999988079071z"></path></g></g><g transform="matrix(1,0,0,1,68.58000183105469,27.895000457763672)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M11.420000076293945,16.104999542236328 C11.420000076293945,16.104999542236328 4.78000020980835,16.104999542236328 4.78000020980835,16.104999542236328 C4.78000020980835,16.104999542236328 4.78000020980835,14.635000228881836 4.78000020980835,14.635000228881836 C4.25,4.054999828338623 -1.940000057220459,-5.425000190734863 -11.420000076293945,-10.164999961853027 C-11.420000076293945,-10.164999961853027 -8.479999542236328,-16.104999542236328 -8.479999542236328,-16.104999542236328 C3.7200000286102295,-10.005000114440918 11.420000076293945,2.4649999141693115 11.420000076293945,16.104999542236328 C11.420000076293945,16.104999542236328 11.420000076293945,16.104999542236328 11.420000076293945,16.104999542236328z"></path></g></g><g transform="matrix(1,0,0,1,19.450000762939453,27.895000457763672)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M-4.809999942779541,16.104999542236328 C-4.809999942779541,16.104999542236328 -11.449999809265137,16.104999542236328 -11.449999809265137,16.104999542236328 C-11.449999809265137,2.4649999141693115 -3.75,-10.005000114440918 8.449999809265137,-16.104999542236328 C8.449999809265137,-16.104999542236328 11.449999809265137,-10.164999961853027 11.449999809265137,-10.164999961853027 C1.4900000095367432,-5.204999923706055 -4.809999942779541,4.974999904632568 -4.809999942779541,16.104999542236328 C-4.809999942779541,16.104999542236328 -4.809999942779541,16.104999542236328 -4.809999942779541,16.104999542236328z"></path></g></g><g transform="matrix(1,0,0,1,44.0099983215332,65.96499633789062)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M-0.009999999776482582,5.34499979019165 C-5.46999979019165,5.355000019073486 -10.800000190734863,3.7149999141693115 -15.319999694824219,0.6549999713897705 C-15.319999694824219,0.6549999713897705 -12.319999694824219,-5.34499979019165 -12.319999694824219,-5.34499979019165 C-5,0.08500000089406967 5,0.08500000089406967 12.319999694824219,-5.34499979019165 C12.319999694824219,-5.34499979019165 15.319999694824219,0.6549999713897705 15.319999694824219,0.6549999713897705 C10.800000190734863,3.7249999046325684 5.460000038146973,5.355000019073486 -0.009999999776482582,5.34499979019165z"></path></g></g><g transform="matrix(1,0,0,1,62.275001525878906,31.780000686645508)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M9.015000343322754,10.850000381469727 C9.015000343322754,10.850000381469727 9.015000343322754,12.220000267028809 9.015000343322754,12.220000267028809 C9.015000343322754,12.220000267028809 2.434999942779541,12.220000267028809 2.434999942779541,12.220000267028809 C2.434999942779541,12.220000267028809 2.434999942779541,11.220000267028809 2.434999942779541,11.220000267028809 C2.075000047683716,3.740000009536743 -2.305000066757202,-2.9700000286102295 -9.015000343322754,-6.309999942779541 C-9.015000343322754,-6.309999942779541 -6.014999866485596,-12.220000267028809 -6.014999866485596,-12.220000267028809 C-6.014999866485596,-12.220000267028809 -6.014999866485596,-12.220000267028809 -6.014999866485596,-12.220000267028809 C2.7850000858306885,-7.800000190734863 8.524999618530273,1.0099999904632568 9.015000343322754,10.850000381469727 C9.015000343322754,10.850000381469727 9.015000343322754,10.850000381469727 9.015000343322754,10.850000381469727z"></path></g></g><g transform="matrix(1,0,0,1,25.729999542236328,31.780000686645508)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M-2.440000057220459,12.220000267028809 C-2.440000057220459,12.220000267028809 -9.050000190734863,12.220000267028809 -9.050000190734863,12.220000267028809 C-9.050000190734863,1.8700000047683716 -3.2100000381469727,-7.590000152587891 6.050000190734863,-12.220000267028809 C6.050000190734863,-12.220000267028809 9.050000190734863,-6.309999942779541 9.050000190734863,-6.309999942779541 C2.0199999809265137,-2.809999942779541 -2.430000066757202,4.360000133514404 -2.440000057220459,12.220000267028809 C-2.440000057220459,12.220000267028809 -2.440000057220459,12.220000267028809 -2.440000057220459,12.220000267028809z"></path></g></g><g transform="matrix(1,0,0,1,44,57.654998779296875)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M0,4.974999904632568 C-4.110000133514404,4.994999885559082 -8.119999885559082,3.6449999809265137 -11.380000114440918,1.1349999904632568 C-11.380000114440918,1.1349999904632568 -8.319999694824219,-4.974999904632568 -8.319999694824219,-4.974999904632568 C-3.6700000762939453,-0.5049999952316284 3.6700000762939453,-0.5049999952316284 8.319999694824219,-4.974999904632568 C8.319999694824219,-4.974999904632568 11.380000114440918,1.1349999904632568 11.380000114440918,1.1349999904632568 C8.109999656677246,3.634999990463257 4.110000133514404,4.985000133514404 0,4.974999904632568 C0,4.974999904632568 0,4.974999904632568 0,4.974999904632568z"></path></g></g><g transform="matrix(1,0,0,1,55.9900016784668,35.665000915527344)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M6.619999885559082,7.40500020980835 C6.619999885559082,7.40500020980835 6.619999885559082,8.335000038146973 6.619999885559082,8.335000038146973 C6.619999885559082,8.335000038146973 0.009999999776482582,8.335000038146973 0.009999999776482582,8.335000038146973 C0.009999999776482582,3.7850000858306885 -2.549999952316284,-0.375 -6.619999885559082,-2.4049999713897705 C-6.619999885559082,-2.4049999713897705 -3.619999885559082,-8.335000038146973 -3.619999885559082,-8.335000038146973 C2.380000114440918,-5.324999809265137 6.300000190734863,0.6949999928474426 6.619999885559082,7.40500020980835 C6.619999885559082,7.40500020980835 6.619999885559082,7.40500020980835 6.619999885559082,7.40500020980835z"></path></g></g><g transform="matrix(1,0,0,1,31.9950008392334,35.665000915527344)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M6.635000228881836,-2.4049999713897705 C2.565000057220459,-0.375 0.004999999888241291,3.7850000858306885 0.004999999888241291,8.335000038146973 C0.004999999888241291,8.335000038146973 -6.635000228881836,8.335000038146973 -6.635000228881836,8.335000038146973 C-6.635000228881836,1.274999976158142 -2.6449999809265137,-5.184999942779541 3.674999952316284,-8.335000038146973 C3.674999952316284,-8.335000038146973 6.635000228881836,-2.4049999713897705 6.635000228881836,-2.4049999713897705z"></path></g></g><g transform="matrix(1,0,0,1,44,66.322998046875)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M8.319000244140625,-13.677000045776367 C8.319000244140625,-13.677000045776367 19.2189998626709,8.123000144958496 19.2189998626709,8.123000144958496 C13.659000396728516,11.642999649047852 7.068999767303467,13.67300033569336 -0.0010000000474974513,13.67300033569336 C-7.071000099182129,13.67300033569336 -13.66100025177002,11.642999649047852 -19.22100067138672,8.123000144958496 C-19.22100067138672,8.123000144958496 -8.321000099182129,-13.677000045776367 -8.321000099182129,-13.677000045776367 C-6.160999774932861,-11.597000122070312 -3.2309999465942383,-10.32699966430664 -0.0010000000474974513,-10.32699966430664 C3.2290000915527344,-10.32699966430664 6.169000148773193,-11.597000122070312 8.319000244140625,-13.677000045776367z"></path></g></g><g transform="matrix(1,0,0,1,64.68399810791016,27.89699935913086)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M15.314000129699707,16.10700035095215 C15.314000129699707,16.10700035095215 -8.685999870300293,16.10700035095215 -8.685999870300293,16.10700035095215 C-8.685999870300293,11.406999588012695 -11.38599967956543,7.336999893188477 -15.315999984741211,5.367000102996826 C-15.315999984741211,5.367000102996826 -4.576000213623047,-16.10300064086914 -4.576000213623047,-16.10300064086914 C7.214000225067139,-10.192999839782715 15.314000129699707,2.006999969482422 15.314000129699707,16.10700035095215z"></path></g></g><g transform="matrix(1,0,0,1,23.31599998474121,27.89699935913086)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M4.584000110626221,-16.10300064086914 C4.584000110626221,-16.10300064086914 15.314000129699707,5.367000102996826 15.314000129699707,5.367000102996826 C11.383999824523926,7.336999893188477 8.684000015258789,11.406999588012695 8.684000015258789,16.10700035095215 C8.684000015258789,16.10700035095215 -15.315999984741211,16.10700035095215 -15.315999984741211,16.10700035095215 C-15.315999984741211,2.006999969482422 -7.216000080108643,-10.192999839782715 4.584000110626221,-16.10300064086914z"></path></g></g><g transform="matrix(1,0,0,1,44,44)" opacity="1" style="display: block;"><g opacity="1" transform="matrix(1,0,0,1,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M0,-4 C2.140000104904175,-4 3.890000104904175,-2.319999933242798 4,-0.20000000298023224 C4,-0.20000000298023224 4,0 4,0 C4,0 4,0.20000000298023224 4,0.20000000298023224 C3.890000104904175,2.319999933242798 2.140000104904175,4 0,4 C-2.2100000381469727,4 -4,2.2100000381469727 -4,0 C-4,-2.2100000381469727 -2.2100000381469727,-4 0,-4z"></path></g></g></g>'
})
})
}, (t) => {
t.addEventListener('click', toggleFullscreen)
}),
]
}),
]
}),
]
}),
tag('div', {
class: 'bpx-player-playrate-hint',
style: 'display: none',
children: [
tag('span', {
class: 'icon', children: tag('svg', {
attrs: {
viewBox: '0 0 111 66',
},
innerHTML: '<g clip-path="url(#__lottie_element_421)"><g transform="matrix(1,0,0,1,94.5,32.5)" opacity="1" style=""><g opacity="1" transform="matrix(0,3,-3,0,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M6.138000011444092,3.5460000038146973 C6.4679999351501465,4.105999946594238 6.2779998779296875,4.826000213623047 5.7179999351501465,5.156000137329102 C5.538000106811523,5.265999794006348 5.3379998207092285,5.326000213623047 5.118000030517578,5.326000213623047 C5.118000030517578,5.326000213623047 -5.122000217437744,5.326000213623047 -5.122000217437744,5.326000213623047 C-5.771999835968018,5.326000213623047 -6.302000045776367,4.796000003814697 -6.302000045776367,4.145999908447266 C-6.302000045776367,3.936000108718872 -6.242000102996826,3.7260000705718994 -6.142000198364258,3.5460000038146973 C-6.142000198364258,3.5460000038146973 -1.3519999980926514,-4.553999900817871 -1.3519999980926514,-4.553999900817871 C-0.9120000004768372,-5.294000148773193 0.04800000041723251,-5.544000148773193 0.7979999780654907,-5.104000091552734 C1.027999997138977,-4.973999977111816 1.218000054359436,-4.783999919891357 1.3480000495910645,-4.553999900817871 C1.3480000495910645,-4.553999900817871 6.138000011444092,3.5460000038146973 6.138000011444092,3.5460000038146973z"></path></g></g><g transform="matrix(1,0,0,1,55.5,32.5)" opacity="" style=""><g opacity="1" transform="matrix(0,3,-3,0,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M6.138000011444092,3.5460000038146973 C6.4679999351501465,4.105999946594238 6.2779998779296875,4.826000213623047 5.7179999351501465,5.156000137329102 C5.538000106811523,5.265999794006348 5.3379998207092285,5.326000213623047 5.118000030517578,5.326000213623047 C5.118000030517578,5.326000213623047 -5.122000217437744,5.326000213623047 -5.122000217437744,5.326000213623047 C-5.771999835968018,5.326000213623047 -6.302000045776367,4.796000003814697 -6.302000045776367,4.145999908447266 C-6.302000045776367,3.936000108718872 -6.242000102996826,3.7260000705718994 -6.142000198364258,3.5460000038146973 C-6.142000198364258,3.5460000038146973 -1.3519999980926514,-4.553999900817871 -1.3519999980926514,-4.553999900817871 C-0.9120000004768372,-5.294000148773193 0.04800000041723251,-5.544000148773193 0.7979999780654907,-5.104000091552734 C1.027999997138977,-4.973999977111816 1.218000054359436,-4.783999919891357 1.3480000495910645,-4.553999900817871 C1.3480000495910645,-4.553999900817871 6.138000011444092,3.5460000038146973 6.138000011444092,3.5460000038146973z"></path></g></g><g transform="matrix(1,0,0,1,16.5,32.5)" style=""><g opacity="1" transform="matrix(0,3,-3,0,0,0)"><path fill="rgb(255,255,255)" fill-opacity="1" d=" M6.138000011444092,3.5460000038146973 C6.4679999351501465,4.105999946594238 6.2779998779296875,4.826000213623047 5.7179999351501465,5.156000137329102 C5.538000106811523,5.265999794006348 5.3379998207092285,5.326000213623047 5.118000030517578,5.326000213623047 C5.118000030517578,5.326000213623047 -5.122000217437744,5.326000213623047 -5.122000217437744,5.326000213623047 C-5.771999835968018,5.326000213623047 -6.302000045776367,4.796000003814697 -6.302000045776367,4.145999908447266 C-6.302000045776367,3.936000108718872 -6.242000102996826,3.7260000705718994 -6.142000198364258,3.5460000038146973 C-6.142000198364258,3.5460000038146973 -1.3519999980926514,-4.553999900817871 -1.3519999980926514,-4.553999900817871 C-0.9120000004768372,-5.294000148773193 0.04800000041723251,-5.544000148773193 0.7979999780654907,-5.104000091552734 C1.027999997138977,-4.973999977111816 1.218000054359436,-4.783999919891357 1.3480000495910645,-4.553999900817871 C1.3480000495910645,-4.553999900817871 6.138000011444092,3.5460000038146973 6.138000011444092,3.5460000038146973z"></path></g></g></g>'
})
}),
tag('span', { class: 'text', innerHTML: '倍速播放中' })
]
}),
tag('div', {
class: 'bpx-player-tooltip-incenter',
children: tag('div', {
class: 'incenter bpx-player-tooltip-item',
children: tag('span', { class: 'text', innerHTML: '' })
})
}),
]
}),
tag('div', { class: 'bpx-player-sending-area' }),
tag('div', {
class: 'bpx-player-tooltip-area', children: [
tag('div', {
class: 'previous bpx-player-tooltip-item',
style: 'left: -2px; top: -85px;',
children: tag('span', { class: 'text', innerHTML: '上一个 ([)' })
}),
tag('div', {
class: 'next bpx-player-tooltip-item',
style: 'left: 68px; top: -85px;',
children: tag('span', { class: 'text', innerHTML: '下一个 (])' })
}),
tag('div', {
class: 'fullscreen bpx-player-tooltip-item',
style: 'right: -5px; top: -85px;',
children: tag('span', { class: 'text', innerHTML: '进入全屏 (f)' })
}),
]
}),
]
});
}
/**
* 自动开播
*/
canplay_func() {
this.playerElement.querySelector('.control-btn.time .duration').innerHTML = formatTime(this.duration);
this.playerElement.querySelector('.bpx-player-loading-panel').classList.remove('bpx-state-loading');
this.play();
}
canplay_wrap(e) {
e.target.canplay = (e.target.canplay || 0) + 1;
if ((this.audioElement.canplay === 1 || !this.has_audio) && this.videoElement.canplay === 1) this.canplay_func();
}
/**
* 鼠标进入/离开
*/
playerLeave() {
this.playerElement.style.cursor = 'none';
this.playerElement.classList.remove('hover');
if (isMobile()) {
this.playerElement.querySelector('.bpx-player-control').style.opacity = 0;
}
}
playerEnter() {
this.playerElement.style.cursor = 'pointer';
this.playerElement.classList.add('hover');
if (isMobile()) {
this.playerElement.querySelector('.bpx-player-control').style.opacity = 1;
}
clearTimeout(this.leave_timer);
this.leave_timer = setTimeout(() => this.playerLeave(), 3000);
}
/**
* 进度条渲染
*/
progress_render() {
const audio_buffer = this.audioElement.buffered;
const video_buffer = this.videoElement.buffered;
const audio_buffered = this.has_audio ? (audio_buffer.length > 0 ? audio_buffer.end(audio_buffer.length - 1) : 0) : 0;
const video_buffered = video_buffer.length > 0 ? video_buffer.end(video_buffer.length - 1) : 0;
const duration = this.videoElement.duration;
const buffered = Math.min(audio_buffered, video_buffered) / duration;
const current = this.currentTime / duration;
const total_px = this.progressElement.querySelector('.schedule').clientWidth;
this.progressElement.querySelector('.buffer').style.transform = 'scaleX(' + buffered + ')';
this.progressElement.querySelector('.current').style.transform = 'scaleX(' + current + ')';
this.progressElement.querySelector('.thumb').style.transform = 'translateX(' + current * total_px + 'px)';
this.playerElement.querySelector('.control-btn.time .current').innerHTML = formatTime(this.currentTime);
if (Math.abs(this.currentTime - (this.video_info.lastRecordTime || 0)) > 15) {
this.video_info.lastRecordTime = this.currentTime;
record_history(this.video_info.aid, this.video_info.cid, this.currentTime);
}
const danmaku_index = Math.floor((this.currentTime - 10) / 360);
if (danmaku_index > 0 && !this.video_info.danmakuIndexs[danmaku_index]) {
this.add_danmakus(danmaku_index);
}
for (let i = (this.#danmaku_offset || 0); i < this.video_info.danmakus.length; i++) {
if (!this.video_info.danmakus[i].progress) continue;
if (this.currentTime * 1000 - this.video_info.danmakus[i].progress > 10) {
this.#danmaku_offset = i + 1;
this.load_danmaku(this.video_info.danmakus[i]);
} else {
break;
}
}
}
danmaku_reset_state() {
this.playerElement.querySelector('.bpx-player-row-dm-wrap').innerHTML = '';
this.#danmaku_rolls = [-1, -1, -1, -1, -1, -1, -1, -1];
this.#danmaku_tops = [-1, -1, -1, -1, -1, -1, -1, -1];
this.#danmaku_tasks = [];
}
add_danmakus(index) {
this.video_info.danmakuIndexs[index] = 1;
get_danmaku(this.video_info.aid, this.video_info.cid, index).then((r) => {
if (r.code != 0 || !r.data.elems || r.data.elems.length == 0) return;
const elems = r.data.elems.sort((a, b) => a.progress - b.progress);
for (const e of elems) {
this.video_info.danmakus.push(e);
}
// console.log(this.video_info.danmakus)
})
}
#danmaku_tasks = [];
load_danmaku(danmaku) {
if (
danmaku.mode < 4 &&
(
(this.#danmaku_rolls.reduce((num, value) => {
return value === -1 ? num + 1 : num;
}, 0) <= 0) ||
(this.#danmaku_tops.reduce((num, value) => {
return value === -1 ? num + 1 : num;
}, 0) <= 0) ||
this.paused
)
) {
this.#danmaku_tasks.push(danmaku);
setTimeout(() => {
if (this.#danmaku_tasks.length == 0) return;
this.load_danmaku(this.#danmaku_tasks.shift());
}, 200);
return
}
// console.log('load_danmaku', danmaku.mode, danmaku.content);
const r = danmaku.color >> 16 & 255;
const g = danmaku.color >> 8 & 255;
const b = danmaku.color & 255;
let t = tag('div', {
class: 'bili-danmaku-x-dm',
attrs: {
'data-id': danmaku.idStr,
},
innerText: danmaku.content,
});
t.style.setProperty('--color', `rgb(${r},${g},${b})`);
t.style.setProperty('--fontSize', danmaku.fontsize + 'px');
switch (danmaku.mode) {
case 9: // BAS 弹幕(仅限于特殊弹幕专包)
case 8: // 代码弹幕
case 7: // 高级弹幕
case 6: // 逆向弹幕
t = null;
break;
case 5: // 顶部弹幕
t.top_index = this.#danmaku_tops.indexOf(-1);
this.#danmaku_tops[t.top_index] = 0;
t.classList.add('bili-danmaku-x-center');
t.style.setProperty('--translateY', t.top_index * danmaku.fontsize + 'px');
break;
case 4: // 底部弹幕
t = null;
break;
default: // 普通弹幕
t.roll_index = this.#danmaku_rolls.indexOf(-1);
let rand;
while (this.#danmaku_rolls.indexOf((rand = Math.floor(Math.random() * 8) * danmaku.fontsize)) !== -1) { }
this.#danmaku_rolls[t.roll_index] = rand;
t.classList.add('bili-danmaku-x-roll');
t.style.setProperty('--top', rand + 'px');
}
if (t && !this.playerElement.querySelector(`.bili-danmaku-x-dm[data-id="${danmaku.idStr}"]`)) {
t.addEventListener('animationend', () => {
if (t.top_index >= 0) {
this.#danmaku_tops[t.top_index] = -1;
}
t.remove()
});
this.playerElement.querySelector('.bpx-player-row-dm-wrap').appendChild(t);
if (t.roll_index >= 0) {
t.style.setProperty('--translateX', '-' + (this.playerElement.clientWidth + t.clientWidth) + 'px');
setTimeout(() => {
this.#danmaku_rolls[t.roll_index] = -1;
}, 60 * t.clientWidth);
}
}
}
/**
* 视频播放/暂停
*/
videoClick() {
if (this.paused) {
this.play();
} else {
this.pause();
}
}
/**
* 监听
*/
startListening() {
/**
* player 节点监听
*/
this.playerElement.addEventListener('mouseenter', () => this.playerEnter());
this.playerElement.addEventListener('mousemove', () => this.playerEnter());
this.playerElement.addEventListener('mouseleave', () => this.playerLeave());
if (isMobile()) {
this.playerElement.addEventListener('touchstart', () => this.playerEnter());
this.playerElement.addEventListener('touchmove', () => this.playerEnter());
this.playerElement.addEventListener('touchend', () => this.playerLeave());
}
/**
* 监听进入/退出全屏
*/
document.addEventListener('fullscreenchange', () => {
if (document.fullscreenElement) {
this.playerElement.classList.add('bpx-state-fullscreen');
this.videoElement.style.width = '100%';
this.videoElement.style.height = '100%';
} else {
this.playerElement.classList.remove('bpx-state-fullscreen');
this.videoElement.style.removeProperty('width');
this.videoElement.style.removeProperty('height');
}
})
/**
* 监听键盘
*/
document.addEventListener('keydown', async (e) => {
if (e.target.closest('input')) return;
switch (e.code) {
case 'F11':
case 'KeyF':
case 'Space':
e.preventDefault();
break;
// 快退
case 'ArrowLeft':
e.preventDefault();
this.videoBackwardStart();
break;
// 快进
case 'ArrowRight':
e.preventDefault();
this.videoForwardStart();
break;
case 'ArrowUp':
case 'ArrowDown':
e.preventDefault();
break;
}
})
document.addEventListener('keyup', async (e) => {
if (e.target.closest('input')) return;
switch (e.code) {
// 上一条
case 'BracketLeft':
case 'ArrowUp':
e.preventDefault();
await previousVideo();
break;
// 下一条
case 'BracketRight':
case 'ArrowDown':
e.preventDefault();
await nextVideo();
break;
// 点赞
case 'KeyQ':
await likeClick();
break;
// 全屏
case 'F11':
case 'KeyF':
e.preventDefault();
toggleFullscreen();
break;
// 播放/暂停
case 'Space':
e.preventDefault();
this.videoClick();
break;
// 快退
case 'ArrowLeft':
e.preventDefault();
this.videoBackwardEnd();
break;
// 快进
case 'ArrowRight':
e.preventDefault();
this.videoForwardEnd();
break;
}
})
/**
* 音频节点监听
*/
this.audioElement.addEventListener('canplay', (e) => this.canplay_wrap(e));
this.audioElement.addEventListener('ended', () => {
nextVideo().then();
});
this.audioElement.addEventListener('timeupdate', () => {
if (!this.has_audio) return;
if (this.progress_is_mousedown) return;
this.progress_render();
});
this.audioElement.addEventListener('error', (e) => {
if (!this.has_audio) return;
this.video_info.audio_error_times = (this.video_info.audio_error_times || 0) + 1;
console.warn('音频播放失败 error_times: ', this.video_info.audio_error_times, ', 尝试切换备用链接');
this.audio_url = chooseQuality(this.video_info)[1];
});
/**
* 视频节点监听
*/
this.videoElement.addEventListener('canplay', (e) => {
this.canplay_wrap(e);
const w = this.videoElement.videoWidth;
const h = this.videoElement.videoHeight;
if (w > h) {
this.canvas.width = 320;
this.canvas.height = Math.floor(h * 320 / w);
} else {
this.canvas.width = Math.floor(w * 320 / h);
this.canvas.height = 320;
}
});
this.videoElement.addEventListener('ended', () => {
if (this.has_audio) return;
nextVideo().then();
});
this.videoElement.addEventListener('click', () => this.videoClick());
this.playerElement.querySelector('.control-btn.play').addEventListener('click', () => this.videoClick());
this.videoElement.addEventListener('timeupdate', () => {
if (this.no_buffing) {
setTimeout(() => this.no_buffing = false, 50);
}
if (this.has_audio) return;
if (this.progress_is_mousedown) return;
this.progress_render();
});
this.videoElement.addEventListener('error', (e) => {
this.video_info.video_error_times = (this.video_info.video_error_times || 0) + 1;
const t = chooseQuality(this.video_info)[0];
if (!t) return;
console.warn('视频播放失败 error_times: ', this.video_info.video_error_times, ', 尝试切换备用链接');
this.video_url = t;
})
this.videoElement.addEventListener('waiting', async () => {
if (this.no_buffing) return;
if (!this.waiting) {
this.waiting = true;
this.playerElement.classList.add('bpx-state-buff');
}
})
this.videoElement.addEventListener('playing', async () => {
if (this.waiting) {
this.waiting = false;
this.playerElement.classList.remove('bpx-state-buff');
}
if (this.no_buffing) return;
if (this.has_audio && !this.videoElement.paused && !this.videoElement.seeking && Math.abs(this.videoElement.currentTime - this.audioElement.currentTime) > 0.01) {
this.no_buffing = true;
this.videoElement.currentTime = this.audioElement.currentTime;
}
})
/**
* 进度条节点监听
*/
let idx;
const progress_func = (e) => {
let x = (e.clientX - this.progressElement.getBoundingClientRect().left + 2);
if (x < 0 || x > this.progressElement.clientWidth) return;
this.progressElement.querySelector('.move-indicator').style.left = x + 'px';
this.progressElement.querySelector('.popup').style.left = x + 'px';
const current = x / this.progressElement.clientWidth;
const duration = this.videoElement.duration;
if (!duration) return;
const flag = Math.floor((this.#newTime + 2) / 7) * 7 == Math.floor((current * duration + 2) / 7) * 7;
if (this.progress_is_mousedown) {
const total_px = this.progressElement.querySelector('.schedule').clientWidth;
this.progressElement.querySelector('.current').style.transform = 'scaleX(' + current + ')';
this.progressElement.querySelector('.thumb').style.transform = 'translateX(' + current * total_px + 'px)';
}
this.progressElement.querySelector('.preview-time').innerHTML = formatTime(current * duration);
this.#newTime = current * duration;
if (flag) return;
clearTimeout(idx);
idx = setTimeout(() => {
this.videoElementPreview.currentTime = this.#newTime;
}, 50);
};
/**
* 生成预览图
*/
this.videoElementPreview.addEventListener('timeupdate', () => {
this.canvas.getContext('2d').drawImage(this.videoElementPreview, 0, 0, this.canvas.width, this.canvas.height);
this.progressElement.querySelector('.preview-image').src = this.canvas.toDataURL("image/png");
})
this.progressElement.addEventListener('mouseenter', (e) => {
this.progressElement.classList.add('active');
progress_func(e);
});
document.addEventListener('mousemove', (e) => {
if (this.progress_is_mousedown || e.target.closest('.bpx-player-progress')) {
progress_func(e);
}
});
this.progressElement.addEventListener('mouseleave', (e) => {
if (!this.progress_is_mousedown) this.progressElement.classList.remove('active');
progress_func(e);
});
this.progressElement.addEventListener('mousedown', (e) => {
e.stopPropagation();
if (e.buttons & 1 === 1) {
this.progress_is_mousedown = true;
this.progressElement.classList.add('active');
}
});
document.addEventListener('mouseup', () => {
if (this.progress_is_mousedown) {
this.currentTime = this.#newTime;
}
if (!this.progress_is_mousedown) this.progressElement.classList.remove('active');
this.progress_is_mousedown = false;
});
}
/**
* @returns {String}
*/
get audio_url() {
return this.#audio_url;
}
/**
* @param {String} u
*/
set audio_url(u) {
this.#audio_url = u;
this.audioElement.src = u;
this.has_audio = !!u;
}
/**
* @returns {String}
*/
get video_url() {
return this.#video_url;
}
/**
* @param {String} u
*/
set video_url(u) {
this.#video_url = u;
this.videoElement.src = u;
this.videoElementPreview.src = u;
}
/**
* duration
*/
get duration() {
return this.video_info.timelength / 1000;
}
/**
* 当前播放时间
* @returns {Number}
*/
get currentTime() {
if (this.has_audio) return this.audioElement.currentTime;
return this.videoElement.currentTime;
}
/**
* 跳转播放 seeking
* @param {Number} c
*/
set currentTime(c) {
if (this.has_audio) this.audioElement.currentTime = c;
this.videoElement.currentTime = c;
this.danmaku_reset_state();
let flag = true;
for (let i = 0; i < this.video_info.danmakus.length; i++) {
if (this.video_info.danmakus[i].progress > c * 1000) {
this.#danmaku_offset = i - 1 > 0 ? i - 1 : 0;
flag = false;
break;
}
}
if (flag) this.#danmaku_offset = this.video_info.danmakus.length;
}
get seeking() {
if (this.has_audio) return this.audioElement.seeking;
return this.videoElement.seeking;
}
/**
* 播放速度
* @returns {Number}
*/
get playbackRate() {
if (this.has_audio) return this.audioElement.playbackRate;
return this.videoElement.playbackRate;
}
/**
* ratechange
* @param {Number} r
*/
set playbackRate(r) {
if (this.has_audio) this.audioElement.playbackRate = r;
this.videoElement.playbackRate = r;
}
/**
* paused
* @returns {Bool}
*/
get paused() {
if (this.has_audio) return this.audioElement.paused;
return this.videoElement.paused;
}
/**
* 音量
* @returns {Number}
*/
get volume() {
return this.audioElement.volume;
}
/**
* 设置音量
* @param {Number} v
*/
set volume(v) {
this.audioElement.volume = v;
}
/**
* 设置当前视频信息
* @param {Object} video
*/
setVideo(video) {
this.audioElement.canplay = 0;
this.videoElement.canplay = 0;
this.video_info = video;
this.video_info.lastRecordTime = 0;
this.#danmaku_offset = 0;
this.danmaku_reset_state();
if (this.video_info.danmakus === undefined) {
this.video_info.danmakuIndexs = {};
this.video_info.danmakus = [];
this.add_danmakus(0);
}
const urls = chooseQuality(video);
this.video_url = urls[0];
this.audio_url = urls[1];
if (this.has_audio) {
const lt = video.last_play_time || video.currentTime;
if (lt && lt < this.duration * 0.9 && lt < this.duration - 5) {
this.currentTime = lt;
}
}
this.playerElement.classList.remove('bpx-state-paused');
this.playerElement.querySelector('.bpx-player-follow-text').innerHTML = video.owner.name;
this.playerElement.querySelector('.bpx-player-follow-face').setAttribute('src', video.owner.face);
this.playerElement.querySelector('.bpx-player-top-left-title').innerHTML = video.title;
}
/**
* 播放
*/
play() {
if (this.has_audio) this.audioElement.play();
this.videoElement.play();
this.playerElement.classList.remove('bpx-state-paused');
clearTimeout(this.#lastPauseTimer);
}
/**
* 暂停
*/
pause() {
if (this.has_audio) this.audioElement.pause();
this.videoElement.pause();
this.playerElement.classList.add('bpx-state-paused');
if (Math.abs(this.currentTime - (this.video_info.lastRecordTime || 0)) > 5) {
this.#lastPauseTimer = setTimeout(() => {
this.video_info.lastRecordTime = this.currentTime;
record_history(this.video_info.aid, this.video_info.cid, this.currentTime);
}, 5000);
}
}
/**
* 视频快进 / 3倍速播放
*/
forward_idx = null;
forwarding = false;
videoForwardStart() {
this.playerElement.classList.add('hover')
if (!this.forwarding) this.forward_idx = setTimeout(() => {
this.forwarding = true;
this.playbackRate = this.currentRate * 3;
this.playerElement.querySelector('.bpx-player-playrate-hint').style.removeProperty('display');
}, 500);
}
videoForwardEnd() {
clearTimeout(this.forward_idx);
if (!this.forwarding) {
this.currentTime = this.currentTime + 5 > this.duration ? this.duration : this.currentTime + 5;
}
this.forwarding = false;
this.playerElement.querySelector('.bpx-player-playrate-hint').style.display = 'none';
this.playbackRate = this.currentRate;
}
/**
* 视频快退
*/
backward_idx = null;
backwarding = false;
videoBackwardStart() {
this.playerElement.classList.add('hover')
if (!this.backwarding) this.backward_idx = setInterval(() => {
this.backwarding = true
if (this.backwarding) this.currentTime = this.currentTime - 1 > 0 ? this.currentTime - 1 : 0;
}, 200);
}
videoBackwardEnd() {
if (!this.backwarding) {
this.currentTime = this.currentTime - 5 > 0 ? this.currentTime - 5 : 0;
}
clearInterval(this.backward_idx);
this.backwarding = false
}
}
/**
* 创建 Element
* @param {String} tagName
* @param {Object} options
* @param {function} func
* @returns {SVGElement | HTMLElement}
*/
function tag(tagName, options, func) {
options = options || {};
var svgTags = ['svg', 'g', 'path', 'filter', 'animate', 'marker', 'line', 'polyline', 'rect', 'circle', 'ellipse', 'polygon'];
let newElement;
if (svgTags.indexOf(tagName) >= 0) {
newElement = document.createElementNS("http://www.w3.org/2000/svg", tagName);
} else {
newElement = document.createElement(tagName);
}
if (options.id) newElement.id = options.id;
if (options.class) {
if (!Array.isArray(options.class)) options.class = options.class.split(' ');
for (const e of options.class) {
if (e) newElement.classList.add(e);
}
}
if (options.innerHTML) newElement.innerHTML = options.innerHTML;
if (options.innerText) newElement.innerText = options.innerText;
if (options.children) {
if (!isArrayLike(options.children)) options.children = [options.children];
for (let e of options.children) {
if (isString(e) || isNumber(e)) e = document.createTextNode(e);
newElement.appendChild(e);
}
}
if (options.style) newElement.style.cssText = options.style
if (options.attrs) {
for (const [k, v] of Object.entries(options.attrs)) {
newElement.setAttribute(k, v)
}
}
func && func(newElement)
return newElement;
}
/**
* 视频简介实体化
* @param {Array<Desc>} desc_v2
* @returns {Array<HTMLElement>}
*/
function parseDesc(desc_v2) {
return !desc_v2 ? [] : desc_v2.map((i) => {
switch (i.type) {
case 2:
return tag('a', { attrs: { target: '_blank', href: '//space.bilibili.com/' + i.biz_id }, innerHTML: '@' + i.raw_text })
case 1:
default:
const text = i.raw_text
.replaceAll(/(https?:\/\/[0-9a-z\.]*(?:\/(?:(?! |\n)[\x00-\xff])*)?)|(BV[0-9a-zA-Z]{10,10})/g, (g0, g1, g2) => {
if (g1) return `<a target="_blank" href="${g1}">${g1}</a>`;
if (g2) return `<a target="_blank" href="//www.bilibili.com/video/${g2}">${g2}</a>`;
return g0;
});
return tag('span', { innerHTML: text })
}
});
}
/**
* 初始化
* @param {Object} video
*/
async function init(video) {
inited = true;
// UP 信息
container.appendChild(tag('div', {
class: 'up-info-container',
children: [
tag('a', {
class: 'up-avatar-wrap',
attrs: { href: 'https://space.bilibili.com/' + video.owner.mid, target: '_blank' },
children: tag('img', { class: 'up-avatar', attrs: { src: video.owner.face } })
}),
tag('div', {
class: 'up-detail', children: [
tag('a', {
class: 'up-detail-top',
attrs: { href: 'https://space.bilibili.com/' + video.owner.mid, target: '_blank' },
innerHTML: video.owner.name
}),
tag('div', {
class: 'up-detail-down',
children: tag('a', {
class: 'up-detail-bvid',
style: 'color: #00AEEC',
attrs: { href: '/video/' + video.bvid, target: '_blank' },
innerHTML: video.bvid
}),
}),
]
})
],
}));
// 视频信息
container.appendChild(tag('div', {
class: 'video-info-container',
children: [
tag('div', {
class: 'video-info-title',
children: [
tag('span', { class: 'video-title', innerHTML: video.title }),
]
}),
tag('div', {
class: 'video-meta', children: [
tag('div', {
class: 'view item',
children: [
tag('svg', {
class: 'icon',
style: 'width: 20px; height: 20px',
attrs: {
'viewBox': '0 0 20 20',
},
innerHTML: `<path d="M10 4.040041666666666C7.897383333333334 4.040041666666666 6.061606666666667 4.147 4.765636666666667 4.252088333333334C3.806826666666667 4.32984 3.061106666666667 5.0637316666666665 2.9755000000000003 6.015921666666667C2.8803183333333333 7.074671666666667 2.791666666666667 8.471183333333332 2.791666666666667 9.998333333333333C2.791666666666667 11.525566666666668 2.8803183333333333 12.922083333333333 2.9755000000000003 13.9808C3.061106666666667 14.932983333333334 3.806826666666667 15.666916666666667 4.765636666666667 15.744683333333336C6.061611666666668 15.849716666666666 7.897383333333334 15.956666666666667 10 15.956666666666667C12.10285 15.956666666666667 13.93871666666667 15.849716666666666 15.234766666666667 15.74461666666667C16.193416666666668 15.66685 16.939000000000004 14.933216666666667 17.024583333333336 13.981216666666668C17.11975 12.922916666666667 17.208333333333332 11.526666666666666 17.208333333333332 9.998333333333333C17.208333333333332 8.470083333333333 17.11975 7.073818333333334 17.024583333333336 6.015513333333334C16.939000000000004 5.063538333333333 16.193416666666668 4.329865000000001 15.234766666666667 4.252118333333334C13.93871666666667 4.147016666666667 12.10285 4.040041666666666 10 4.040041666666666zM4.684808333333334 3.255365C6.001155 3.14862 7.864583333333334 3.0400416666666668 10 3.0400416666666668C12.13565 3.0400416666666668 13.999199999999998 3.148636666666667 15.315566666666667 3.2553900000000002C16.753416666666666 3.3720016666666672 17.890833333333333 4.483195 18.020583333333335 5.925965000000001C18.11766666666667 7.005906666666667 18.208333333333336 8.433 18.208333333333336 9.998333333333333C18.208333333333336 11.56375 18.11766666666667 12.990833333333335 18.020583333333335 14.0708C17.890833333333333 15.513533333333331 16.753416666666666 16.624733333333335 15.315566666666667 16.74138333333333C13.999199999999998 16.848116666666666 12.13565 16.95666666666667 10 16.95666666666667C7.864583333333334 16.95666666666667 6.001155 16.848116666666666 4.684808333333334 16.7414C3.2467266666666665 16.624750000000002 2.1092383333333338 15.513266666666667 1.9795200000000002 14.070383333333334C1.8823900000000002 12.990000000000002 1.7916666666666667 11.562683333333334 1.7916666666666667 9.998333333333333C1.7916666666666667 8.434066666666666 1.8823900000000002 7.00672 1.9795200000000002 5.926381666666667C2.1092383333333338 4.483463333333334 3.2467266666666665 3.371976666666667 4.684808333333334 3.255365z" fill="currentColor"></path><path d="M12.23275 9.1962C12.851516666666667 9.553483333333332 12.851516666666667 10.44665 12.232683333333332 10.803866666666666L9.57975 12.335600000000001C8.960983333333335 12.692816666666667 8.1875 12.246250000000002 8.187503333333334 11.531733333333333L8.187503333333334 8.4684C8.187503333333334 7.753871666666667 8.960983333333335 7.307296666666667 9.57975 7.66456L12.23275 9.1962z" fill="currentColor"></path>`
}),
tag('div', {
class: 'text',
innerHTML: video.stat.view,
}),
],
}),
tag('div', {
class: 'danmaku item',
children: [
tag('svg', {
class: 'icon',
style: 'width: 20px; height: 20px',
attrs: {
'viewBox': '0 0 20 20',
},
innerHTML: `<path d="M10 4.040041666666666C7.897383333333334 4.040041666666666 6.061606666666667 4.147 4.765636666666667 4.252088333333334C3.806826666666667 4.32984 3.061106666666667 5.0637316666666665 2.9755000000000003 6.015921666666667C2.8803183333333333 7.074671666666667 2.791666666666667 8.471183333333332 2.791666666666667 9.998333333333333C2.791666666666667 11.525566666666668 2.8803183333333333 12.922083333333333 2.9755000000000003 13.9808C3.061106666666667 14.932983333333334 3.806826666666667 15.666916666666667 4.765636666666667 15.744683333333336C6.061611666666668 15.849716666666666 7.897383333333334 15.956666666666667 10 15.956666666666667C12.10285 15.956666666666667 13.93871666666667 15.849716666666666 15.234766666666667 15.74461666666667C16.193416666666668 15.66685 16.939000000000004 14.933216666666667 17.024583333333336 13.981216666666668C17.11975 12.922916666666667 17.208333333333332 11.526666666666666 17.208333333333332 9.998333333333333C17.208333333333332 8.470083333333333 17.11975 7.073818333333334 17.024583333333336 6.015513333333334C16.939000000000004 5.063538333333333 16.193416666666668 4.329865000000001 15.234766666666667 4.252118333333334C13.93871666666667 4.147016666666667 12.10285 4.040041666666666 10 4.040041666666666zM4.684808333333334 3.255365C6.001155 3.14862 7.864583333333334 3.0400416666666668 10 3.0400416666666668C12.13565 3.0400416666666668 13.999199999999998 3.148636666666667 15.315566666666667 3.2553900000000002C16.753416666666666 3.3720016666666672 17.890833333333333 4.483195 18.020583333333335 5.925965000000001C18.11766666666667 7.005906666666667 18.208333333333336 8.433 18.208333333333336 9.998333333333333C18.208333333333336 11.56375 18.11766666666667 12.990833333333335 18.020583333333335 14.0708C17.890833333333333 15.513533333333331 16.753416666666666 16.624733333333335 15.315566666666667 16.74138333333333C13.999199999999998 16.848116666666666 12.13565 16.95666666666667 10 16.95666666666667C7.864583333333334 16.95666666666667 6.001155 16.848116666666666 4.684808333333334 16.7414C3.2467266666666665 16.624750000000002 2.1092383333333338 15.513266666666667 1.9795200000000002 14.070383333333334C1.8823900000000002 12.990000000000002 1.7916666666666667 11.562683333333334 1.7916666666666667 9.998333333333333C1.7916666666666667 8.434066666666666 1.8823900000000002 7.00672 1.9795200000000002 5.926381666666667C2.1092383333333338 4.483463333333334 3.2467266666666665 3.371976666666667 4.684808333333334 3.255365z" fill="currentColor"></path><path d="M13.291666666666666 8.833333333333334L8.166666666666668 8.833333333333334C7.890526666666666 8.833333333333334 7.666666666666666 8.609449999999999 7.666666666666666 8.333333333333334C7.666666666666666 8.057193333333334 7.890526666666666 7.833333333333334 8.166666666666668 7.833333333333334L13.291666666666666 7.833333333333334C13.567783333333335 7.833333333333334 13.791666666666668 8.057193333333334 13.791666666666668 8.333333333333334C13.791666666666668 8.609449999999999 13.567783333333335 8.833333333333334 13.291666666666666 8.833333333333334z" fill="currentColor"></path><path d="M14.541666666666666 12.166666666666666L9.416666666666668 12.166666666666666C9.140550000000001 12.166666666666666 8.916666666666666 11.942783333333333 8.916666666666666 11.666666666666668C8.916666666666666 11.390550000000001 9.140550000000001 11.166666666666668 9.416666666666668 11.166666666666668L14.541666666666666 11.166666666666668C14.817783333333335 11.166666666666668 15.041666666666668 11.390550000000001 15.041666666666668 11.666666666666668C15.041666666666668 11.942783333333333 14.817783333333335 12.166666666666666 14.541666666666666 12.166666666666666z" fill="currentColor"></path><path d="M6.5 8.333333333333334C6.5 8.609449999999999 6.27614 8.833333333333334 6 8.833333333333334L5.458333333333333 8.833333333333334C5.182193333333334 8.833333333333334 4.958333333333334 8.609449999999999 4.958333333333334 8.333333333333334C4.958333333333334 8.057193333333334 5.182193333333334 7.833333333333334 5.458333333333333 7.833333333333334L6 7.833333333333334C6.27614 7.833333333333334 6.5 8.057193333333334 6.5 8.333333333333334z" fill="currentColor"></path><path d="M7.750000000000001 11.666666666666668C7.750000000000001 11.942783333333333 7.526140000000001 12.166666666666666 7.25 12.166666666666666L6.708333333333334 12.166666666666666C6.432193333333334 12.166666666666666 6.208333333333334 11.942783333333333 6.208333333333334 11.666666666666668C6.208333333333334 11.390550000000001 6.432193333333334 11.166666666666668 6.708333333333334 11.166666666666668L7.25 11.166666666666668C7.526140000000001 11.166666666666668 7.750000000000001 11.390550000000001 7.750000000000001 11.666666666666668z" fill="currentColor"></path>`
}),
tag('div', {
class: 'text',
innerHTML: video.stat.danmaku,
}),
],
}),
tag('div', {
class: 'pubdate item',
children: tag('div', {
class: 'text',
children: formatDateTime(new Date(video.pubdate * 1000))
})
})
]
}),
],
}));
/**
* 视频播放器
*/
player = new Player();
player.setVideo(video);
container.appendChild(tag('div', {
id: 'playerWrap',
class: 'player-wrap',
children: [
player.playerElement,
tag('div', {
class: 'video-controls', children: [
tag('div', {
class: 'goto item', attrs: { title: 'BV号跳转' }, children: [
tag('span', { innerText: 'B' }),
tag('form', {
class: 'goto-form', children: [
tag('input', { class: 'goto-input', attrs: { type: 'normal', value: 'BV' } }),
tag('button', { class: 'goto-confirm', attrs: { type: 'button' }, innerText: '→' }),
tag('span', { class: 'goto-tip' }),
]
}),
]
}, (t) => {
let idx;
t.addEventListener('mouseenter', () => {
clearTimeout(idx);
t.classList.add('hover');
})
t.addEventListener('mouseleave', () => {
idx = setTimeout(() => { t.classList.remove('hover') }, 200);
})
t.querySelector('.goto-confirm').addEventListener('click', e => {
e.preventDefault();
t.querySelector('.goto-form').requestSubmit();
});
t.querySelector('.goto-form').addEventListener('submit', (e) => {
e.preventDefault();
const x = e.target.children[0].value;
if (x.match(/^(BV|av|bv|AV)/)) {
if (x.match(/^(BV|bv)/) && player.video_info.bvid == x) {
t.querySelector('.goto-tip').innerText = `当前已经在播放 ${x} 了`;
return;
}
if (x.match(/^(av|AV)/) && x.substring(2) == player.video_info.aid + '') {
t.querySelector('.goto-tip').innerText = `当前已经在播放 ${x} 了`;
return;
}
t.querySelector('.goto-tip').innerText = '';
getInfo(x).then((res) => {
videos.splice(currentIndex + 1, 0, {
goto: 'av',
id: res.aid,
cid: res.cid,
})
if (!videoInfos['av_' + res.aid]) videoInfos['av_' + res.aid] = res;
nextVideo().then();
}).catch((err) => {
t.querySelector('.goto-tip').innerText = '视频不存在';
})
return;
}
t.querySelector('.goto-tip').innerText = '必须以BV/av开头';
});
}),
tag('div', { class: 'previous item', attrs: { title: '上一个([)' }, innerText: '<' }, (t) => t.addEventListener('click', previousVideo)),
tag('div', { class: 'next item', attrs: { title: '下一个(])' }, innerText: '>' }, (t) => t.addEventListener('click', nextVideo)),
]
})
]
}))
// 视频 toolbar
container.appendChild(tag('div', {
id: 'arc_toolbar_report',
children: tag('div', {
class: 'video-toolbar',
children: [
tag('div', {
class: 'like item' + (video.relation.like ? ' on' : ''),
attrs: { title: '点赞(Q)' },
children: [
tag('svg', { class: 'icon', attrs: { viewBox: "0 0 36 36" }, innerHTML: '<path fill-rule="evenodd" clip-rule="evenodd" d="M9.77234 30.8573V11.7471H7.54573C5.50932 11.7471 3.85742 13.3931 3.85742 15.425V27.1794C3.85742 29.2112 5.50932 30.8573 7.54573 30.8573H9.77234ZM11.9902 30.8573V11.7054C14.9897 10.627 16.6942 7.8853 17.1055 3.33591C17.2666 1.55463 18.9633 0.814421 20.5803 1.59505C22.1847 2.36964 23.243 4.32583 23.243 6.93947C23.243 8.50265 23.0478 10.1054 22.6582 11.7471H29.7324C31.7739 11.7471 33.4289 13.402 33.4289 15.4435C33.4289 15.7416 33.3928 16.0386 33.3215 16.328L30.9883 25.7957C30.2558 28.7683 27.5894 30.8573 24.528 30.8573H11.9911H11.9902Z" fill="currentColor"></path>' }),
tag('span', { class: 'text', children: video.stat.like + '' }),
]
}, (t) => t.addEventListener('click', async () => {
let text;
if (!t.classList.contains('on')) {
const res = await likeVideo(videos[currentIndex].id);
if (res.code == 0) {
t.classList.add('on')
text = '点赞成功'
t.querySelector('.text').innerText = player.video_info.stat.like + 1;
} else {
text = '点赞失败, 未登录'
}
} else {
t.classList.remove('on')
await unlikeVideo(videos[currentIndex].id)
text = '取消点赞'
t.querySelector('.text').innerText = player.video_info.stat.like;
}
showToast(text);
})),
tag('div', {
class: 'coin item' + (video.relation.coin ? ' on' : ''),
attrs: { title: '投币' },
children: [
tag('svg', { class: 'icon', attrs: { viewBox: "0 0 28 28" }, innerHTML: '<path fill-rule="evenodd" clip-rule="evenodd" d="M14.045 25.5454C7.69377 25.5454 2.54504 20.3967 2.54504 14.0454C2.54504 7.69413 7.69377 2.54541 14.045 2.54541C20.3963 2.54541 25.545 7.69413 25.545 14.0454C25.545 17.0954 24.3334 20.0205 22.1768 22.1771C20.0201 24.3338 17.095 25.5454 14.045 25.5454ZM9.66202 6.81624H18.2761C18.825 6.81624 19.27 7.22183 19.27 7.72216C19.27 8.22248 18.825 8.62807 18.2761 8.62807H14.95V10.2903C17.989 10.4444 20.3766 12.9487 20.3855 15.9916V17.1995C20.3854 17.6997 19.9799 18.1052 19.4796 18.1052C18.9793 18.1052 18.5738 17.6997 18.5737 17.1995V15.9916C18.5667 13.9478 16.9882 12.2535 14.95 12.1022V20.5574C14.95 21.0577 14.5444 21.4633 14.0441 21.4633C13.5437 21.4633 13.1382 21.0577 13.1382 20.5574V12.1022C11.1 12.2535 9.52148 13.9478 9.51448 15.9916V17.1995C9.5144 17.6997 9.10883 18.1052 8.60856 18.1052C8.1083 18.1052 7.70273 17.6997 7.70265 17.1995V15.9916C7.71158 12.9487 10.0992 10.4444 13.1382 10.2903V8.62807H9.66202C9.11309 8.62807 8.66809 8.22248 8.66809 7.72216C8.66809 7.22183 9.11309 6.81624 9.66202 6.81624Z" fill="currentColor"></path>' }),
tag('span', { class: 'text', children: video.stat.coin + '' }),
]
}),
tag('div', {
class: 'favorite item' + (video.relation.favorite ? ' on' : ''),
attrs: { title: '收藏(E)' },
children: [
tag('svg', { class: 'icon', attrs: { viewBox: "0 0 28 28" }, innerHTML: '<path fill-rule="evenodd" clip-rule="evenodd" d="M19.8071 9.26152C18.7438 9.09915 17.7624 8.36846 17.3534 7.39421L15.4723 3.4972C14.8998 2.1982 13.1004 2.1982 12.4461 3.4972L10.6468 7.39421C10.1561 8.36846 9.25639 9.09915 8.19315 9.26152L3.94016 9.91102C2.63155 10.0734 2.05904 11.6972 3.04049 12.6714L6.23023 15.9189C6.96632 16.6496 7.29348 17.705 7.1299 18.7605L6.39381 23.307C6.14844 24.6872 7.62063 25.6614 8.84745 25.0119L12.4461 23.0634C13.4276 22.4951 14.6544 22.4951 15.6359 23.0634L19.2345 25.0119C20.4614 25.6614 21.8518 24.6872 21.6882 23.307L20.8703 18.7605C20.7051 17.705 21.0339 16.6496 21.77 15.9189L24.9597 12.6714C25.9412 11.6972 25.3687 10.0734 24.06 9.91102L19.8071 9.26152Z" fill="currentColor"></path>' }),
tag('span', { class: 'text', children: video.stat.favorite + '' }),
]
}),
tag('div', {
class: 'share item',
attrs: { title: '转发(T)' },
children: [
tag('svg', { class: 'icon', attrs: { viewBox: "0 0 28 28" }, innerHTML: '<path d="M12.6058 10.3326V5.44359C12.6058 4.64632 13.2718 4 14.0934 4C14.4423 4 14.78 4.11895 15.0476 4.33606L25.3847 12.7221C26.112 13.3121 26.2087 14.3626 25.6007 15.0684C25.5352 15.1443 25.463 15.2144 25.3847 15.2779L15.0476 23.6639C14.4173 24.1753 13.4791 24.094 12.9521 23.4823C12.7283 23.2226 12.6058 22.8949 12.6058 22.5564V18.053C7.59502 18.053 5.37116 19.9116 2.57197 23.5251C2.47607 23.6489 2.00031 23.7769 2.00031 23.2122C2.00031 16.2165 3.90102 10.3326 12.6058 10.3326Z" fill="currentColor"></path>' }),
tag('span', { class: 'text', children: video.stat.share + '' }),
tag('span', { class: 'copy-tip', children: '点击复制视频链接' }),
]
}, (t) => {
t.addEventListener('click', () => {
shareClick().then((res) => {
if (res.code == 0) t.querySelector('.text').innerText = parseInt(player.video_info.stat.share) + 1;
t.querySelector('.copy-tip').innerText = '复制成功';
setTimeout(async () => t.querySelector('.copy-tip').innerText = '点击复制视频链接', 3000);
})
});
}),
]
})
}));
/**
* 视频简介
*/
container.appendChild(tag('div', {
id: 'v_desc', class: 'video-desc-container', children: tag('div', {
class: 'basic-desc-info',
children: parseDesc(video.desc_v2)
})
}))
}
/**
* 获取当前 currentIndex 视频信息
* @returns {Promise<Object>}
*/
async function getCurrentVideo() {
const v = videos[currentIndex];
const v1 = videoInfos[v.goto + '_' + v.id];
if (v1) return v1;
const v2 = await getInfo(v.id, v.cid);
videoInfos[v.goto + '_' + v.id] = v2;
return v2;
}
/**
* 更新视频信息
*/
async function updateVideo() {
const v = videos[currentIndex];
if (!v) {
console.error('视频获取失败');
return;
}
let video = await getCurrentVideo();
// console.log('video', video);
if (!inited) {
return await init(video);
}
document.querySelector('.up-avatar-wrap').setAttribute('href', 'https://space.bilibili.com/' + video.owner.mid);
document.querySelector('.up-detail-top').setAttribute('href', 'https://space.bilibili.com/' + video.owner.mid);
document.querySelector('.up-detail-top').innerHTML = video.owner.name;
document.querySelector('.up-avatar').setAttribute('src', video.owner.face);
document.querySelector('.up-detail-bvid').setAttribute('href', '/video/' + video.bvid);
document.querySelector('.up-detail-bvid').innerHTML = video.bvid;
document.querySelector('.video-title').innerText = video.title;
document.querySelector('.video-meta .view .text').innerHTML = video.stat.view;
document.querySelector('.video-meta .danmaku .text').innerHTML = video.stat.danmaku;
document.querySelector('.video-meta .pubdate .text').innerHTML = formatDateTime(new Date(video.pubdate * 1000));
player.setVideo(video);
document.querySelector('.video-toolbar .like .text').innerHTML = video.stat.like;
document.querySelector('.video-toolbar .coin .text').innerHTML = video.stat.coin;
document.querySelector('.video-toolbar .favorite .text').innerHTML = video.stat.favorite;
document.querySelector('.video-toolbar .share .text').innerHTML = video.stat.share;
document.querySelectorAll('.video-toolbar .item').forEach((e) => e.classList.remove('on'));
if (video.relation.like) document.querySelector('.video-toolbar .like').classList.add('on');
if (video.relation.coin) document.querySelector('.video-toolbar .coin').classList.add('on');
if (video.relation.favorite) document.querySelector('.video-toolbar .favorite').classList.add('on');
if (video.relation.share) document.querySelector('.video-toolbar .share').classList.add('on');
document.querySelector('#v_desc .basic-desc-info').innerHTML = '';
parseDesc(video.desc_v2).forEach((i) => document.querySelector('#v_desc .basic-desc-info').appendChild(i));
}
let last_rcmded_index = -1;
async function tryGetRcmd() {
if (currentIndex >= last_rcmded_index) {
const res = await getRcmd();
if (res) {
last_rcmded_index = videos.length + res.length - 4;
res.forEach(i => videos.push(i));
}
}
}
/**
* 视频中间弹窗提示
*/
function showToast(text) {
const i = document.querySelector('.incenter');
i.innerText = text;
i.style.opacity = 1;
i.style.transform = 'translateY(0)';
setTimeout(() => { i.style.opacity = 0; i.style.transform = 'translateY(5px)'; }, 1000);
}
/**
* 下一个视频
*/
async function nextVideo() {
await tryGetRcmd();
if (currentIndex < videos.length - 1) {
if (player) player.pause();
if (document.querySelector('.bpx-player-loading-panel')) document.querySelector('.bpx-player-loading-panel').classList.add('bpx-state-loading');
// 保存当前视频播放时长
if (videos[currentIndex]) {
player.video_info.currentTime = player.currentTime;
if (Math.abs(player.currentTime - (player.video_info.lastRecordTime || 0)) > 3) {
player.video_info.lastRecordTime = player.currentTime;
record_history(player.video_info.aid, player.video_info.cid, player.currentTime);
}
}
currentIndex = currentIndex + 1;
const last_showlist = JSON.parse((window.localStorage.getItem('last_showlist') || '[]'));
const addto_showlist = (v) => {
if (!last_showlist.includes(v.goto + '_' + v.id)) last_showlist.push(v.goto + '_' + v.id);
if (last_showlist.length > 22) last_showlist.shift();
};
while (videos[currentIndex].goto != 'av') {
currentIndex = currentIndex + 1;
addto_showlist(videos[currentIndex])
await tryGetRcmd();
}
addto_showlist(videos[currentIndex])
window.localStorage.setItem('last_showlist', JSON.stringify(last_showlist));
await updateVideo();
record_history(player.video_info.aid, player.video_info.cid, 0);
return;
}
showToast('已经到顶啦 >ʍ<');
}
/**
* 上一个视频
*/
async function previousVideo() {
if (currentIndex > 0) {
if (document.querySelector('.bpx-player-loading-panel')) document.querySelector('.bpx-player-loading-panel').classList.add('bpx-state-loading');
currentIndex = currentIndex - 1;
while (videos[currentIndex].goto != 'av' && currentIndex > 0) {
currentIndex = currentIndex - 1;
}
await updateVideo()
return;
}
showToast('已经到顶啦 >ʍ<');
}
/**
* 点赞按钮
*/
async function likeClick() {
const t = document.querySelector('.video-toolbar .like');
let text;
if (!t.classList.contains('on')) {
const res = await likeVideo(videos[currentIndex].id);
if (res.code == 0) {
t.classList.add('on')
text = '点赞成功'
} else {
text = '点赞失败, 未登录'
}
} else {
t.classList.remove('on')
await unlikeVideo(videos[currentIndex].id)
text = '取消点赞'
}
showToast(text);
}
/**
* 转发按钮
*/
async function shareClick() {
let res = await shareVideo(videos[currentIndex].id);
await navigator.clipboard.writeText('https://www.bilibili.com/video/' + player.video_info.bvid);
return res;
}
/**
* 退出全屏
*/
const closeFullscreen = () => {
if (document.exitFullscreen) {
document.exitFullscreen();
} else if (document.webkitExitFullscreen) { /* Safari */
document.webkitExitFullscreen();
} else if (document.msExitFullscreen) { /* IE11 */
document.msExitFullscreen();
}
}
/**
* 进入全屏
*/
const openFullscreen = () => {
const el = player.playerElement;
if (!el) return;
if (el.requestFullscreen) {
el.requestFullscreen();
} else if (el.webkitRequestFullscreen) { /* Safari */
el.webkitRequestFullscreen();
} else if (el.msRequestFullscreen) { /* IE11 */
el.msRequestFullscreen();
}
}
/**
* 切换全屏
*/
const toggleFullscreen = () => {
document.fullscreenElement ? closeFullscreen() : openFullscreen();
}
window.addEventListener('load', async () => {
mixin_key = await getMixinKey();
container = document.querySelector('.error-container');
if (!container) return;
document.querySelector("iframe") && document.querySelector("iframe").remove();
document.querySelectorAll("script") && document.querySelectorAll("script").forEach((i) => i.remove());
if (isMobile()) {
document.querySelector("html").style.height = `${window.screen.height}px`;
document.querySelector("html").style.overflow = 'hidden';
document.body.style.overflow = 'hidden';
}
document.querySelector('meta[name="viewport"]').content = 'width=device-width, height=device-height, user-scalable=yes, initial-scale=1.0';
container.innerHTML = '';
document.title = '404 刷视频'
container.style.cssText = 'margin-top: 0; margin-bottom: 0; padding: 10px 40px; width: 740px'
let style = document.createElement('style');
style.innerHTML = styles;
document.body.after(style);
nextVideo().then();
})
let container;
let mixin_key;
let videos = [];
let videoInfos = {};
let currentIndex = -1;
let inited = false;
let player_icon = {
animationData: JSON.parse('{"v":"5.6.6","ip":0,"op":1,"fr":60,"w":18,"h":18,"layers":[{"ind":1890,"nm":"surface6457","ao":0,"ip":0,"op":60,"st":0,"ty":4,"ks":{"ty":"tr","o":{"k":100},"r":{"k":0},"p":{"k":[0,0]},"a":{"k":[0,0]},"s":{"k":[133.33,133.33]},"sk":{"k":0},"sa":{"k":0}},"shapes":[{"ty":"gr","hd":false,"nm":"surface6457","it":[{"ty":"gr","hd":false,"it":[{"ty":"sh","ks":{"k":{"i":[[0,0],[0,0],[0.37,0],[0,0.38],[0,0],[-0.37,0],[0,-0.38]],"o":[[0,0],[0,0.38],[-0.37,0],[0,0],[0,-0.38],[0.37,0],[0,0]],"v":[[9.29,6.28],[9.29,7.93],[8.61,8.6],[7.94,7.93],[7.94,6.28],[8.61,5.6],[9.29,6.28]],"c":true}}},{"ty":"fl","o":{"k":100},"c":{"k":[0.2,0.2,0.2,1]}},{"ty":"tr","o":{"k":100},"r":{"k":0},"p":{"k":[0,0]},"a":{"k":[0,0]},"s":{"k":[100,100]},"sk":{"k":0},"sa":{"k":0},"hd":false}]},{"ty":"gr","hd":false,"it":[{"ty":"sh","ks":{"k":{"i":[[0,0],[0,0],[0.36,0],[0,0.36],[0,0],[-0.36,0],[0,-0.36]],"o":[[0,0],[0,0.36],[-0.36,0],[0,0],[0,-0.36],[0.36,0],[0,0]],"v":[[5.44,6.26],[5.44,7.95],[4.78,8.6],[4.12,7.95],[4.12,6.26],[4.78,5.6],[5.44,6.26]],"c":true}}},{"ty":"fl","o":{"k":100},"c":{"k":[0.2,0.2,0.2,1]}},{"ty":"tr","o":{"k":100},"r":{"k":0},"p":{"k":[0,0]},"a":{"k":[0,0]},"s":{"k":[100,100]},"sk":{"k":0},"sa":{"k":0},"hd":false}]},{"ty":"gr","hd":false,"it":[{"ty":"sh","ks":{"k":{"i":[[0,0],[0,0],[1.38,0],[0,0],[0,1.38],[0,0],[-1.38,0],[0,0],[0,-1.38]],"o":[[0,0],[0,1.38],[0,0],[-1.38,0],[0,0],[0,-1.38],[0,0],[1.38,0],[0,0]],"v":[[7,-3],[7,3],[4.5,5.5],[-4.5,5.5],[-7,3],[-7,-3],[-4.5,-5.5],[4.5,-5.5],[7,-3]],"c":true}}},{"ty":"st","lc":1,"lj":1,"ml":4,"o":{"k":100},"w":{"k":1.5},"c":{"k":[0.2,0.2,0.2,1]},"hd":false},{"ty":"tr","o":{"k":100},"r":{"k":0},"p":{"k":[6.74,7.13]},"a":{"k":[0,0]},"s":{"k":[75,75]},"sk":{"k":0},"sa":{"k":0},"hd":false}]},{"ty":"gr","hd":false,"it":[{"ty":"sh","ks":{"k":{"i":[[0,0],[0,0],[1.03,0],[0,0],[0,1.04],[0,0],[-1.04,0],[0,0],[0,-1.04]],"o":[[0,0],[0,1.04],[0,0],[-1.04,0],[0,0],[0,-1.04],[0,0],[1.03,0],[0,0]],"v":[[11.99,4.88],[11.99,9.38],[10.11,11.25],[3.36,11.25],[1.49,9.38],[1.49,4.88],[3.36,3],[10.11,3],[11.99,4.88]],"c":true}}},{"ty":"fl","o":{"k":100},"c":{"k":[1,1,1,1]}},{"ty":"tr","o":{"k":100},"r":{"k":0},"p":{"k":[0,0]},"a":{"k":[0,0]},"s":{"k":[100,100]},"sk":{"k":0},"sa":{"k":0},"hd":false}]},{"ty":"gr","hd":false,"it":[{"ty":"sh","ks":{"k":{"i":[[0,0],[0,0],[0.33,0.27],[-0.23,0.27],[0,0],[-0.33,-0.27],[0.24,-0.27]],"o":[[0,0],[-0.24,0.27],[-0.33,-0.27],[0,0],[0.23,-0.27],[0.33,0.27],[0,0]],"v":[[10.5,1.42],[9.07,3.04],[8.04,3.04],[7.87,2.07],[9.3,0.45],[10.33,0.45],[10.5,1.42]],"c":true}}},{"ty":"fl","o":{"k":100},"c":{"k":[0.2,0.2,0.2,1]}},{"ty":"tr","o":{"k":100},"r":{"k":0},"p":{"k":[0,0]},"a":{"k":[0,0]},"s":{"k":[100,100]},"sk":{"k":0},"sa":{"k":0},"hd":false}]},{"ty":"gr","hd":false,"it":[{"ty":"sh","ks":{"k":{"i":[[0,0],[0,0],[0.28,-0.25],[0.24,0.26],[0,0],[-0.28,0.26],[-0.25,-0.26]],"o":[[0,0],[0.24,0.26],[-0.28,0.26],[0,0],[-0.25,-0.26],[0.28,-0.25],[0,0]],"v":[[4.1,0.52],[5.57,2.08],[5.5,3.01],[4.55,3.01],[3.08,1.45],[3.15,0.51],[4.1,0.52]],"c":true}}},{"ty":"fl","o":{"k":100},"c":{"k":[0.2,0.2,0.2,1]}},{"ty":"tr","o":{"k":100},"r":{"k":0},"p":{"k":[0,0]},"a":{"k":[0,0]},"s":{"k":[100,100]},"sk":{"k":0},"sa":{"k":0},"hd":false}]},{"ty":"tr","o":{"k":100},"r":{"k":0},"p":{"k":[0,0]},"a":{"k":[0,0]},"s":{"k":[100,100]},"sk":{"k":0},"sa":{"k":0},"hd":false}]}]}],"meta":{"g":"LF SVG to Lottie"},"assets":[]}')
};
let player;
/**
* ------ dm.proto.js --- start ------
**/
let decodeDmSegMobileReply;
(function () {
const decodeDmColorfulType = {
0: "NoneType",
60001: "VipGradualColor",
};
function _decodeDanmakuAIFlag(bb) {
let message = {};
end_of_message: while (!isAtEnd(bb)) {
let tag = readVarint32(bb);
switch (tag >>> 3) {
case 0:
break end_of_message;
// repeated DanmakuFlag dm_flags = 1;
case 1: {
let limit = pushTemporaryLength(bb);
let values = message.dm_flags || (message.dm_flags = []);
values.push(_decodeDanmakuFlag(bb));
bb.limit = limit;
break;
}
default:
skipUnknownField(bb, tag & 7);
}
}
return message;
}
function _decodeDanmakuElem(bb) {
let message = {};
end_of_message: while (!isAtEnd(bb)) {
let tag = readVarint32(bb);
switch (tag >>> 3) {
case 0:
break end_of_message;
// optional int64 id = 1;
case 1: {
message.id = readVarint64(bb, /* unsigned */ false);
break;
}
// optional int32 progress = 2;
case 2: {
message.progress = readVarint32(bb);
break;
}
// optional int32 mode = 3;
case 3: {
message.mode = readVarint32(bb);
break;
}
// optional int32 fontsize = 4;
case 4: {
message.fontsize = readVarint32(bb);
break;
}
// optional uint32 color = 5;
case 5: {
message.color = readVarint32(bb) >>> 0;
break;
}
// optional string midHash = 6;
case 6: {
message.midHash = readString(bb, readVarint32(bb));
break;
}
// optional string content = 7;
case 7: {
message.content = readString(bb, readVarint32(bb));
break;
}
// optional int64 ctime = 8;
case 8: {
message.ctime = readVarint64(bb, /* unsigned */ false);
break;
}
// optional int32 weight = 9;
case 9: {
message.weight = readVarint32(bb);
break;
}
// optional string action = 10;
case 10: {
message.action = readString(bb, readVarint32(bb));
break;
}
// optional int32 pool = 11;
case 11: {
message.pool = readVarint32(bb);
break;
}
// optional string idStr = 12;
case 12: {
message.idStr = readString(bb, readVarint32(bb));
break;
}
// optional int32 attr = 13;
case 13: {
message.attr = readVarint32(bb);
break;
}
// optional string animation = 22;
case 22: {
message.animation = readString(bb, readVarint32(bb));
break;
}
// optional DmColorfulType colorful = 24;
case 24: {
message.colorful = decodeDmColorfulType[readVarint32(bb)];
break;
}
default:
skipUnknownField(bb, tag & 7);
}
}
return message;
}
function _decodeDanmakuFlag(bb) {
let message = {};
end_of_message: while (!isAtEnd(bb)) {
let tag = readVarint32(bb);
switch (tag >>> 3) {
case 0:
break end_of_message;
// optional int64 dmid = 1;
case 1: {
message.dmid = readVarint64(bb, /* unsigned */ false);
break;
}
// optional uint32 flag = 2;
case 2: {
message.flag = readVarint32(bb) >>> 0;
break;
}
default:
skipUnknownField(bb, tag & 7);
}
}
return message;
}
function _decodeDmColorful(bb) {
let message = {};
end_of_message: while (!isAtEnd(bb)) {
let tag = readVarint32(bb);
switch (tag >>> 3) {
case 0:
break end_of_message;
// optional DmColorfulType type = 1;
case 1: {
message.type = decodeDmColorfulType[readVarint32(bb)];
break;
}
// optional string src = 2;
case 2: {
message.src = readString(bb, readVarint32(bb));
break;
}
default:
skipUnknownField(bb, tag & 7);
}
}
return message;
}
decodeDmSegMobileReply = function (binary) {
return _decodeDmSegMobileReply(wrapByteBuffer(binary));
}
function _decodeDmSegMobileReply(bb) {
let message = {};
end_of_message: while (!isAtEnd(bb)) {
let tag = readVarint32(bb);
switch (tag >>> 3) {
case 0:
break end_of_message;
// repeated DanmakuElem elems = 1;
case 1: {
let limit = pushTemporaryLength(bb);
let values = message.elems || (message.elems = []);
values.push(_decodeDanmakuElem(bb));
bb.limit = limit;
break;
}
// optional int32 state = 2;
case 2: {
message.state = readVarint32(bb);
break;
}
// optional DanmakuAIFlag ai_flag = 3;
case 3: {
let limit = pushTemporaryLength(bb);
message.ai_flag = _decodeDanmakuAIFlag(bb);
bb.limit = limit;
break;
}
// repeated DmColorful colorfulSrc = 5;
case 5: {
let limit = pushTemporaryLength(bb);
let values = message.colorfulSrc || (message.colorfulSrc = []);
values.push(_decodeDmColorful(bb));
bb.limit = limit;
break;
}
default:
skipUnknownField(bb, tag & 7);
}
}
return message;
}
function pushTemporaryLength(bb) {
let length = readVarint32(bb);
let limit = bb.limit;
bb.limit = bb.offset + length;
return limit;
}
function skipUnknownField(bb, type) {
switch (type) {
case 0: while (readByte(bb) & 0x80) { } break;
case 2: skip(bb, readVarint32(bb)); break;
case 5: skip(bb, 4); break;
case 1: skip(bb, 8); break;
default: throw new Error("Unimplemented type: " + type);
}
}
function wrapByteBuffer(bytes) {
return { bytes, offset: 0, limit: bytes.length };
}
function skip(bb, offset) {
if (bb.offset + offset > bb.limit) {
throw new Error('Skip past limit');
}
bb.offset += offset;
}
function isAtEnd(bb) {
return bb.offset >= bb.limit;
}
function advance(bb, count) {
let offset = bb.offset;
if (offset + count > bb.limit) {
throw new Error('Read past limit');
}
bb.offset += count;
return offset;
}
function readString(bb, count) {
// Sadly a hand-coded UTF8 decoder is much faster than subarray+TextDecoder in V8
let offset = advance(bb, count);
let fromCharCode = String.fromCharCode;
let bytes = bb.bytes;
let invalid = '\uFFFD';
let text = '';
for (let i = 0; i < count; i++) {
let c1 = bytes[i + offset], c2, c3, c4, c;
// 1 byte
if ((c1 & 0x80) === 0) {
text += fromCharCode(c1);
}
// 2 bytes
else if ((c1 & 0xE0) === 0xC0) {
if (i + 1 >= count) text += invalid;
else {
c2 = bytes[i + offset + 1];
if ((c2 & 0xC0) !== 0x80) text += invalid;
else {
c = ((c1 & 0x1F) << 6) | (c2 & 0x3F);
if (c < 0x80) text += invalid;
else {
text += fromCharCode(c);
i++;
}
}
}
}
// 3 bytes
else if ((c1 & 0xF0) == 0xE0) {
if (i + 2 >= count) text += invalid;
else {
c2 = bytes[i + offset + 1];
c3 = bytes[i + offset + 2];
if (((c2 | (c3 << 8)) & 0xC0C0) !== 0x8080) text += invalid;
else {
c = ((c1 & 0x0F) << 12) | ((c2 & 0x3F) << 6) | (c3 & 0x3F);
if (c < 0x0800 || (c >= 0xD800 && c <= 0xDFFF)) text += invalid;
else {
text += fromCharCode(c);
i += 2;
}
}
}
}
// 4 bytes
else if ((c1 & 0xF8) == 0xF0) {
if (i + 3 >= count) text += invalid;
else {
c2 = bytes[i + offset + 1];
c3 = bytes[i + offset + 2];
c4 = bytes[i + offset + 3];
if (((c2 | (c3 << 8) | (c4 << 16)) & 0xC0C0C0) !== 0x808080) text += invalid;
else {
c = ((c1 & 0x07) << 0x12) | ((c2 & 0x3F) << 0x0C) | ((c3 & 0x3F) << 0x06) | (c4 & 0x3F);
if (c < 0x10000 || c > 0x10FFFF) text += invalid;
else {
c -= 0x10000;
text += fromCharCode((c >> 10) + 0xD800, (c & 0x3FF) + 0xDC00);
i += 3;
}
}
}
}
else text += invalid;
}
return text;
}
function readByte(bb) {
return bb.bytes[advance(bb, 1)];
}
function readVarint32(bb) {
let c = 0;
let value = 0;
let b;
do {
b = readByte(bb);
if (c < 32) value |= (b & 0x7F) << c;
c += 7;
} while (b & 0x80);
return value;
}
function readVarint64(bb, unsigned) {
let part0 = 0;
let part1 = 0;
let part2 = 0;
let b;
b = readByte(bb); part0 = (b & 0x7F); if (b & 0x80) {
b = readByte(bb); part0 |= (b & 0x7F) << 7; if (b & 0x80) {
b = readByte(bb); part0 |= (b & 0x7F) << 14; if (b & 0x80) {
b = readByte(bb); part0 |= (b & 0x7F) << 21; if (b & 0x80) {
b = readByte(bb); part1 = (b & 0x7F); if (b & 0x80) {
b = readByte(bb); part1 |= (b & 0x7F) << 7; if (b & 0x80) {
b = readByte(bb); part1 |= (b & 0x7F) << 14; if (b & 0x80) {
b = readByte(bb); part1 |= (b & 0x7F) << 21; if (b & 0x80) {
b = readByte(bb); part2 = (b & 0x7F); if (b & 0x80) {
b = readByte(bb); part2 |= (b & 0x7F) << 7;
}
}
}
}
}
}
}
}
}
return {
low: part0 | (part1 << 28),
high: (part1 >>> 4) | (part2 << 24),
unsigned,
};
}
})();
/**
* ------ dm.proto.js --- end ------
**/
})();