NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name 气象数据填写 // @description 仅支持私人内网网站使用! // @version 0.0.1 // @author FanZhenHua // @match *://www.jyshare.com/front-end/5575* // @match *://10.1.65.226/index.html* // @connect */radarParam/selectRadarParams/* // 匹配Api接口链接,禁止跨域弹窗 // @grant GM_xmlhttpRequest // @require https://unpkg.com/mammoth/mammoth.browser.min.js // @license MIT // @icon  // ==/UserScript== /* 创建一个按钮组元素 */ function buttonBoxGroup() { const buttonGroup = document.createElement("div"); // 设置按钮为悬浮固定定位,使其在页面滚动时位置不变 buttonGroup.style.position = "fixed"; buttonGroup.style.left = "35px"; buttonGroup.style.top = "520px"; buttonGroup.style.zIndex = "9999"; // buttonGroup.style.backgroundColor = "#F5F5FB"; // 背景颜色 buttonGroup.style.border = "none"; // 去除边框 buttonGroup.style.borderRadius = "5px"; // 添加圆角 buttonGroup.style.padding = "10px"; // 添加内边距 buttonGroup.style.gap = "5px"; // 子元素间间距 buttonGroup.style.cursor = "move"; // 鼠标指针 buttonGroup.style.display = "flex"; //弹性布局 buttonGroup.style.flexDirection = "column"; // 垂直排列 buttonGroup.style.boxShadow = "0 4px 6px rgba(0, 0, 0, 0.1)"; // 添加阴影 document.body.appendChild(buttonGroup); return buttonGroup; } const buttonGroup = buttonBoxGroup(); // 创建按钮组元素 /* 创建一个按钮元素 */ function buttonBox(textContent) { const button = document.createElement("button"); button.textContent = textContent; button.style.color = "white"; // 字体颜色 button.style.fontSize = "20px"; // 字体大小 button.style.backgroundColor = "#325D88"; // 背景颜色 button.style.border = "none"; // 去除边框 button.style.borderRadius = "5px"; // 添加圆角 button.style.padding = "8px"; // 添加内边距 buttonGroup.appendChild(button); return button; } /* 启用-禁用 按钮 */ function disabledButtonGroup(state, button) { if (state) { // 计算按钮偏移量 const dx = Math.abs(parseInt(buttonGroup.style.left) - parseInt(startX)); const dy = Math.abs(parseInt(buttonGroup.style.top) - parseInt(startY)); // 移动量均小于3 if (dx < 3 && dy < 3) { button.disabled = true; // 禁用按钮 button.style.backgroundColor = "#CDCDCD"; button.style.cursor = "not-allowed"; return true; } return false; } else { // 取消禁用 button.disabled = false; button.style.backgroundColor = "#325D88"; button.style.cursor = "pointer"; return false; } } const tipBoxes = []; // 记录所有提示框元素的数组 /* 计算并设置所有提示框的位置 */ function setTipBoxesPosition() { const totalHeight = tipBoxes.reduce((sum, box) => sum + box.offsetHeight, 0); const gap = 5; const totalGap = (tipBoxes.length - 1) * gap; const startTop = (window.innerHeight - totalHeight - totalGap) / 2; let currentTop = startTop; tipBoxes.forEach((box) => { box.style.top = `${currentTop}px`; currentTop += box.offsetHeight + gap; }); } /* 创建并显示悬浮提示框 */ function showTipsBox(text, color = "black") { const popup = document.createElement("div"); // popup.textContent = text; // 将字符串中的 \n 替换为 <br> const textWithBreaks = text.replace(/\n/g, "<br>"); popup.innerHTML = textWithBreaks; // 设置基本样式 popup.style.position = "fixed"; popup.style.left = "50%"; popup.style.transform = "translateX(-50%)"; popup.style.color = color; // 字体颜色 popup.style.fontSize = "22px"; // 字体大小 popup.style.backgroundColor = "lightblue"; // 背景色 popup.style.opacity = "0.6"; // 透明度 popup.style.padding = "15px"; popup.style.zIndex = "10000"; // 前置等级 popup.style.textAlign = "center"; // 设置文本水平居中 popup.style.border = "none"; // 去除边框 popup.style.borderRadius = "10px"; // 添加圆角 document.body.appendChild(popup); tipBoxes.push(popup); setTipBoxesPosition(); // 计算并设置所有提示框的位置 // 定时移除提示框 setTimeout(() => { document.body.removeChild(popup); const index = tipBoxes.indexOf(popup); if (index > -1) { tipBoxes.splice(index, 1); setTipBoxesPosition(); // 计算并设置所有提示框的位置 } }, 8000); } /* 添加事件侦听器 */ function addMyEventListener() { let isDragging = false; let initialX, initialY, currentX, currentY; (startX = 0), (startY = 0); // 全局变量 // 鼠标按下事件处理函数 const handleMouseDown = (e) => { isDragging = true; initialX = e.clientX; initialY = e.clientY; startX = buttonGroup.style.left; startY = buttonGroup.style.top; }; // 鼠标抬起事件处理函数 const handleMouseUp = () => { isDragging = false; }; // 鼠标移动事件处理函数 const handleMouseMove = (e) => { if (isDragging) { currentX = e.clientX; currentY = e.clientY; const diffX = currentX - initialX; const diffY = currentY - initialY; const left = parseInt(buttonGroup.style.left) + diffX; const top = parseInt(buttonGroup.style.top) + diffY; buttonGroup.style.left = left + "px"; buttonGroup.style.top = top + "px"; initialX = currentX; initialY = currentY; } }; // 绑定事件 buttonGroup.addEventListener("mousedown", handleMouseDown); document.addEventListener("mouseup", handleMouseUp); document.addEventListener("mousemove", handleMouseMove); } function main() { addMyEventListener(); // 添加事件侦听器 var button = buttonBox("填写数据"); // 按钮点击事件处理函数 button.addEventListener("click", async function () { const result = disabledButtonGroup(true, this); // 禁用按钮 if (result) { showTipsBox(`请联系作者!`, "red"); } disabledButtonGroup(false, this); // 启用按钮 }); } main();