一个阅读APP网页端自动滚动功能
// ==UserScript==
// @name 自动滚动配置
// @description 一个阅读APP网页端自动滚动功能
// @namespace http://tampermonkey.net/
// @version 0.1
// @author You
// @match *
// @icon 
// @grant none
// @license MIT
// @resource css https://cdnjs.cloudflare.com/ajax/libs/antd/4.17.0/antd.min.css
// ==/UserScript==
(function() {
'use strict';
var isScrolling = false;
var intervalId;
var scrollSpeed = 25; // 默认的每次滚动间隔
var scrollPixels = 1; // 默认的每次滚动像素
var isConfigPanelOpen = false;
function startScrolling() {
if (!isScrolling) {
isScrolling = true;
intervalId = setInterval(function() {
window.scrollBy(0, scrollPixels);
if (isAtBottom()) {
window.scrollBy(0, 1); // Scroll one more pixel to prevent getting stuck at the bottom
}
}, scrollSpeed);
}
}
function stopScrolling() {
if (isScrolling) {
isScrolling = false;
clearInterval(intervalId);
}
}
function toggleScrolling() {
if (isScrolling) {
stopScrolling();
} else {
startScrolling();
}
updateButtonState();
}
function updateButtonState() {
var scrollButton = document.getElementById('scrollButton');
if (isScrolling) {
scrollButton.innerText = '停止滚动';
scrollButton.style.backgroundColor = '#FF0000';
} else {
scrollButton.innerText = '开始滚动';
scrollButton.style.backgroundColor = '#007BFF';
}
document.getElementById('scrollStatus').innerText = isScrolling ? '当前状态:滚动' : '当前状态:停止';
}
function updateScrollConfig() {
var speedInput = document.getElementById('scrollSpeedInput');
var pixelsInput = document.getElementById('scrollPixelsInput');
scrollSpeed = parseInt(speedInput.value) || scrollSpeed;
scrollPixels = parseInt(pixelsInput.value) || scrollPixels;
}
function isAtBottom() {
// Check if we are at the bottom of the page
return window.innerHeight + window.scrollY >= document.body.scrollHeight;
}
function toggleConfigPanel() {
var configPanel = document.getElementById('configPanel');
var configButton = document.getElementById('configButton');
isConfigPanelOpen = !isConfigPanelOpen;
configPanel.style.display = isConfigPanelOpen ? 'block' : 'none';
configButton.innerText = isConfigPanelOpen ? '收起' : '配置';
// Adjust the position of the buttons based on the config panel state
var scrollButton = document.getElementById('scrollButton');
scrollButton.style.right = isConfigPanelOpen ? '290px' : '10px';
var statusDiv = document.getElementById('statusDiv');
statusDiv.style.right = isConfigPanelOpen ? '310px' : '10px';
}
function addButton() {
var configDiv = document.createElement('div');
configDiv.style.position = 'fixed';
configDiv.style.bottom = '50%';
configDiv.style.right = isConfigPanelOpen ? '100px' : '0';
configDiv.style.transform = 'translateY(50%)';
configDiv.style.zIndex = '9999';
configDiv.style.padding = '20px';
configDiv.style.background = '#fff';
configDiv.style.boxShadow = '0 2px 5px rgba(0, 0, 0, 0.2)';
configDiv.style.width = '150px';
configDiv.style.borderRadius = isConfigPanelOpen ? '5px 0 0 5px' : '5px';
configDiv.className = 'ant-card';
configDiv.id = 'configPanel';
configDiv.style.display = 'none';
var configButton = document.createElement('button');
configButton.textContent = '收起';
configButton.style.position = 'absolute';
configButton.style.padding = '2px 5px';
configButton.style.fontSize = '12px';
configButton.style.top = '10px';
configButton.style.right = '10px';
configButton.style.backgroundColor = '#007BFF';
configButton.style.color = '#fff';
configButton.style.border = 'none';
configButton.style.borderRadius = '5px';
configButton.style.boxShadow = '0 2px 5px rgba(0, 0, 0, 0.2)';
configButton.addEventListener('click', toggleConfigPanel);
configDiv.appendChild(configButton);
var scrollButton = document.createElement('button');
scrollButton.textContent = '开始滚动';
scrollButton.style.margin = '30px auto 0';
scrollButton.style.padding = '10px 20px';
scrollButton.style.display = 'block';
scrollButton.style.backgroundColor = '#007BFF';
scrollButton.style.fontSize = '14px';
scrollButton.style.color = '#fff';
scrollButton.style.border = 'none';
scrollButton.style.borderRadius = '5px';
scrollButton.style.boxShadow = '0 2px 5px rgba(0, 0, 0, 0.2)';
scrollButton.id = 'scrollButton';
scrollButton.addEventListener('click', toggleScrolling);
configDiv.appendChild(scrollButton);
var scrollStatus = document.createElement('div');
scrollStatus.textContent = '当前状态:停止';
scrollStatus.id = 'scrollStatus';
scrollStatus.style.margin = '0 auto';
scrollStatus.style.textAlign = 'center';
scrollStatus.style.color = '#000';
scrollStatus.style.fontSize = '12px';
configDiv.appendChild(scrollStatus);
var speedLabel = document.createElement('label');
speedLabel.textContent = '每次滚动间隔(ms):';
speedLabel.style.float='left';
speedLabel.style.margin='6px 0 2px';
speedLabel.style.padding='0px';
speedLabel.style.fontSize = '14px';
speedLabel.style.color = '#000';
var speedInput = document.createElement('input');
speedInput.type = 'number';
speedInput.min = '1';
speedInput.value = scrollSpeed.toString();
speedInput.id = 'scrollSpeedInput';
speedInput.style.backgroundColor = 'rgba(202,203,204,.3)';
speedInput.style.border='0px';
speedInput.style.outline='0px';
speedInput.style.padding='5px 0 5px 8px';
speedLabel.style.margin='0px';
speedInput.style.borderRadius='5px';
speedInput.style.color='#000';
speedInput.className = 'ant-input';
speedInput.addEventListener('change', updateScrollConfig);
var pixelsLabel = document.createElement('label');
pixelsLabel.textContent = '每次滚动像素(px):';
pixelsLabel.style.float='left';
pixelsLabel.style.margin='6px 0 2px';
pixelsLabel.style.padding='0px';
pixelsLabel.style.fontSize = '14px';
pixelsLabel.style.color = '#000';
var pixelsInput = document.createElement('input');
pixelsInput.type = 'number';
pixelsInput.min = '1';
pixelsInput.value = scrollPixels.toString();
pixelsInput.id = 'scrollPixelsInput';
pixelsInput.style.backgroundColor = 'rgba(202,203,204,.3)';
pixelsInput.style.border='0px';
pixelsInput.style.outline='0px';
pixelsInput.style.padding='5px 0 5px 8px';
pixelsInput.style.margin='0px';
pixelsInput.style.borderRadius='5px';
pixelsInput.style.color='#000';
pixelsInput.className = 'ant-input';
pixelsInput.addEventListener('change', updateScrollConfig);
configDiv.appendChild(speedLabel);
configDiv.appendChild(speedInput);
configDiv.appendChild(pixelsLabel);
configDiv.appendChild(pixelsInput);
document.body.appendChild(configDiv);
}
function addConfigButton() {
var configButton = document.createElement('button');
configButton.textContent = '配置';
configButton.style.position = 'fixed';
configButton.style.bottom = '50%';
configButton.style.right = '-3px';
configButton.style.transform = 'translateY(50%)';
configButton.style.opacity = '.6';
configButton.style.zIndex = '9999';
configButton.style.padding = '8px .5em';
configButton.style.fontSize = '12px';
configButton.style.backgroundColor = '#007BFF';
configButton.style.color = '#fff';
configButton.style.border = 'none';
configButton.style.borderRadius = '5px';
configButton.style.boxShadow = '0 2px 5px rgba(0, 0, 0, 0.2)';
configButton.id = 'configButton';
configButton.addEventListener('click', toggleConfigPanel);
document.body.appendChild(configButton);
}
addConfigButton();
addButton();
})();