原脚本的[循环发送]修改为[说书人]功能,现在说书可以直接粘贴整段文字,不用自己手动分割弹幕
// ==UserScript==
// @name 枝江拖拉机 独轮车+说书人整合优化版
// @namespace http://tampermonkey.net/
// @version 1.1.4
// @description 原脚本的[循环发送]修改为[说书人]功能,现在说书可以直接粘贴整段文字,不用自己手动分割弹幕
// @author 原作者:你失散已久的父亲向晚&修改者:9otihc
// @match https://live.bilibili.com/*
// @icon 
// @grant GM_getValue
// @grant GM_setValue
// @license MIT
// ==/UserScript==
(function () {
'use strict';
var check = setInterval(function () {
let point1 = document.getElementsByClassName("bottom-actions p-relative")[0];
let point2 = document.getElementsByClassName('chat-history-panel')[0];
if (point1 !== undefined && point2 !== undefined) {
let panelBtn = 0;//面板开关的数值,开为1,关为0
let tractorBtn = 0;//拖拉机开关数值,开为1,关为0
var tractorValue = '';//拖拉机内容
var mudTruckValue = '';//泥头车内容
var tractor;//拖拉机定时器
var value;//快速发送内容
var time = '';//弹幕发送间隔
var mudLength='18';//弹幕长度
var index = 0;
//创建控制面板开关按钮
let btn = document.createElement('div');
btn.className = 'p-absolute';
btn.style.left = '0';
btn.style.top = '0';
btn.innerHTML = '<button style="position: relative; box-sizing: border-box; line-height: 1; margin: 0; padding: 6px 12px; border: 0; cursor: pointer; outline: 0; overflow: hidden; display: inline-flex; justify-content: center; align-items: center; min-width: 80px; height: 24px; font-size: 12px; background-color: #23ade5; color: #fff; border-radius: 4px; "><span class="txt" style="position: relative; ">拖拉机面板</span></button>';
point1.appendChild(btn);
//创建拖拉机关闭按钮
let btn1 = document.createElement('div');
btn1.className = 'p-absolute';
btn1.style.left = '90px';
btn1.style.top = '0';
btn1.innerHTML = '<button id="closeBtn" style="display: none; position: relative; box-sizing: border-box; line-height: 1; margin: 0; padding: 6px 12px; border: 0; cursor: pointer; outline: 0; overflow: hidden; display: inline-flex; justify-content: center; align-items: center; min-width: 80px; height: 24px; font-size: 12px; background-color: #23ade5; color: #fff; border-radius: 4px; "><span class="txt" style="position: relative; ">关闭拖拉机</span></button>';
btn1.style.display = 'none';
point1.appendChild(btn1);
//创建控制面板
let panel = document.createElement('div');
panel.style.position = 'absolute';
panel.style.bottom = '145px';
panel.style.left = '0';
panel.style.width = '100%';
panel.style.zIndex = 50;
panel.style.backgroundColor = '#fff';
panel.style.display = 'flex';
panel.style.justifyContent = 'center';
panel.style.alignItems = 'center';
panel.innerHTML = '<img src="https://i0.hdslb.com/bfs/album/[email protected]" width="100%" style="opacity: 0.3;filter: blur(3px);" /> <div id="partition" style=" display: none; position: absolute; top: 0; left: 0; z-index: 52; width: 100%; height: 100%; margin: 0; padding: 0; font-size: 20px; font-weight: 700; background-color: rgba(255, 255, 255, 0.7); align-items: center; justify-content: center; " > <div>嘀哩啪啦吧啦啪啦boom</div> </div> <div style=" position: absolute; top: 0; left: 0; z-index: 51; width: 100%; height: 100%; margin: 0; padding: 0; font-weight: 700; " > <div id="myHead" style=" width: 100%; height: 10%; margin: 0; padding: 0; display: flex; justify-content: space-around; " > <div id="dulunche" data-index="0" style=" margin: 0; padding: 0; width: 33%; height: 100%; text-align: center; cursor: pointer; " > 独轮车 </div> <div id="loop" data-index="1" style=" margin: 0; padding: 0; width: 33%; height: 100%; border-left: 1px solid #e1e1e1; text-align: center; cursor: pointer; " > 说书人 </div> <div id="random" data-index="2" style=" margin: 0; padding: 0; width: 33%; height: 100%; border-left: 1px solid #e1e1e1; text-align: center; cursor: pointer; " > 手动分段说书 </div> </div> <div id="myBody" style="width: 100%; height: 90%; margin: 0; padding: 0"> <div id="dulunchePanel" style=" display: flex; flex-direction: column; justify-content: space-around; align-items: center; width: 100%; height: 100%; margin: 0; padding: 0; " > <input type="text" id="duluncheInput" placeholder="字数不能超过30个字" style="outline: medium; display: block; margin-bottom: 10px; width: 80%" maxlength="100" /> <div id="settime"> 发送间隔为<button id="sub">-</button ><input type="text" id="time" style="text-align: center; width: 1.5rem" /><button id="add">+</button>秒 </div> <button id="ruin" style="width: 28%">开启拖拉机</button> </div> <div id="loopPanel" style="display: none; width: 100%; height: 100%; margin: 0; padding: 0" > <textarea id="loopInput" cols="21" placeholder="输入长度至少大于单个弹幕长度的文字段落" style="width: 45%; height: 90%; margin: 0; padding: 0; resize: none" ></textarea> <div style=" margin: 0; padding: 0; display: flex; flex-direction: column; justify-content: space-around; align-items: center; " > <div id="settime"> 发送间隔为<button id="sub">-</button ><input type="text" id="time" style="text-align: center; width: 1.5rem" /><button id="add">+</button>秒 </div> <div id="setMudLength"> 单个弹幕<button id="sub1">-</button ><input type="text" id="mudLength" style="text-align: center; width: 1.5rem" /><button id="add1">+</button>长度 </div> <button id="ruin" style="width: 55%">开启拖拉机</button> </div> </div> <div id="randomPanel" style="display: none; width: 100%; height: 100%; margin: 0; padding: 0" > <textarea id="randomInput" cols="21" placeholder="手动分段说书模式用 | 或者[回车]分隔不同条弹幕" style="width: 45%; height: 90%; margin: 0; padding: 0; resize: none" ></textarea> <div style=" margin: 0; padding: 0; display: flex; flex-direction: column; justify-content: space-around; align-items: center; " > <div id="settime"> 发送间隔为<button id="sub">-</button ><input type="text" id="time" style="text-align: center; width: 1.5rem" /><button id="add">+</button>秒 </div> <button id="ruin" style="width: 55%">开启拖拉机</button> </div> </div> </div> </div>';
panel.style.display = 'none';
point2.appendChild(panel);
for (var i = 0; i < panel.querySelectorAll('#time').length; i++) {
panel.querySelectorAll('#time')[i].value = GM_getValue('time', '6');
}
for (var i = 0; i < panel.querySelectorAll('#mudLength').length; i++) {
panel.querySelectorAll('#mudLength')[i].value = GM_getValue('mudLength', '15');
}
//为按钮绑定点击事件,点击打开或关闭面板
btn.addEventListener('click', function () {
if (!panelBtn) {
panel.style.display = 'flex';
panelBtn = 1;
}
else {
panel.style.display = 'none';
panelBtn = 0;
}
});
//为控制面板切换绑定事件
for (var i = 0; i < panel.querySelector('#myHead').children.length; i++) {
panel.querySelector('#myHead').children[i].addEventListener('click', function () {
for (var j = 0; j < panel.querySelector('#myBody').children.length; j++) {
panel.querySelector('#myBody').children[j].style.display = 'none';
}
panel.querySelector('#myBody').children[this.getAttribute('data-index')].style.display = 'flex';
});
}
//为加减时间按钮绑定事件
for (var i = 0; i < panel.querySelectorAll('#sub').length; i++) {
panel.querySelectorAll('#sub')[i].addEventListener('click', function () {
let timeClone = panel.querySelector('#time').value;
if (timeClone * 1 > 1) {
timeClone = --timeClone + '';
GM_setValue('time', timeClone);
for (var j = 0; j < panel.querySelectorAll('#sub').length; j++) {
panel.querySelectorAll('#time')[j].value = timeClone;
}
}
});
}
for (var i = 0; i < panel.querySelectorAll('#add').length; i++) {
panel.querySelectorAll('#add')[i].addEventListener('click', function () {
let timeClone = panel.querySelector('#time').value;
timeClone = timeClone * 1;
timeClone = ++timeClone + '';
GM_setValue('time', timeClone);
for (var j = 0; j < panel.querySelectorAll('#add').length; j++) {
panel.querySelectorAll('#time')[j].value = timeClone;
}
});
}
//为间隔时间输入框绑定输入事件
for (var i = 0; i < panel.querySelectorAll('#time').length; i++) {
panel.querySelectorAll('#time')[i].addEventListener('input', function () {
this.value = this.value.replace(/[^\d]/g, '');
GM_setValue('time', this.value);
for (var j = 0; j < panel.querySelectorAll('#time').length; j++) {
panel.querySelectorAll('#time')[j].value = this.value;
}
});
}
//为加减弹幕长度按钮绑定事件
for (var i = 0; i < panel.querySelectorAll('#sub1').length; i++) {
panel.querySelectorAll('#sub1')[i].addEventListener('click', function () {
let mudLengthClone = panel.querySelector('#mudLength').value;
if (mudLengthClone * 1 > 1) {
mudLengthClone = --mudLengthClone + '';
GM_setValue('mudLength', mudLengthClone);
for (var j = 0; j < panel.querySelectorAll('#sub1').length; j++) {
panel.querySelectorAll('#mudLength')[j].value = mudLengthClone;
}
}
});
}
for (var i = 0; i < panel.querySelectorAll('#add1').length; i++) {
panel.querySelectorAll('#add1')[i].addEventListener('click', function () {
let mudLengthClone = panel.querySelector('#mudLength').value;
mudLengthClone = mudLengthClone * 1;
mudLengthClone = ++mudLengthClone + '';
GM_setValue('mudLength', mudLengthClone);
for (var j = 0; j < panel.querySelectorAll('#add1').length; j++) {
panel.querySelectorAll('#mudLength')[j].value = mudLengthClone;
}
});
}
//为弹幕长度输入框绑定输入事件
for (var i = 0; i < panel.querySelectorAll('#mudLength').length; i++) {
panel.querySelectorAll('#mudLength')[i].addEventListener('input', function () {
this.value = this.value.replace(/[^\d]/g, '');
GM_setValue('mudLength', this.value);
for (var j = 0; j < panel.querySelectorAll('#mudLength').length; j++) {
panel.querySelectorAll('#mudLength')[j].value = this.value;
}
});
}
//拖拉机开关闭
//为独轮车开关绑定事件
panel.querySelector('#dulunchePanel').querySelector('#ruin').addEventListener('click', function () {
//开启独轮车
if (!tractorBtn) {
tractorValue = panel.querySelector('#duluncheInput').value;
time = panel.querySelector('#dulunchePanel').querySelector('#time').value;
if (tractorValue != '' && time != '') {
if(tractorValue.length>30){
alert("超过弹幕30字符限制");
}else{
btn.getElementsByTagName('button')[0].getElementsByTagName('span')[0].innerText = '拖拉机启动';
btn.getElementsByTagName('button')[0].style.backgroundColor = '#d93f4b';
go();
tractor = setInterval(go, time * 1000);//弹幕发送间隔时间
panel.querySelector('#partition').style.display = 'flex';
btn1.style.display = 'block';
tractorBtn = 1;
}
}
else if (tractorValue == '' && time != '') {
alert('未设置弹幕');
}
else if (tractorValue != '' && time == '') {
alert('未设置弹幕发送间隔时间');
}
else {
alert('未设置弹幕及弹幕发送间隔时间');
}
}
});
//分割弹幕函数
function seperateMud(mudTruckValue){
if(mudTruckValue.length<1)return NULL;
let s=mudTruckValue;
let dot="。;!?";
dot+='\n';
let flg=0;
let ans="";
for(let i=1;i<=s.length;i++){
if(s[i-1]!='\n')
ans+=s[i-1];
if(i%mudLength==0&&i!=s.length)
{ans+="|";
}
}
return ans;
}
//为说书人模式开关绑定事件
panel.querySelector('#loopPanel').querySelector('#ruin').addEventListener('click', function () {
if (!tractorBtn) {
mudTruckValue = panel.querySelector('#loopInput').value;
time = panel.querySelector('#loopPanel').querySelector('#time').value;
mudLength=panel.querySelector('#loopPanel').querySelector('#mudLength').value;
console.log(mudLength);
if(mudLength==''){
alert('未设置弹幕长度');
}else if(mudLength<1||mudLength>30){
alert('请设置1-30长度范围的单个弹幕长度')
}else if (mudTruckValue != ''&& time != ''&&mudTruckValue.length>=mudLength&&mudLength!='') {
let _mudTruckValue=seperateMud(mudTruckValue);
var valueArray = _mudTruckValue.split('|');
console.log(valueArray);
for(let i=0;i<valueArray.length;i++){
console.log((valueArray[i].length>30?"*":"")+valueArray[i].length+" : "+valueArray[i]);
}
if (valueArray.length > 1) {
tractorValue = valueArray[index];
index++;
go();
tractor = setInterval(function () {
tractorValue = valueArray[index];
if (index < valueArray.length - 1) {
index++;
}
else if (index == valueArray.length - 1) {
index = 0;
}
go();
}, time * 1000);
btn.getElementsByTagName('button')[0].getElementsByTagName('span')[0].innerText = '拖拉机启动';
btn.getElementsByTagName('button')[0].style.backgroundColor = '#d93f4b';
panel.querySelector('#partition').style.display = 'flex';
btn1.style.display = 'block';
tractorBtn = 1;
}
}
else if (mudTruckValue != ''&& time != ''&&mudTruckValue.length<=mudLength) {
alert('需要说书的文字段落长度不应该少于单个弹幕长度');
}
else if (mudTruckValue == '' && time != '') {
alert('未设置弹幕');
}
else if (mudTruckValue != '' && time == '') {
alert('未设置弹幕发送间隔时间');
}
else {
alert('未设置弹幕及弹幕发送间隔时间');
}
}
});
//为手动分段说书模式开关绑定事件
panel.querySelector('#randomPanel').querySelector('#ruin').addEventListener('click', function () {
if (!tractorBtn) {
mudTruckValue = panel.querySelector('#randomInput').value;
time = panel.querySelector('#randomPanel').querySelector('#time').value;
if (mudTruckValue != '' && time != '') {
console.log(mudTruckValue.replaceAll('\n','[|]'));
console.log(mudTruckValue);
mudTruckValue=mudTruckValue.replaceAll('\n','|');
var randomArray = mudTruckValue.split('|');
if (randomArray.length > 1) {
// let _mudTruckValue=seperateMud(mudTruckValue);
var valueArray = mudTruckValue.split('|');
console.log(valueArray);
for(let i=0;i<valueArray.length;i++){
console.log((valueArray[i].length>30?"*":"")+valueArray[i].length+" : "+valueArray[i]);
}
if (valueArray.length > 1) {
tractorValue = valueArray[index];
index++;
go();
tractor = setInterval(function () {
tractorValue = valueArray[index];
if (index < valueArray.length - 1) {
index++;
}
else if (index == valueArray.length - 1) {
index = 0;
}
go();
}, time * 1000);
btn.getElementsByTagName('button')[0].getElementsByTagName('span')[0].innerText = '拖拉机启动';
btn.getElementsByTagName('button')[0].style.backgroundColor = '#d93f4b';
panel.querySelector('#partition').style.display = 'flex';
btn1.style.display = 'block';
tractorBtn = 1;
}
}
else {
alert('请设置大于1条弹幕');
}
}
else if (mudTruckValue == '' && time != '') {
alert('未设置弹幕');
}
else if (mudTruckValue != '' && time == '') {
alert('未设置弹幕发送间隔时间');
}
else {
alert('未设置弹幕及弹幕发送间隔时间');
}
}
});
//为关闭拖拉机按钮绑定事件
btn1.querySelector('#closeBtn').addEventListener('click', function () {
if (tractorBtn) {
tractorBtn = 0;
btn.getElementsByTagName('button')[0].getElementsByTagName('span')[0].innerText = '拖拉机面板';
btn.getElementsByTagName('button')[0].style.backgroundColor = '#23ade5';
panel.querySelector('#partition').style.display = 'none';
btn1.style.display = 'none';
mudTruckValue = '';
index = 0;
clearInterval(tractor);
}
});
//发送弹幕函数
function go() {
let text = document.getElementsByClassName('chat-input')[1];
let evt = document.createEvent('HTMLEvents');
evt.initEvent('input', true, true);
text.value = text._value = tractorValue;
text.dispatchEvent(evt);
document.querySelector('.live-skin-highlight-button-bg').click();
}
clearInterval(check);
}
}, 100);
})();