|
@@ -96,16 +96,57 @@
|
|
|
button:hover {
|
|
|
background-color: #2c974b;
|
|
|
}
|
|
|
- .ad-container {
|
|
|
+ .carousel {
|
|
|
+ width: 100%;
|
|
|
+ height: 300px;
|
|
|
display: flex;
|
|
|
justify-content: center;
|
|
|
align-items: center;
|
|
|
+ perspective: 1000px;
|
|
|
+ position: relative;
|
|
|
margin-top: 30px;
|
|
|
margin-bottom: 30px;
|
|
|
}
|
|
|
- .ad-container img {
|
|
|
- max-width: 100%;
|
|
|
- border-radius: 8px;
|
|
|
+ .carousel-inner {
|
|
|
+ position: relative;
|
|
|
+ width: 50%;
|
|
|
+ height: 100%;
|
|
|
+ transform-style: preserve-3d;
|
|
|
+ transform: translateZ(-300px);
|
|
|
+ transition: transform 1s;
|
|
|
+ }
|
|
|
+ .carousel-item {
|
|
|
+ position: absolute;
|
|
|
+ width: 70%;
|
|
|
+ height: 100%;
|
|
|
+ left: 50%;
|
|
|
+ top: 0;
|
|
|
+ transform-origin: center center;
|
|
|
+ transition: transform 1s, opacity 1s;
|
|
|
+ opacity: 0.5;
|
|
|
+ }
|
|
|
+ .carousel-item.active {
|
|
|
+ transform: translateX(-50%) translateZ(300px);
|
|
|
+ opacity: 1;
|
|
|
+ }
|
|
|
+ .carousel-item.left {
|
|
|
+ transform: translateX(-150%) translateZ(100px) rotateY(30deg);
|
|
|
+ }
|
|
|
+ .carousel-item.right {
|
|
|
+ transform: translateX(50%) translateZ(100px) rotateY(-30deg);
|
|
|
+ }
|
|
|
+ .carousel-control {
|
|
|
+ position: absolute;
|
|
|
+ top: 50%;
|
|
|
+ transform: translateY(-50%);
|
|
|
+ font-size: 2em;
|
|
|
+ cursor: pointer;
|
|
|
+ }
|
|
|
+ .carousel-control.left {
|
|
|
+ left: 10px;
|
|
|
+ }
|
|
|
+ .carousel-control.right {
|
|
|
+ right: 10px;
|
|
|
}
|
|
|
pre {
|
|
|
background-color: #f6f8fa;
|
|
@@ -211,9 +252,13 @@
|
|
|
width: 100%;
|
|
|
padding: 10px;
|
|
|
}
|
|
|
- .ad-container img {
|
|
|
- width: 100%;
|
|
|
- height: auto;
|
|
|
+ .carousel {
|
|
|
+ height: 300px;
|
|
|
+ }
|
|
|
+ .carousel-item {
|
|
|
+ width: 80%;
|
|
|
+ height: 70%;
|
|
|
+ left: 10%;
|
|
|
}
|
|
|
}
|
|
|
@media (min-width: 769px) {
|
|
@@ -224,7 +269,7 @@
|
|
|
.notification {
|
|
|
display: none;
|
|
|
position: absolute;
|
|
|
- top: 7px; /* Adjust the position as needed */
|
|
|
+ top: 7px;
|
|
|
left: 87%;
|
|
|
transform: translateX(-50%);
|
|
|
background-color: #333;
|
|
@@ -256,8 +301,12 @@
|
|
|
<button onclick="generateCommands()">获取加速命令</button>
|
|
|
</div>
|
|
|
<!-- 广告容器 -->
|
|
|
- <div class="ad-container" id="adContainer" style="display: flex;">
|
|
|
- <!-- 广告内容将通过 JavaScript 动态加载 -->
|
|
|
+ <div class="carousel" id="carousel">
|
|
|
+ <div class="carousel-inner" id="carouselInner">
|
|
|
+ <!-- 图片将在 JavaScript 中加载 -->
|
|
|
+ </div>
|
|
|
+ <div class="carousel-control left" onclick="prevSlide()">❮</div>
|
|
|
+ <div class="carousel-control right" onclick="nextSlide()">❯</div>
|
|
|
</div>
|
|
|
<!-- 结果容器 -->
|
|
|
<div id="result" style="display:none;">
|
|
@@ -278,6 +327,8 @@
|
|
|
document.getElementById('currentYear').textContent = new Date().getFullYear();
|
|
|
|
|
|
let proxyDomain = ''; // 默认代理加速地址
|
|
|
+ let currentIndex = 0;
|
|
|
+ let items = [];
|
|
|
|
|
|
// 生成加速命令
|
|
|
function generateCommands() {
|
|
@@ -321,7 +372,7 @@
|
|
|
|
|
|
// 显示结果并隐藏广告
|
|
|
resultDiv.style.display = 'block';
|
|
|
- document.getElementById('adContainer').style.display = 'none';
|
|
|
+ document.getElementById('carousel').style.display = 'none';
|
|
|
document.getElementById('backToTopBtn').style.display = 'block';
|
|
|
}
|
|
|
|
|
@@ -334,7 +385,6 @@
|
|
|
console.error('无法复制文本: ', err);
|
|
|
});
|
|
|
} else {
|
|
|
- // 回退方案:使用临时的 <textarea> 元素
|
|
|
const textarea = document.createElement('textarea');
|
|
|
textarea.value = text;
|
|
|
document.body.appendChild(textarea);
|
|
@@ -367,6 +417,45 @@
|
|
|
});
|
|
|
}
|
|
|
|
|
|
+ let autoPlayTimer; // 用于存储自动播放的定时器
|
|
|
+
|
|
|
+ // 更新轮播图
|
|
|
+ function updateCarousel() {
|
|
|
+ items.forEach((item, index) => {
|
|
|
+ item.classList.remove('active', 'left', 'right');
|
|
|
+ if (index === currentIndex) {
|
|
|
+ item.classList.add('active');
|
|
|
+ } else if (index === (currentIndex - 1 + items.length) % items.length) {
|
|
|
+ item.classList.add('left');
|
|
|
+ } else if (index === (currentIndex + 1) % items.length) {
|
|
|
+ item.classList.add('right');
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ function prevSlide() {
|
|
|
+ currentIndex = (currentIndex - 1 + items.length) % items.length;
|
|
|
+ updateCarousel();
|
|
|
+ resetAutoPlay(); // 重置自动播放计时器
|
|
|
+ }
|
|
|
+
|
|
|
+ function nextSlide() {
|
|
|
+ currentIndex = (currentIndex + 1) % items.length;
|
|
|
+ updateCarousel();
|
|
|
+ resetAutoPlay(); // 重置自动播放计时器
|
|
|
+ }
|
|
|
+
|
|
|
+ // 开始自动播放
|
|
|
+ function startAutoPlay() {
|
|
|
+ autoPlayTimer = setInterval(nextSlide, 10000); // 每10秒自动切换到下一张
|
|
|
+ }
|
|
|
+
|
|
|
+ // 重置自动播放计时器
|
|
|
+ function resetAutoPlay() {
|
|
|
+ clearInterval(autoPlayTimer);
|
|
|
+ startAutoPlay();
|
|
|
+ }
|
|
|
+
|
|
|
// 获取并加载配置
|
|
|
async function loadConfig() {
|
|
|
try {
|
|
@@ -389,34 +478,33 @@
|
|
|
});
|
|
|
}
|
|
|
if (config.adImages && Array.isArray(config.adImages)) {
|
|
|
- const adContainer = document.getElementById('adContainer');
|
|
|
- adContainer.innerHTML = ''; // 清空广告容器
|
|
|
+ const carouselInner = document.getElementById('carouselInner');
|
|
|
+ carouselInner.innerHTML = ''; // 清空广告容器
|
|
|
config.adImages.forEach((ad, index) => {
|
|
|
- const adLink = document.createElement('a');
|
|
|
- adLink.href = ad.link;
|
|
|
- adLink.target = '_blank';
|
|
|
+ const adItem = document.createElement('div');
|
|
|
+ adItem.className = 'carousel-item';
|
|
|
+ if (index === 0) {
|
|
|
+ adItem.classList.add('active');
|
|
|
+ }
|
|
|
const adImage = document.createElement('img');
|
|
|
adImage.src = ad.url;
|
|
|
adImage.alt = ad.alt || '广告图片';
|
|
|
- adImage.style.display = 'none'; // 初始状态隐藏所有广告图片
|
|
|
- adLink.appendChild(adImage);
|
|
|
- adContainer.appendChild(adLink);
|
|
|
- });
|
|
|
+ adImage.style.width = "100%";
|
|
|
+ adImage.style.height = "100%";
|
|
|
+ adItem.appendChild(adImage);
|
|
|
+ carouselInner.appendChild(adItem);
|
|
|
|
|
|
- // 轮播功能
|
|
|
- let currentAdIndex = 0;
|
|
|
- const adImages = adContainer.querySelectorAll('img');
|
|
|
- function showAd(index) {
|
|
|
- adImages.forEach((img, i) => {
|
|
|
- img.style.display = i === index ? 'block' : 'none';
|
|
|
+ // 添加点击事件监听器
|
|
|
+ adItem.addEventListener('click', function() {
|
|
|
+ window.open(ad.link, '_blank');
|
|
|
});
|
|
|
- }
|
|
|
- showAd(currentAdIndex); // 显示第一张广告图片
|
|
|
|
|
|
- setInterval(() => {
|
|
|
- currentAdIndex = (currentAdIndex + 1) % adImages.length;
|
|
|
- showAd(currentAdIndex);
|
|
|
- }, 5000); // 每5秒切换一次广告
|
|
|
+ // 改变鼠标样式,表明可以点击
|
|
|
+ adItem.style.cursor = 'pointer';
|
|
|
+ });
|
|
|
+ items = document.querySelectorAll('.carousel-item');
|
|
|
+ updateCarousel();
|
|
|
+ startAutoPlay(); // 启动自动播放
|
|
|
}
|
|
|
if (config.proxyDomain) {
|
|
|
proxyDomain = config.proxyDomain;
|
|
@@ -427,6 +515,14 @@
|
|
|
}
|
|
|
|
|
|
loadConfig();
|
|
|
+ // 当页面不可见时暂停自动播放,可见时恢复
|
|
|
+ document.addEventListener("visibilitychange", function() {
|
|
|
+ if (document.hidden) {
|
|
|
+ clearInterval(autoPlayTimer);
|
|
|
+ } else {
|
|
|
+ startAutoPlay();
|
|
|
+ }
|
|
|
+ });
|
|
|
</script>
|
|
|
</body>
|
|
|
</html>
|