弹幕词云

bilibili弹幕词云、弹幕分析、弹幕列表

// ==UserScript==
// @license MIT
// @name         弹幕词云
// @namespace    http://tampermonkey.net/
// @version      2.6.3
// @description  bilibili弹幕词云、弹幕分析、弹幕列表
// @author       You
// @match        https://www.bilibili.com/bangumi/play/*
// @match        https://www.bilibili.com/video/*
// @grant        none
// @require      https://cdn.jsdelivr.net/npm/wordcloud2@1.0.0/index.min.js
// @require      https://cdn.jsdelivr.net/npm/victor@1.1.0/index.min.js
// ==/UserScript==

(function() {
    'use strict';
 function geo(){
    console.log("开始")
  //  setInterval(modi,1000);
  initBase();
  init();
  }
//======变量=======
var lastScorllEl;
var diag;
var diagCon;
var canv;
var btnTextE;
var baocun;//保存按钮
var baocun2;//保存按钮
var holder;//包裹词云
var canvP;//词云div
var title;
var hasCi = false;//词云是否显示
let s = []//弹幕
let dmlang = []//所有弹幕
let wds = []//所有
let sai = []//词频
let stageSai = [];
let dmBar;
let pao;
let fail = false;
let walkPao = false;
let tez = [0, 1]//[最大值,最小值,中位数]
let count = 350//最大词数
let reqParm = [0, 1]
let liFac = 0.5;//
let weiFac = 0.5;//字体权重
let dmCount = 0;//总弹幕数量
let colorTable = ['#9794DB', '#8240BF', '#6344C1', '#4840BF', '#444EC1', '#4461C1', '#5E90C9', '#4BABC3', '#66C7CC', '#66CCBD', '#53C69F', '#BDD071', '#C9965E', '#C15444', '#BF4640', '#D13D3D', '#FF533E']
let peiIdx = 0;
let sepei = [//背景色,高频色,低频色,遮罩
  ['#2775b6', [255, 255, 255], [73, 92, 105], '//i0.hdslb.com/bfs/article/874074999995e6981d7602a7d5a770043a10b932.png@256w_256h.webp', '景泰蓝'],
  ['#AC1F18', [28, 13, 26], [54, 41, 47], '//i0.hdslb.com/bfs/article/874074999995e6981d7602a7d5a770043a10b932.png@256w_256h.webp', '对联红'],
  ['#621d34', [226, 225, 228], [97, 113, 114], '//i0.hdslb.com/bfs/article/874074999995e6981d7602a7d5a770043a10b932.png@256w_256h.webp', '鹞冠紫'],
  ['#ed9db2', [51, 20, 30], [181, 152, 162], '//i0.hdslb.com/bfs/article/874074999995e6981d7602a7d5a770043a10b932.png@256w_256h.webp', '豇豆红'],
  ['#1ba784', [173, 213, 162], [65, 174, 60], '//i0.hdslb.com/bfs/article/874074999995e6981d7602a7d5a770043a10b932.png@256w_256h.webp', '竹绿'],
  ['#fed71a', [140, 194, 105], [140, 194, 105], '//i0.hdslb.com/bfs/article/874074999995e6981d7602a7d5a770043a10b932.png@256w_256h.webp', '佛手黄'],
  ['#f26b1f', [249, 233, 205], [240, 156, 90], '//i0.hdslb.com/bfs/article/874074999995e6981d7602a7d5a770043a10b932.png@256w_256h.webp', '金黄'],
  ['#500A16', [226, 225, 228], [97, 113, 114], '//i0.hdslb.com/bfs/article/d2bba9afdcd82302d8d387696e076da26050fb37.jpg@1320w_1760h.webp', '浪'],
]//背景+文字颜色2
let levelColor = [
  ["#7b7b7b", "#b6b6b6"],
  ["#dfd7ba", "#dfd7ba"],
  ["#8eca5e", "#dfd4ae"],
  ["#9c9c9c", "#9bff74"],
  ["#ffffff", "#43eced"],
  ["#ffffff", "#5e0eb4"],
  []
]
let levelStyle = "font-size: 12px;color:c1;background-color:c2;margin: 0 8px;"
let sepeiBtn = [];
let yuTuPic=``
let styleSheet = ` .blura{
animation: 1s animatea 1 linear;
}
.blura:hover{
animation: 2s animateb 1 linear;
}
@keyframes animatea{
0%{ text-shadow: 0 0 0 white; }
50%{
color: rgba(238, 235, 235, 0.8);
text-shadow: 0 0 30px rgb(216, 227, 243);
}
100%{ text-shadow: 0 0 40px white; }
}
@keyframes animateb{
0%{ text-shadow: 0 0 0px rgba(255,255,255,0); }
50%{
  color: rgba(255, 255, 255, 0.925);
  text-shadow: 0 0 10px rgb(184, 245, 242);
}
100%{ text-shadow: 0 0 0 white; }
}
@keyframes ac{
0%{ color: rgba(33, 33, 33, 0.9); }
50%{color: rgba(238, 235, 235, 0.5);}
100%{ color: rgba(238, 235, 235, 1); }
}
@keyframes ad{
0%{ color: rgba(238, 235, 235, 1); }
50%{color: rgba(238, 235, 235, 0.5);}
100%{ color: rgba(33, 33, 33, 0.9); }
}
.btnBg{
position:relative;top:-17px;
/*background: linear-gradient(45deg , #e5c0ff, skyblue);*/
background: linear-gradient(45deg , #df4b4b, #ebda87);
border-radius: 4px;filter: blur(15px);width: 100%;height: 100%;
}
.blr-btn{
color: #fb8561;
user-select:none;overflow:hidden;position:fixed;top:56px;z-index:999;left:10px;width: 54px;height: 26px;border-radius: 3px;font-size: 18px;padding: 5px;cursor: pointer;
width:fit-content;
padding-top: 15px;
width:-webkit-fit-content;
width:-moz-fit-content;
animation: 0.5s ad 1 linear;
transition:.5s;
}
.blr-btn:hover{
animation: 0.5s ac 1 linear;
}
.blr-btn-on{
  border-bottom: 4px solid #07ff7abd;
}
.fEl{
width: 100%;
height: 25px;
padding: 1px 0px;
transition:.5s;
color: cornsilk;
}
.bar-indicator{
height: 100%;
background-color: rgb(76 173 104);
width: 80%;
}
.fEl:hover{
background-color: rgba(96, 160, 243, 0.363);
cursor: pointer;
}
.frequency{
width: 10%;
float: right;
font-size: 14px;
padding: 0px 5px 0 0;
text-align: right;
text-shadow: -2px -1px 8px #bdfa9d;
}
.msgBox{
  width: 550px;
  height: 200px;
  background-color: rgb(249 0 0 / 55%);
  position: fixed;
  /* background: linear-gradient(45deg , #e32e2e99, #ffd60b54); */
  border-radius: 5px;
  z-index: 999999;
  border: 4px solid #ffffffb8;
  backdrop-filter: blur(20px);
  box-shadow: 1px 1px 10px 0px #767676bd;
  display: flex;
  justify-content: center;
}
.msgBox>span{
  font-size: 30px;
  color: #fff6b4;
  line-height: 200px;
  text-align: center;
  font-weight: bolder;
  text-shadow: 0px 0px 7px #ffc800;
}
.danmu-word{
padding: 5px;
font-size: 12px;
line-height: 15px;
position: relative;
top: -22px;
}
.hid{
opacity: 0;
transition: 0.5s;
}
:root{
--rds: 0px;
}
*{
border-radius: var(--rds) !important;
}
*:after{
border-radius: var(--rds) !important;
}
.roll-entry-btn{
    position: absolute;
    right: 5px;
    background-color: rgb(245 250 255);
    top: -5px;
    padding: 0 4px;
    cursor: pointer;
    color: #7c7c7c;
}
.slow-dh{
  transition:1s;
}
.roll-entry-btn:hover{
  background-color: rgb(219 224 255);
}

.mc-duihua-neirong{
  color: #696969;
  padding: 10px 10px 5px 10px;
  margin:0 45px;
  border-radius: 3px;
  box-shadow: 1px 1px 7px 0px #bababac7;
  border: 1px solid #88888852;
  font-size: 14px;
}
.mc-duihua-neirong:hover{
  box-shadow: 1px 1px 7px 0px #ffa40061;
}
.mc-user-face{
  float: left;
  border-radius: 22px;
}
.mc-flow-right{
  float: right;
  clear: both;
}
.mc-comment-info{
  color: #99a2aa;
  line-height: 14px;
  font-size: 12px;
}
.mc-link{
  background-color: #dedede;
  color: #ddd;
  padding: 2px;
  font-size: 14px;
  font-family: fangsong,serif;
  transition: 0.5s;
}
.mc-link:link {
  color: #c9acac;
  text-decoration:none;
}

.mc-link:visited {
  color: #a1b8a1;
  text-decoration:none;
}
.mc-link:hover {
  color: #ffffff;
  text-decoration:none;
}

.mc-link:active {
  color:#FFFFFF;
  text-decoration:none;
}
.mc-duihua-wrap{
  width: 400px;
  margin: 10px 0;
}
.mc-user-info{
  height: 16px;
  font-size: 14px;
  color: #ff4b00;
  margin: 0 45px;
  padding: 5px;
  font-family: monospace;
  font-weight: 900;
}
.mc-dh{
  transition: 0.5s;
}
.mc-divider{
  border-top: 1px solid #d4d4d4;
  width: 100%;
  margin: 5px 0;
}
.mc-red{
  background-color: red;
  cursor: pointer;
}
.mc-red:hover{
  background-color: #fe4d6d;
  color: #d4d4d4;
}
.scrollDiag{
  position: relative;
  transition: 0.2s;
  width:600px;
}
.mc-comment-info>.like i{
  background-position: -153px -25px;
}
.mc-comment-info i{
  display: inline-block;
  width: 14px;
  height: 14px;
  vertical-align: text-top;
  margin-right: 5px;
  background: url(//s1.hdslb.com/bfs/seed/jinkela/commentpc/./img/icons-comment.2f36fc5.png) no-repeat;
}
.hate i{
    background-position: -153px -153px;
}
.mc-comment-info>span{
  cursor: pointer;
  margin-right: 10px;
}
.mc-duihua-neirong img{
  vertical-align: text-bottom;
  padding: 0 1px;
  width: 30px;
  height: 30px;
}
.send-box{
  width:100%;
  height:65px;
  border:1px solid #333;
}
`
//======基础======
var mbox;
function initBase() {
  mbox = document.createElement("div");
  var m = [window.innerHeight / 2 - 100, window.innerWidth / 2 - 275]
  mbox.style = "top:" + m[0] + "px;left:" + m[1] + "px;"
  mbox.classList.add('msgBox','hid')
  mbox.hidden = true;
  document.body.append(mbox)
}
function msg(t) {
  mbox.hidden = false;
  mbox.innerHTML = "";
  let txt = document.createElement('span');
  let image=document.createElement('img')
  image.style='position: absolute;left: -80px;height: 150px;top: -60px;'
  image.setAttribute('src',yuTuPic);
  if (t.length > 23) t = t.substr(0, 23) + "..."
  else if (t.length < 6) txt.style.fontSize = '50px'
  txt.innerText = t;
  mbox.append(txt)
  mbox.append(image)
  mbox.classList.remove('hid')
  var outTime = t.length / 6 * 1000
  setTimeout(() => { mbox.classList.add('hid') }, outTime)
  setTimeout(() => { mbox.hidden = true }, outTime + 500)
}
//======函数======
let linkRegex = /((http[s]?:\/\/)|(ftp)|((?<!\/)www\.)).*?(?=\s)/g
function newEl(tag, parent, classList) {
  let el = document.createElement(tag ? tag : "div");
  if (classList) {
    classList.forEach(x => el.classList.add(x))
  }
  if (parent) parent.append(el)
  return el;
}
//时间戳转换方法    date:时间戳数字
function formatDate(date) {
  let lag = new Date().getTime() - date;
  if (lag < 1000 * 3600) return parseInt(lag / 1000 / 60) + "分钟前"
  if (lag < 1000 * 3600 * 12) return parseInt(lag / 3600 / 1000) + "小时前";
  var date = new Date(date);
  var YY = date.getFullYear() + '-';
  var MM = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '-';
  var DD = (date.getDate() < 10 ? '0' + (date.getDate()) : date.getDate());
  var hh = (date.getHours() < 10 ? '0' + date.getHours() : date.getHours()) + ':';
  var mm = (date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes()) + ':';
  var ss = (date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds());
  return YY + MM + DD + " " + hh + mm + ss;
}
function duiY(data, left) {
  let root = newEl("div");
  root.classList.add("dh", "mc-duihua-wrap");

  let userFace = newEl("div", root, ["mc-user-face"]);
  let userFaceLink = newEl("a", userFace)
  userFaceLink.href = data.link;
  userFaceLink.target = "_blank";
  let userFaceImg = newEl("img", userFaceLink);
  userFaceImg.height = 38; userFaceImg.width = 38;
  userFaceImg.src = data.userFaceImg;

  let userInfo = newEl("div", root, ["mc-user-info"]);
  newEl("span", userInfo).innerText = data.userName;
  let userLevel = newEl("span", userInfo)
  userLevel.style = levelStyle.replace("c1", levelColor[data.lv - 1][0]).replace("c2", levelColor[data.lv - 1][1])
  userLevel.innerText = "lv" + data.lv;

  let content = newEl("div", root, ["mc-duihua-neirong", "mc-dh"]);
  let contentTxt = newEl("div", content);
  let contentTxtDe = data.contentMsg;
  //处理内容链接
  let cap = linkRegex.exec(data.contentMsg);
  while (cap) {
    let link = newEl("a", undefined, ["mc-link"]);
    link.href = cap[0];
    link.target = "_blank";
    link.innerText = "前往链接"
    contentTxtDe = contentTxtDe.replaceAll(cap[0], link.outerHTML);
    cap = linkRegex.exec(data.contentMsg);
  }
  if (data.emote) {
    for (let i in data.emote) {
      let x = data.emote[i];
      let emj = document.createElement("img");
      emj.src = x.url; emj.alt = x.text
      contentTxtDe = contentTxtDe.replaceAll(x.text, emj.outerHTML);
    }
  }
  contentTxt.innerHTML = contentTxtDe;
  newEl("div", content, ["mc-divider"])
  let commentInfo;
  if (!left) {
    root.classList.add("mc-flow-right");
    userFace.classList.add("mc-flow-right");
    userInfo.style.textAlign = "right";
    commentInfo = newEl("div", content, ["mc-comment-info"]);
  } else {
    let comment = newEl("div", content)
    comment.style.height = "14px";
    commentInfo = newEl("div", comment, ["mc-comment-info", "mc-flow-right"])
  }
  newEl("span", commentInfo, ["time"]).innerText = data.time
  let commentLike = newEl("span", commentInfo, ["like"]);
  newEl("i", commentLike)
  let commentLikeNum = newEl("span", commentLike);
  commentLikeNum.innerText = data.likeNum;
  newEl("i", newEl("span", commentInfo, ["hate"]))
  newEl("span", commentInfo, ["reply"]).innerText = "回复"

  return root;
}

//------------------------------------
function drag(obj) {
  obj.onmousedown = function (e) {
    // 鼠标点击物体那一刻相对于物体左侧边框的距离=点击时的位置相对于浏览器
    // 最左边的距离-物体左边框相对于浏览器最左边的距离,纵向同理
    var divX = e.clientX - this.offsetLeft;
    var divY = e.clientY - this.offsetTop;

    document.onmousemove = function (e) {
      var disX = e.clientX - divX;
      var disY = e.clientY - divY;

      // 移动时重新得到物体的距离,解决拖动时出现晃动现象
      obj.style.top = disY + "px";
      obj.style.left = disX + "px";
      document.onmouseup = function () {    // 鼠标抬起时不再移动
        // 预防鼠标弹起来后还会循环(即预防鼠标放上去的时候还会移动)
        document.onmousedown = document.onmousemove = null;
      }
    }
  }
}
var init = () => {
    
  var sty = document.createElement("style");
  sty.innerHTML = styleSheet
  document.head.append(sty)
  //按钮
  let cibtn = newBtn(document.body, ciw, 10, 54, '词云');
  btnTextE = cibtn.tx;
  let saveBtn = newBtn(document.body, () => {
    saveDiv(holder)
  }, 10, 100, '保存')
  let saveBtn2 = newBtn(document.body, () => {
    saveDiv(canvP)
  }, 10, 140, '仅文字保存')

  sepei.forEach((v, i) => {
    let themBtn = newBtn(document.body, () => {
      peiIdx = i; doWordCloud();
    }, 10, 240 + i * 50, v[4])
    // themBtn.bt.style.background='linear-gradient(45deg , #e5c0ff, '+v[0]+')'
    themBtn.bt.style.background = v[0]
    themBtn.bt.style.display = 'none'
    themBtn.tx.style.color = 'rgb(' + v[1][0] + ',' + v[1][1] + ',' + v[1][2] + ')'
    themBtn.bt.style.textAlign = 'center'; themBtn.bt.style.width = '70px'
    sepeiBtn[i] = themBtn.bt;
  })


  let dmBarBtn = newBtn(document.body, () => {
    if (sai.length == 0) msg('请先生成词云(>_<)')
    if (dmBar.hidden) {
      dmBar.hidden = false
      dmBar.style.display = 'block'
      dmBar.children.forEach((e,i) => {
        setTimeout(()=>fadeIn(e),i*10)
      })
    }
    else {
      setTimeout(()=>{
        dmBar.style.display = 'none';
        dmBar.hidden = true;
    },200)
      dmBar.children.forEach((e,i) => {
          setTimeout(()=>fadeOut(e),10)
      })
    }
  }, 60, 54, '列表')

  let paopaoBtn = newBtn(document.body, () => {
    if (!pao.hidden) { pao.hidden = true; return }
    pao.hidden = false
  }, 110, 54, '小球')

  baocun = saveBtn.bt
  baocun.style.display = 'none'
  baocun2 = saveBtn2.bt
  baocun2.style.display = 'none'
  //词云画布
  canv = document.createElement("div");
  canvP = document.createElement("div");//背景
  canvP.append(canv);
  canv.style = "height: 100%;width: 100%;"

  //渐变
  // canvP.style="opacity:0.96;border: 5px solid rgb(237 237 237 / 74%);height: 700px;width: 1200px;position:fixed;top:50px;left:60px;z-index:999999;background:linear-gradient(311deg, rgb(234 229 229), rgb(233 241 227), rgb(218 231 230));";
  //单色background-image: url(https://i0.hdslb.com/bfs/album/d16f34b89e59174bd066a27101bf6b9c92d16615.jpg);
  canvP.style = "background-image: url(//i0.hdslb.com/bfs/article/874074999995e6981d7602a7d5a770043a10b932.png@256w_256h.webp);opacity:0.96;border: 5px solid rgb(237 237 237 / 74%);height: 700px;width: 1200px;background-color: rgb(236, 43, 36);";
  holder = document.createElement('div')
  holder.style = "position:fixed;top:40px;left:115px;z-index:999;"
  holder.setAttribute("hidden", true);
  title = document.createElement("span")
  title.style = "font-size:10px;color:rgb(225,235,215);position:absolute;z-index:10;background-color:#888"
  holder.append(canvP)
  holder.append(title)
  document.body.append(holder)
  drag(holder)

  //弹幕列表
  dmBar = document.createElement('div')
  dmBar.style = 'background-color: rgb(255 255 255 / 96%);position: absolute;z-index: 998;width: 350px;box-shadow: rgba(113, 113, 113, 0.23) 1px 2px 8px 2px;border: 4px solid rgb(225 225 225);top: 120px;right: 30px;display: block;'
  dmBar.style.display = 'none'
  dmBar.hidden = true
  //泡泡图
  pao = document.createElement('div')
  pao.style = 'pointer-events: none;position: fixed;z-index: 999999;width: ' + window.innerWidth + 'px;height:' + window.innerHeight + 'px;top:0px;'
  let qiuCanvas = document.createElement('canvas');
  qiuCanvas.height = window.innerHeight
  qiuCanvas.width = window.innerWidth
  qiuCanvas.setAttribute('id', 'qiuCanvas')
  pao.append(qiuCanvas);
  document.body.append(pao)
  initQiuWorld();
  //对话回放板
  diag = document.createElement("div");
  diag.style.width = '80%'
  diag.style.zIndex = '9999';
  diag.style.position = 'fixed';
  diag.style.backgroundColor = '#fffffff2'
  diag.style.boxShadow = '0px -1px 9px 0px #79787891'
  diag.style.height = '80vh'; diag.style.top = '50px'; diag.style.left = '50px'
  diag.innerHTML =
    ` <div style="width: 100%;height: 22px">
      <div class="mc-dh mc-red" id="closeDiag" style="font-size: 14px;float: right;height:22px;width: 44px;padding: 5px;text-align: center">关闭</div>
    </div>`
  let diagConCov = newEl("div", diag); diagConCov.style.overflow = 'hidden'; diagConCov.style.height = '500px'
  diagCon = newEl("div", diagConCov)
  diagCon.classList.add("scrollDiag")
  document.body.append(diag)
  diag.style.display = 'none';
  document.getElementById("closeDiag").onclick = () => {
    diag.style.display = 'none';
  }
  mcDrag(document.getElementById("closeDiag").parentNode, diag, 1)
  let sendBox = newEl("div", diag, ["send-box"]);
  diag.onmousewheel = (e) => {
    if (diagCon.children.length == 0) return
    let speed = 100
    let t = new Number(diagCon.style.top.replace("px", ""))
    let min = diagCon.parentNode.offsetHeight - (diagCon.lastChild.offsetTop + diagCon.lastChild.clientHeight + 40)
    if (min > 0) return;
    if (e.wheelDelta < 0 && t > min) {
      if (t - speed < min) diagCon.style.top = min + "px";
      else diagCon.style.top = t - speed + "px";
    } else if (e.wheelDelta > 0 && t < 0) {
      if (speed + t > 0) diagCon.style.top = "0px";
      else diagCon.style.top = (t + speed) + "px";
    }
  }
  let today=new Date().getTime();
  if(today<1675612800000){
    let days=16-Math.ceil((1675612800000-today)/3600/24/1000)
    if(days>-1&&days<16){
      let dayCn=['一', '二', '三', '四', '五', '六', '七', '八', '九','十']
      let todayFest='除夕';
      if(days==15){
        todayFest='元宵';
      }else if(days>10){
        todayFest='十'+dayCn[days-11]
      }else if(days>0){
        todayFest='初'+dayCn[days-1]
      }
      msg(todayFest+'玉兔迎春,祝您兔年新春快乐!')
    }
  }
}
function fadeOut(el){
  el.style.displayX=el.style.display
  setTimeout(()=>{
    el.style.opacity=0
  },5)
  setTimeout(()=>{
    el.style.display='none'
  },500)
}
/**
 * 淡入
 */
function fadeIn(el){
  el.style.display='';
  el.style.opacity=0
  el.removeAttribute("hidden")
  setTimeout(()=>{
    el.style.opacity=1
  },5)
}
//产生词云
async function ciw() {
  if (hasCi) {
    holder.setAttribute("hidden", true);
    // $(baocun, baocun2).fadeOut(1000, 'linear', () => {
    // })
    // $(baocun2).fadeOut(1000, 'linear')
    // $(sepeiBtn).fadeOut(1000, 'linear')
    fadeOut(baocun)
    fadeOut(baocun2)
    sepeiBtn.forEach(x=>fadeOut(x))
    btnTextE.innerText = '词云'
    hasCi = false;
    return;
  };
  console.log('生成词云');
  let pid = reqParm[0]
  loadParam();
  if (sai.length == 0 || pid != reqParm[0]) analysi();
  else afterTask.a();
}
let afterTask = {
  a: function () {
    // peiIdx=peiIdx==sepei.length-1?0:peiIdx+1 改为按钮切换
    holder.removeAttribute("hidden");
    setTimeout(() => { btnTextE.innerText = '^_^' }, 100)
    doWordCloud()
    hasCi = true;
    btnTextE.innerText = '关闭'
    // $(baocun).fadeIn(1000, 'linear')
    // $(baocun2).fadeIn(1000, 'linear')
    // $(sepeiBtn).fadeIn(1000, 'linear')
    fadeIn(baocun)
    fadeIn(baocun2)
    sepeiBtn.forEach(x=>fadeIn(x))
    // pao.hidden=true;
  },
  b: function () {
    //实际获取弹幕总数
    dmCount=dmlang.length
    wds.forEach(e => {
      if (e[1] >= 1) {
        sai.push(e)
      }
    })
    wds = []
    let sTime=new Date().getTime();
    sai.sort((a, b) => b[1] - a[1]);//降序
    //取前30个或者取数量大于 总弹幕数的0.02倍的生成球
    console.log("排序耗时:",new Date().getTime()-sTime+"ms")
    setTimeout(() => {
      let unit = 0.2;
      window.clearQiu();
      let qiuCount=sai.length<30?sai.length:30
      let minR=sai[qiuCount-1][1]
      for (let i = 0; i<qiuCount; i++) {
        // if(a[i][1]>=unit*dmCount){
        //   if(qiuses[i]){
        //     //添加Qiu
        //     qiuses[i].r=a[i][1]*20/(unit*dmCount)
        //   }else {
        //     qiuses[i]=window.addQiu(a[i][0],a[i][1]*20/(unit*dmCount))
        //   }
        // }
        //最大直径为窗口1/5+20
        let r=(sai[i][1]-minR)/(sai[0][1]-minR)*(window.innerWidth*.1)
        setTimeout(() => { window.addQiu(sai[i][0],r+20) }, 150*i)
      }
    }, 50)
    //计算weiFac
    if (sai.length > count) sai.splice(count)
    let siz = 0;
    sai.forEach(e => siz += e[0].length * e[1] * e[1])
    let bgSize = canvP.style.height.replace("px", "") * canvP.style.width.replace("px", "")
    weiFac = Math.sqrt(bgSize / siz)

    tez[0] = sai[0][1]
    tez[1] = sai.slice(-1)[0][1]
    tez[2] = sai[parseInt(sai.length / 2)][1]

    console.log(dmlang)
    console.log("大小中", tez)
    console.log("筛选结果:", sai)
    dmLiebiao()//
  }
}
let doWordCloud = () => {
  backgroundImag()
  WordCloud([canv],
    {
      list: sai,
      color: colorw, //'random-light'
      backgroundColor: '',
      gridSize: 18,
      weightFactor: weiFac,//200/tez[0],//被除数为最大字号
      fontFamily: '楷体',
      rotateRatio: 0.5,
      classes: "blura",
      rotationSteps: 2
    });
}
//上色
let colorw = (wd, weight) => {
  //tez[0]红色 #ff0000
  //1=>蓝色 #0000ff
  // console.log(wd,weight,tez[0])
  let i = sai.findIndex(e => e[0] == wd);
  let v = i / sai.length;

  // let v=parseInt(colorTable.length*i/sai.length)
  // return colorTable[v];
  let s = sepei[peiIdx][1]
  let e = sepei[peiIdx][2]
  let colo = 'rgb('
  for (let x in s) {
    colo += (parseInt(s[x] + v * (e[x] - s[x]))) + ','
  }
  return colo.substr(0, colo.lastIndexOf(',')) + ')'
}
//获取弹幕并分析
let analysi = () => {
  //清空
  s = [];
  sai = [];
  reCalcFac()
  console.log("等待弹幕获取完成")
  btnTextE.innerText = '>_<';
  pao.hidden = false
  setTimeout(() => {
   getOneSeg(1)
  }, 20);
}
async function getOneSeg(seg) {
  let regex = /:.(.*?)[�@]/
  await fetch('https://api.bilibili.com/x/v2/dm/web/seg.so?type=1&oid=' + reqParm[0] + '&pid=' + reqParm[1] + '&segment_index=' + seg,{
  "body": null,
  "method": "GET",
  "mode": "cors",
  "credentials": "include"
  }).then(x=>x.text())
  .catch(err=>{
    console.log("失败点:", seg)
    fail = true
    afterTask.b();
    afterTask.a();
    return;
  })
  .then(re=>{
    let ss = re.split('\n');
    ss.forEach(e => {
      let dm = regex.exec(e);
      if (dm && dm[1]) {
        s.push(dm[1]);
        dmlang.push([dm[1], 1])
      }
    })
    console.log(s);
    if(s.length<1){
      console.log("失败点:", seg)
      fail = true
      afterTask.b();
      afterTask.a();
      return;
    }
    //分析进行
    let t1 = new Date().getTime();
    cia()
    //清空s
    s = []
    wds.sort((a, b) => b[1] - a[1]);//降序
    stageSai[stageSai.length] = wds.slice()
    if (wds.length > count) stageSai[stageSai.length - 1].splice(count)
    //如果弹幕总数超过1.2万就停止
    if(dmlang.length>12000){
      console.log("弹幕总数已超过1.2万:",dmlang.length,'停止获取于', seg)
      fail = true
      afterTask.b();
      afterTask.a();
      return;
    }

    let t2 = 500 - (new Date().getTime() - t1)
    if (t2 > 0) sleep(t2)
    getOneSeg(seg + 1)
  })

}
// 弹幕数量过大时,通过promise缓慢执行
function ciaWait(){
  
  console.log('分析弹幕...')
  // let wds=[]
  s.forEach(async e => {
    //去特殊符号
    // e=e.replace(/[\ |\~|\`|\!|\@|\#|\$|\%|\^|\&|\*|\(|\)|\-|\_|\+|\=|\||\\|\[|\]|\{|\}|\;|\:|\"|\'|\,|\<|\.|\>|\/|\?]/g,"");
    // ctin(wds,e)
    
  //异步执行
  let ctinSpare= new Promise((resolve, reject) => {
    setTimeout(() => {
      ctin(wds, e)
      if (1) {
        resolve("ok");
      } else {
        reject(new Error("I am sad"));
      }
    }, 20);
  });
  await ctinSpare
    //展示泡泡
  });
  
}
//分析
function cia() {
 
  console.log('分析弹幕...')
  // let wds=[]
  s.forEach(e => {
    //去特殊符号
    // e=e.replace(/[\ |\~|\`|\!|\@|\#|\$|\%|\^|\&|\*|\(|\)|\-|\_|\+|\=|\||\\|\[|\]|\{|\}|\;|\:|\"|\'|\,|\<|\.|\>|\/|\?]/g,"");
    // ctin(wds,e)
    ctin(wds, e)
    //展示泡泡
  });
}
// function dmFenxi(dm) {
//   let join = true
//   let dmf = [dm, 1]
//   for (let i in wds) {
//     if (wds[i][0] == dm) {
//       join = false;
//       wds[i][1] += 1
//     } else {
//       jiaQuan(wds[i], dmf)
//     }
//   }
//   if (join == true) {
//     wds.push(dmf);
//   }
// }
// function jiaQuan(a, b) {
//   if (a[0].indexOf(b[0]) > -1) {
//     a[1] += b[0].length / a[0].length
//     b[1] += b[0].length / a[0].length
//   } else if (b[0].indexOf(a[0]) > -1) {
//     b[1] += a[0].length / b[0].length
//     a[1] += a[0].length / b[0].length
//   }
// }

function ctin(a, b) {
  var h = true;
  for (let i in a) {
    if (ditIn(a[i], b)) {
      a[i][1] += 1;
      h = false;
      break;
    }
  }
  if (h) {
    a.push([b, 0])
  }
}
let ditIn = (A, b) => {
  if (liFac == 1) {
    if (A[0].indexOf(b) < 0 && b.indexOf(A[0]) < 0) return false;
  } else if (!xiangsi(A[0], b)) return false;
  // if(A[0].length>b.length&&b.length>1) A[0]=b;//选择少的
  if (b.length == 2 || b.length == 4) A[0] = b;//选择2字4字
  return true;
}
//判断 a b是否相似
let xiangsi = (a, b) => {
  if (xiangsi0(a, b) || xiangsi0(b, a)) return true;
  return false;
}
//判断 a b 是否相似
let xiangsi0 = (a, b) => {
  let m = a.split('')
  let c = 0;
  m.forEach(e => {
    if (b.indexOf(e) > -1) c++;
  })
  if (c / m.length >= liFac) return true;
  return false;
}
//找aid和cid
let loadParam = () => {
  reqParm = [window.cid, window.aid]
  if (reqParm[0] == undefined) {
    let x = document.querySelector("#app").__vue__
    if(x.cid==undefined){
      x=window.__INITIAL_STATE__.epInfo
    }
    if(x.cid==undefined){
      x=window.__INITIAL_STATE__
    }
    if(x.cid) reqParm = [x.cid, x.aid]
    else reqParm = [x.cidMap[x.aid].cids[1], x.aid]
  }
  console.log('找到参数:', reqParm)
}
//设置词云宽高和筛选因子
let reCalcFac = () => {
  let m = 0
  
  m=window?.__INITIAL_STATE__?.videoData?.stat?.danmaku
  if(m==undefined)
  try {
    m = parseInt(document.querySelector('.bilibili-player-video-info-danmaku-number').innerText);
  } catch (error) {
    try {
      m = parseInt(document.querySelector('.bpx-player-video-info-dm-number').innerText);
    } catch (error) {
      try {
        m = parseInt(document.querySelector("#viewbox_report > div > span.dm.item").innerText)
      } catch (error) {
        m = parseInt(
          document.querySelector('#bilibili-player > div > div > div.bpx-player-primary-area > div.bpx-player-sending-area > div > div.bpx-player-video-info > div.bpx-player-video-info-dm')
            .innerText.replace('已装填', '').replace('条弹幕', '')
        );
      }
    }
  }
  dmCount = m;
  console.log('弹幕预估总计:',dmCount,'条')
  let titleEl = document.querySelector('#media_module > div > a')
  if (!titleEl) titleEl = document.querySelector('#viewbox_report > h1 > span')
  if (!titleEl) titleEl = document.querySelector('#viewbox_report > h1')
  if (!titleEl) {
    titleEl=document.querySelector('#viewbox_report > div.video-info-title > div > h1')
  }
  title.innerText = "视频标题:" + titleEl.innerText + "   " + new Date()
  if (m < 1000) {
    liFac = 0.5
  } else {
    liFac = 0.5 + (m - 1000) / 10000;//上限10000条
    if (liFac > 1) liFac = 1;
  }
  let w = window.innerWidth - 160;
  let h = window.innerHeight - 70;
  canvP.style.width = w + 'px'
  canvP.style.height = h + 'px'
  pao.style.width = w + 'px'
  pao.style.height = h + 'px'
  holder.style.width = (10 + w) + 'px'
  holder.style.height = (10 + h + 17.6) + 'px'
}
let dmLiebiao = () => {
  dmBar.innerHTML = ''//
  if (null == dmBar.parent) {
    let p = document.querySelector('#app > div.v-wrap > div.r-con');
    if (null == p) p = document.querySelector('#app > div.plp-r');
    if (null == p) p = document.querySelector('#playerAuxiliary > div > div.player-auxiliary-collapse.bui.bui-collapse > div');
    if (null == p) p = document.querySelector('#app > div.video-container-v1');
    p.append(dmBar)
    drag(dmBar)
    // mcDrag(p, dmBar, 1)
  }
  let h = 360 * Math.random();
  let b = 360 - h;
  sai.forEach((e,i) => {
    let fe = document.createElement('div');
    fe.style.display='none'
    fe.className = 'fEl';
    let dw = document.createElement('span');
    dw.className = 'danmu-word';
    dw.innerHTML = e[0]
    if (e[0].length > 21) {
      dw.innerText = e[0].substr(0, 21) + "..."
    }
    let f = document.createElement('div');
    f.className = "frequency";
    f.innerText = parseInt(e[1])
    let bi = document.createElement('div');
    bi.className = 'bar-indicator'
    bi.style = 'width:' + (Math.round(80 * e[1] / tez[0])) + '%'
    bi.style.backgroundColor =  colorTool.hsla(h, 50*e[1] / sai[0][1]+50, 60, 0.75)
    fe.append(f)
    fe.append(bi)
    fe.append(dw)
    dmBar.append(fe)
  })
  dmBar.style.backgroundColor =colorTool.hsla(b, 70, 60, 0.7);
}

let backgroundImag = () => {
  console.log("主题更改:", sepei[peiIdx][4])
  // msg("更改主题:"+sepei[peiIdx][4])
  canvP.style.backgroundImage = 'url("' + sepei[peiIdx][3] + '")'
  canvP.style.backgroundColor = sepei[peiIdx][0]
  // $.ajax({
  //   url:'http://zhongguose.com/img/texture.png',
  //   type:'get',
  //   success:(data)=>{
  //     console.log(daata)
  //     var img=new Blob([data],{type:"png"})
  //     var url=URL.createObjectURL(img);
  //     canvP.style.backgroundImage='url("'+url+'")'
  //   }
  // })
}
//----------------------------------------------------------------
function initQiuWorld() {
  var c = pao.firstElementChild
  // c.width=window.innerWidth;c.height=window.innerHeight;
  let w = c.width, h = c.height;
  var ctx = c.getContext("2d");
  let xFac = 1; //x方向每米多少像素
  let yFac = 1;
  let domain = [];
  let ins = window.ins = [];
  let hand = { x: 0, y: 0, flowIn: false, strength: 20 }
  window.onload = function () {
    let dpi = getDPI();
    xFac = dpi[0] / 0.0254 / 8
    yFac = dpi[1] / 0.0254 / 8
    let windBox = {
      x1: 6 * w / 10, y1: 0, x2: 8 * w / 10, y2: h, eff: function (obj, dt) {
        //简单效果
        if (this.x1 < obj.x && obj.x < this.x2) {
          obj.vY += (2 * obj.y / (h / 9.98) * yFac) * dt
        }
      }, draw: function () {
        let grd = ctx.createLinearGradient(0, 0, 0, h);
        grd.addColorStop(0, "#7e6cff33");
        grd.addColorStop(1, "#7e6cffaa");
        ctx.fillStyle = grd;
        ctx.fillRect(this.x1, this.y1, this.x2 - this.x1, this.y2 - this.y1);
      }
    }
    let windBox2 = {
      x1: 8 * w / 10, y1: 0, x2: 9 * w / 10, y2: h, eff: function (obj, dt) {
        //简单效果 在鼠标吸引时可暂时关闭
        if (hand.flowIn) return
        if (this.x1 < obj.x && obj.x < this.x2) {
          obj.vY -= (2.5 * obj.y / (h / 9.98) * yFac) * dt
        }
      }, draw: function () {
        let grd = ctx.createLinearGradient(0, 0, 0, h);
        grd.addColorStop(0, "#ff2b2b33");
        grd.addColorStop(1, "#f51c1caa");
        ctx.fillStyle = grd;
        ctx.fillRect(this.x1, this.y1, this.x2 - this.x1, this.y2 - this.y1);
      }
      , moveTo: function (x) {
        this.x1 = x - 1 / 20 * w; this.x2 = x + 1 / 20 * w;
      }
    }
    let handEffect = {
      eff: function (obj, dt) {
        //鼠标吸引力
        if (hand.flowIn) {
          let F = new Victor(hand.x - obj.x, hand.y - obj.y).norm().multiply(new Victor(hand.strength, hand.strength))
          let compose = new Victor(obj.vX, obj.vY).add(F);
          obj.vX = compose.x; obj.vY = compose.y
        }
      }, draw: function () {

      }
    }
    domain.push(windBox)
    domain.push(windBox2);
    domain.push(handEffect);
    window.renderQiu = () => {
      ctx.clearRect(0, 0, w, h);
      ins.forEach((x, i) => {
        for (let j = i + 1; j < ins.length; j++) {
          qiuPz(x, ins[j])
        }
        x.positionUpdate()
      })
    }
    window.clearQiu=() => {
      ins=[]
    }
    window.addEventListener('mousemove', (e) => {
      windBox2.moveTo(e.clientX)
    });
    (function run() {
      window.renderQiu()
      // domain.forEach(x=>x.draw())
      requestAnimationFrame(run);
    })()
  }

  function Qiu() {
    this.x = 100;
    this.y = 100;
    this.vX = 1; //一像素
    this.vY = 0;
    this.r = 20;
    this.sT = new Date().getTime();
    this.cT = new Date().getTime();
    this.density = 1;
    this.text = '春风';
    this.textColor = ["magenta", "blue", "red"];
    this.rv = 0.1;
    this.rs = [10, 20];
  }
  Qiu.prototype.born = function () {
    this.x = w-this.r;
    this.y = h;
    this.vX = -2 * xFac;
    this.vY = - 3*xFac;
    this.draw();
  }
  Qiu.prototype.draw = function () {
    var radial = ctx.createRadialGradient(this.x, this.y-this.r*.2, 0.75 * this.r, this.x, this.y, this.r);
    radial.addColorStop(.2, '#ffffff00');
    radial.addColorStop(.9, this.textColor[1]);
    radial.addColorStop(1, this.textColor[2].replace(/%,\.\d{1,2}\)/, "%,.1)"));
    ctx.fillStyle = radial;
    ctx.beginPath();
    ctx.arc(this.x, this.y, this.r, 0, Math.PI * 2);
    ctx.fill();
    ctx.closePath();

    ctx.font = this.r * 2 / 3 + "px Verdana";
    // Create gradient
    var gradient = ctx.createLinearGradient(this.x - this.r, this.y, this.x + this.r, this.y);
    gradient.addColorStop("0", this.textColor[0]);
    gradient.addColorStop("0.5", this.textColor[1]);
    gradient.addColorStop("1.0", this.textColor[2]);
    // Fill with gradient
    ctx.fillStyle = gradient;
    ctx.textAlign = 'center';
    ctx.fillText(this.text, this.x,this.y );
    //绘制连线
    if (hand.flowIn) {
      ctx.strokeStyle = this.textColor[1];
      ctx.lineWidth = .5; ctx.beginPath(); ctx.moveTo(this.x, this.y);
      ctx.lineTo(hand.x, hand.y); ctx.stroke(); ctx.closePath();
    }
  }
  Qiu.prototype.erase = function () {
    // ctx.clearRect(this.x-this.r-2,this.y-this.r-2,this.x+this.r+2,this.y+this.y+2);
    ctx.clearRect(0, 0, w, h);
  }
  Qiu.prototype.speedUpdate = function (dt) {//dt 毫秒
    dt = dt / 1000
    if ((this.y >= h - this.r && this.vY > 0) || (this.y <= 0 + this.r && this.vY < 0)) this.vY = -this.vY
    if ((this.x >= w - this.r && this.vX > 0) || (this.x <= 0 + this.r && this.vX < 0)) this.vX = -this.vX
    speedFun1(this, dt)
  }
  Qiu.prototype.positionUpdate = function () {
    let dT = new Date().getTime() - this.cT;
    this.x += this.vX * dT / 1000;
    this.y += this.vY * dT / 1000;
    if (this.y > h - this.r) this.y = h - this.r
    this.draw();
    this.speedUpdate(dT);
    if (this.r <= this.rs[1]) this.r += this.rv;
    this.cT += dT;
  }

  function speedFun1(obj, dt) {
    // if(obj.y+(obj.vY*dt)<h-obj.r){
    //     obj.vY+=dt*(9.98*yFac)
    // }
    domain.forEach(x => {
      x.eff(obj, dt)
    })
    if (obj.vY != 0) {
      let dy = Math.abs(obj.vY) * 0.98;
      if (dy < 1) dy = 0
      obj.vY = Math.sign(obj.vY) * dy;
    }
    if (obj.vX != 0) {
      let dx = Math.abs(obj.vX) * 0.99;
      if (dx < 1) dx = 0;
      obj.vX = Math.sign(obj.vX) * dx;
    }
  }
  function qiuPz(q1, q2) {
    let dis = Math.sqrt(Math.pow(q1.x - q2.x, 2) + Math.pow(q1.y - q2.y, 2))
    if (dis < q1.r + q2.r) {
      let s = new Victor(q1.x - q2.x, q1.y - q2.y).normalize();
      let v1 = new Victor(q1.vX, q1.vY)
      let v2 = new Victor(q2.vX, q2.vY)
      if (v1.clone().subtract(v2).dot(s) < 0) {
        collide(q1, q2)
      }
    }
  }
  function willCollide(q1, q2, dt) {
    let a = q1.x + dt * q1.vX - q2.x
    let b = q1.y + q1.vY * dt - q2.y
    let dis = Math.sqrt(Math.pow(a, 2) + Math.pow(b, 2))
    if (dis < q1.r + q2.r) {
      return true;
    }
  }
  function collide(q1, q2) {
    let m1 = q1.density; let m2 = q2.density;
    let s = new Victor(q1.x - q2.x, q1.y - q2.y).normalize();
    let v1 = new Victor(q1.vX, q1.vY)
    let v2 = new Victor(q2.vX, q2.vY)
    let v1s = v1.dot(s.clone().invert());
    let v2s = v2.dot(s);
    let v1sc = (v1s * (m1 - m2) + 2 * m2 * v2s) / (m1 + m2);
    let v2sc = (v2s * (m2 - m1) + 2 * m1 * v1s) / (m1 + m2);
    let v1n = v1.dot(s.clone().invert().rotate(Math.PI / 2))
    let v2n = v2.dot(s.clone().rotate(Math.PI / 2))
    let vv1 = s.clone().multiply(new Victor(v1sc, v1sc)).add(s.clone().rotate(-Math.PI / 2).multiply(new Victor(v1n, v1n)))
    let vv2 = s.clone().invert().multiply(new Victor(v2sc, v2sc)).add(s.clone().rotate(-Math.PI / 2).multiply(new Victor(v2n, v2n)))
    q1.vX = vv1.x
    q1.vY = vv1.y
    q2.vX = vv2.x
    q2.vY = vv2.y
  }

  function colorWalk2() {
    let hue = Math.random() * 360;
    return ['hsla(' + (hue - 45) + ',90%,70%,.8)', 'hsla(' + (hue) + ',90%,90%,.9)', 'hsla(' + (hue + 30) + ',90%,70%,.8)']
  }
  function getDPI() {
    var arrDPI = new Array();
    if (window.screen.deviceXDPI != undefined) {
      arrDPI[0] = window.screen.deviceXDPI;
      arrDPI[1] = window.screen.deviceYDPI;
    }
    else {
      var tmpNode = document.createElement("DIV");
      tmpNode.style.cssText = "width:1in;height:1in;position:absolute;left:0px;top:0px;z-index:99;visibility:hidden";
      document.body.appendChild(tmpNode);
      arrDPI[0] = parseInt(tmpNode.offsetWidth);
      arrDPI[1] = parseInt(tmpNode.offsetHeight);
      tmpNode.parentNode.removeChild(tmpNode);
    }
    return arrDPI;
  }
  window.addQiu = (text, r) => {
    let q1 = new Qiu()
    q1.born();
    q1.textColor = colorWalk2();
    q1.text = text
    q1.r = r
    ins.push(q1);
    return q1;
  }
  window.addEventListener('mousemove', (e) => {
    hand.x = e.clientX; hand.y = e.clientY;
  });
  window.addEventListener('mousedown', (e) => {
    hand.flowIn = true;
  });
  window.addEventListener('mouseup', (e) => {
    hand.flowIn = false;
  });
  //----------------------------------------------------------------
  // window.onclick = function(){
  //     let q1=new Qiu()
  //     q1.born();
  //     q1.textColor=colorWalk2();
  //     ins.push(q1);
  // }
}
//----------------------------------------------------------------

//保存div内容为png
function saveDiv(div) {
  //1.将div转成svg
  var divContent = div.innerHTML;
  let w = div.offsetWidth;
  let h = div.offsetHeight
  if (w == 0 || h == 0) {
    w = div.firstElementChild.offsetWidth
    h = div.firstElementChild.offsetHeight
  }
  var data = "data:image/svg+xml," +
    "<svg xmlns='http://www.w3.org/2000/svg' width='" + w + "' height='" + h + "'>" +
    "<foreignObject width='100%' height='100%'>" +
    "<div xmlns='http://www.w3.org/1999/xhtml' style='font-size:16px;font-family:Helvetica'>" +
    divContent +
    "</div>" +
    "</foreignObject>" +
    "</svg>";
  var img = new Image();
  //2.svg转成canvas
  var canvas = document.createElement('canvas');  //准备空画布
  document.body.appendChild(img);
  img.onload = () => {
    var dpr = window.devicePixelRatio;
    canvas.width = img.width;
    canvas.height = img.height;
    canvas.style.width = dpr * w + "px"
    canvas.style.height = dpr * h + "px"
    var context = canvas.getContext('2d');  //取得画布的2d绘图上下文
    context.drawImage(img, 0, 0);
    var a = document.createElement('a');
    let url = canvas.toDataURL('image/png');
    window.open(url, '_blank');
    console.log(url)

    a.href = url;  //将画布内的信息导出为png图片数据
    let titleEl = title
    a.download = titleEl.innerText + (new Date()).getTime() + ".png";  //设定下载名称
    a.click()
    document.body.removeChild(img)
  }
  img.src = data;



}
let colorTool = {
  hsla: function (h, s, l, a) {
    return "hsla(" + h + "," + s + "%," + l + "%," + a + ")";
  }
}
//生产按钮
function newBtn(p, f, left, top, word) {
  var cibtn = document.createElement("div");
  var cibtnBg = document.createElement("div");
  cibtnBg.className = 'btnBg'
  let TextE = document.createElement('span')
  TextE.innerText = word
  cibtn.append(TextE)
  cibtn.className = 'blr-btn'
  cibtn.append(cibtnBg);
  cibtn.style.left = left + 'px';
  cibtn.style.top = top + 'px';
  
  cibtn.onclick = f;
  p.append(cibtn)
  return { bt: cibtn, bg: cibtnBg, tx: TextE }
}
function sleep(numberMillis) {
  var now = new Date();
  var exitTime = now.getTime() + numberMillis;
  while (true) {
    now = new Date();
    if (now.getTime() > exitTime)
      return;
  }
}
//----------------------------------------------------------------
//----------------------------------------------------------------


var ban,unattach = !0;function mcDrag(b,c,k){b.onmousedown=function(m){if(!k||m.target==b){var e=c.style.transition;c.style.transition="unset";var d=m.clientX-c.offsetLeft,a=m.clientY-c.offsetTop;document.onmousemove=function(f){var n=f.clientX-d;c.style.top=f.clientY-a+"px";c.style.left=n+"px";document.onmouseup=function(){document.onmousedown=document.onmousemove=null;c.style.transition=e}}}}}
function tuoyi(b,c,k,m,e,d){var a=(new Date).getTime();b.onmousedown=function(f){var n=f.clientX,q=f.clientY;a=(new Date).getTime();var r=m();e&&e();document.onmousemove=function(h){var p=h.clientX-n,t=h.clientY-q;200<(new Date).getTime()-a&&c(p,t,r);document.onmouseup=function(){document.onmousemove=null;200>(new Date).getTime()-a&&k(h);d&&d()}}}}function g(b){return document.createElement(b)}
function bujie(b){b.classList.add("mc-bujie");setTimeout(function(){b.classList.remove("mc-bujie")},1E3)}function shantishi(b,c,k){b.classList.add(c);setTimeout(function(){b.classList.remove(c)},k)}var LX={wuxian:1,prop:2,bl:3,wb:4};
function MiCan(b,c,k,m){unattach && attachStyle();ban=document.createElement("div");ban.classList.add("mc-b");ban.style.top="200px";ban.style.left="200px";document.body.append(ban);var e=g("div"),d=g("div");d.style.width="100%";ban.append(e);ban.append(d);ban.ti=d;e.classList.add("mc-tou");e.innerText=m;b.forEach(function(a){a[2]==LX.prop?sx(a[0],a[1],k,c,a[3],a[4],a[5]):a[2]==LX.wuxian?wxsx(a[0],a[1],k,c,a[3],a[4]):a[2]==LX.wb?wz(a[0],a[1],k,c):a[2]==LX.bl&&sf(a[0],a[1],k,c)});mcDrag(e,ban,1);return ban}
function sx(b,c,k,m,e,d,a){var f=g("div");f.classList.add("mc-sx");ban.ti.append(f);var n=g("div");n.classList.add("mc-title","mc-dh");n.innerText=b;f.append(n);b=g("div");b.style="float: left;width: 170px;height: 30px;";f.append(b);var q=g("div");q.classList.add("mc-sx-op");b.append(q);var r=g("div");r.classList.add("mc-sx-bar");q.append(r);var h=g("input");h.classList.add("mc-sx-input","mc-input","mc-dh");h.value=k(c);b.append(h);var p=g("div");p.classList.add("mc-slider","mc-dh");b.append(p);var t=
function(){var l=h.value;l>d?(l=d,bujie(n)):l<e&&(l=e,bujie(n));a&&(l=parseInt(l));h.value=l;r.style.width=q.clientWidth*(l-e)/(d-e)+"px";m(c,l)};tuoyi(p,function(l,v,u){h.value=e+(u+l)/q.clientWidth*(d-e);t()},function(){p.style.display="none";setTimeout(function(){h.focus()},1)},function(){return r.clientWidth},function(){p.classList.add("mc-faguang")},function(){p.classList.remove("mc-faguang")});t();h.onblur=function(){p.style.display="block";t()};return f}
function wxsx(b,c,k,m,e,d){function a(l){d&&(l=l.parseInt);h.value=l;m(c,l)}var f=g("div");f.classList.add("mc-sx");ban.ti.append(f);var n=g("div");n.classList.add("mc-title","mc-dh");n.innerText=b;f.append(n);b=g("div");b.style="float: left;width: 170px;height: 30px;";f.append(b);var q=g("div");q.classList.add("mc-sx-op");b.append(q);var r=g("div");r.classList.add("mc-jiantou","mc-z","mc-dh");r.innerText="<";q.append(r);var h=g("input");h.classList.add("mc-sx-input","mc-input","mc-dh");h.style.width=
"100px";h.style.top="0px";h.value=k(c);q.append(h);var p=g("div");p.classList.add("mc-jiantou","mc-y","mc-dh");p.innerText=">";q.append(p);var t=g("div");t.classList.add("mc-huakuai-zj","mc-dh");b.append(t);h.onblur=function(){t.style.display="block";a(h.value)};r.onclick=function(){a(h.value-e);shantishi(this,"mc-huodong",500)};p.onclick=function(){a(new Number(h.value)+e);shantishi(this,"mc-huodong",500)};tuoyi(t,function(l,v,u){a(u- -l*e);0>l?(r.classList.add("mc-huodong"),p.classList.remove("mc-huodong")):
(p.classList.add("mc-huodong"),r.classList.remove("mc-huodong"))},function(){t.style.display="none";setTimeout(function(){h.focus()},1)},function(){return h.value},function(){q.classList.add("mc-faguang")},function(){q.classList.remove("mc-faguang");r.classList.remove("mc-huodong");p.classList.remove("mc-huodong")})}
function wz(b,c,k,m){function e(n){m(c,n);f.value=n}var d=g("div");ban.ti.append(d);d.classList.add("mc-sx");var a=g("div");a.classList.add("mc-title","mc-dh");a.innerText=b;d.append(a);b=g("div");b.style.float="left";b.style.height="100%";d.append(b);d=g("div");d.innerText="\ud83d\udd8a";d.classList.add("mc-tubiao","mc-dh");b.append(d);var f=g("input");f.classList.add("mc-input","mc-dh","mc-bj-danhuang");f.style.width="260px";f.style.textAlign="left";f.value=k(c);b.append(f);f.onblur=function(){m(c,
f.value)};d.onclick=function(n){wbsr.hd=e;wbsr.main||initWbsr();xianshi(wbsr.main);wbsr.in.value=f.value}}
function sf(b,c,k,m){var e=g("div");e.classList.add("mc-sx");ban.ti.append(e);var d=g("div");d.classList.add("mc-title","mc-dh");d.innerText=b;e.append(d);var a=g("div");a.style="float: left";a.classList.add("mc-title","mc-dh","mc-blue");a.innerText="\u662f";k(c)||(a.innerText="\u5426",a.classList.add("mc-red"),a.classList.remove("mc-blue"));e.append(a);a.onclick=function(){k(c)?(a.classList.add("mc-red"),a.classList.remove("mc-blue"),a.innerText="\u5426",m(c,!1)):(a.classList.remove("mc-red"),a.classList.add("mc-blue"),
a.innerText="\u662f",m(c,!0))}}var wbsr={};function xiaoshi(b){b.classList.add("mc-touming");setTimeout(function(){b.classList.add("mc-yincang")},500)}function xianshi(b){b.classList.remove("mc-yincang");b.classList.remove("mc-touming")}
function initWbsr(){wbsr.main=g("div");wbsr.main.classList.add("mc-tanchu","mc-dh","mc-yincang","mc-touming");document.body.append(wbsr.main);wbsr.in=g("textarea");wbsr.in.classList.add("mc-wenben");wbsr.main.append(wbsr.in);wbsr.btp=g("div");wbsr.main.append(wbsr.btp);wbsr.quxiao=g("div");wbsr.quxiao.innerText="\u53d6\u6d88";wbsr.quxiao.classList.add("mc-aniu","mc-red");wbsr.quxiao.style.float="left";wbsr.btp.append(wbsr.quxiao);wbsr.queren=g("div");wbsr.queren.innerText="\u786e\u8ba4";wbsr.queren.classList.add("mc-aniu",
"mc-blue");wbsr.queren.style.float="right";wbsr.btp.append(wbsr.queren);wbsr.quxiao.onclick=function(){xiaoshi(wbsr.main)};wbsr.queren.onclick=function(){wbsr.hd(wbsr.in.value);xiaoshi(wbsr.main)};mcDrag(wbsr.main,wbsr.main,1)};
function attachStyle(){var a=g("style");document.head.append(a);a.innerText="\n    .mc-sx{margin:5px;height:30px;float:left}.mc-tou{width:100%;background-color:rgb(4 4 45);height:25px;text-align:center;line-height:25px;color:cornsilk;font-size:15px}.mc-input{height:24px;color:cornsilk;background-color:inherit;display:block;background:transparent;border:none;padding:3px 10px;text-align:center;font-size:16px}.mc-bj-danhuang{background-color:rgb(68 56 115)}.mc-sx-input{width:150px;float:left;position:relative;top:-30px}.mc-input:focus{border:0px;outline:none;background:rgba(42,165,104,0.425)}.mc-sx-bar{margin: unset;background-color:rgb(163,85,241);width:30px;height:100%}.mc-b{position:fixed;width:800px;background-color:#0a043adb;margin:0;box-shadow:0px 0px 9px 2px#3c35357a;transition:0.5s}.mc-title{background-color:rgb(58 55 110);float:left;line-height:30px;font-size:18px;padding:0px 10px;color:#857cc2}.mc-sx-op{background-color:rgb(86 71 146);height:30px;width:170px}.mc-slider{position:relative;top:-30px;width:170px;height:30px;user-select:none}.mc-huakuai-zj{position:relative;top:-30px;left:25px;width:120px;height:30px;user-select:none}.mc-huakuai-zj:hover{cursor:e-resize}.mc-dh{transition:0.5s linear}.mc-slider:hover{cursor:e-resize}.mc-faguang{box-shadow:0px 0px 8px 3px#ffffffd6}.mc-bujie{background-color:red}.mc-jiantou{background-color:rgb(128,83,173);width:25px;height:100%;font-size:30px;color:#d1c1e0;line-height:26px;cursor:pointer;user-select:none}.mc-z{float:left}.mc-y{float:right}.mc-huodong{background-color:rgb(219,165,245);color:cornsilk}.mc-wenben{border:0;background-color:rgba(233,233,233,0.98);width:355px;height:100px;padding:10px;resize:both;font-size:15px;color:rgb(66,66,64)}.mc-wenben:focus{border:none;outline:none}.mc-tubiao{float:left;height:100%;width:30px;background-color:rgb(89,82,147);color:cornsilk;font-size:18px;line-height:30px;text-align:center;transition:0.5s}.mc-tubiao:hover{cursor:pointer;background-color:rgb(156,127,238)}.mc-aniu{height:30px;line-height:30px;font-size:16px;transition:.4s linear;cursor:pointer;padding:3px 10px;margin:5px;color:cornsilk;user-select:none}.mc-red{cursor:pointer;background-color:rgb(224,68,128)}.mc-blue{cursor:pointer;background-color:rgb(35,245,193)}.mc-red:hover{background-color:rgb(255,0,98)}.mc-blue:hover{background-color:rgb(0,102,255)}.mc-tanchu{position:fixed;background-color:rgba(233,230,218,0.801);top:100px;left:200px;z-index:99}.mc-yincang{display:none}.mc-touming{opacity:0}\n    "};


geo();
})();