// ==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 // @downloadURL none // ==/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(); })();