重构为左中右三栏卡片切换效果
All checks were successful
continuous-integration/drone/push Build is passing

- 中间显示主卡片,完整展示内容
- 左右两侧显示相邻卡片的部分预览(缩小85%,半透明)
- 切换时右侧卡片滑动到中间成为主卡片
- 同时中间卡片滑动到左侧成为预览
- 左侧卡片向左消失,新的右侧卡片从右边进入
- 所有卡片同步移动,形成流畅的轮播效果
- 动画时长0.6s,使用 cubic-bezier 缓动
- 保持自动播放和交互功能

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
yiqiu
2025-11-25 16:06:15 +08:00
parent 817df58b69
commit 8cb6d0cdc9
2 changed files with 148 additions and 92 deletions

View File

@@ -2696,93 +2696,141 @@ html {
display: none;
}
/* 下层:幻灯片容器 - 支持卡片堆叠视觉 */
/* 下层:幻灯片容器 - 左中右三栏布局 */
.solution-slider {
position: relative;
min-height: 450px;
perspective: 1000px;
padding-bottom: 30px;
perspective: 1500px;
overflow: visible;
}
/* 单个幻灯片 - 堆叠卡片效果 */
/* 单个幻灯片 - 默认隐藏 */
.solution-slide {
position: absolute;
top: 0;
left: 0;
left: 50%;
width: 100%;
opacity: 0;
transform: translateX(-100%) scale(0.95);
transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
transform: translateX(-50%) scale(0.7);
transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
pointer-events: none;
z-index: 1;
}
/* 激活的幻灯片 */
/* 中间激活的主卡片 */
.solution-slide.active {
position: relative;
left: 0;
opacity: 1;
transform: translateX(0) translateY(0) scale(1);
transform: translateX(0) scale(1);
pointer-events: auto;
z-index: 10;
}
/* 后面的卡片 - 显示部分轮廓 */
.solution-slide.stack-1 {
/* 左侧卡片 - 上一张的预览 */
.solution-slide.prev {
position: absolute;
opacity: 0.6;
transform: translateX(0) translateY(10px) scale(0.98);
left: 0;
opacity: 0.5;
transform: translateX(-55%) scale(0.85);
pointer-events: none;
z-index: 9;
filter: brightness(0.9);
}
.solution-slide.stack-2 {
position: absolute;
opacity: 0.4;
transform: translateX(0) translateY(20px) scale(0.96);
pointer-events: none;
z-index: 8;
filter: brightness(0.8);
}
.solution-slide.stack-3 {
position: absolute;
opacity: 0.2;
transform: translateX(0) translateY(30px) scale(0.94);
pointer-events: none;
z-index: 7;
z-index: 5;
filter: brightness(0.7);
}
/* 即将离开的幻灯片 */
.solution-slide.leaving {
/* 右侧卡片 - 下一张的预览 */
.solution-slide.next {
position: absolute;
opacity: 1;
transform: translateX(0) scale(1);
z-index: 11;
animation: slideOutLeft 0.8s cubic-bezier(0.4, 0, 0.2, 1) forwards;
left: auto;
right: 0;
opacity: 0.5;
transform: translateX(55%) scale(0.85);
pointer-events: none;
z-index: 5;
filter: brightness(0.7);
}
@keyframes slideOutLeft {
/* 切换动画 - 从右到中 */
.solution-slide.slide-to-center {
animation: slideFromRightToCenter 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
z-index: 11;
}
@keyframes slideFromRightToCenter {
from {
left: auto;
right: 0;
opacity: 0.5;
transform: translateX(55%) scale(0.85);
filter: brightness(0.7);
}
to {
transform: translateX(-120%) scale(0.9);
opacity: 0;
left: 0;
right: auto;
opacity: 1;
transform: translateX(0) scale(1);
filter: brightness(1);
}
}
/* 即将进入的幻灯片 */
.solution-slide.entering {
position: absolute;
opacity: 0;
transform: translateX(120%) scale(0.9);
z-index: 6;
animation: slideInRight 0.8s cubic-bezier(0.4, 0, 0.2, 1) forwards;
/* 切换动画 - 从中到左 */
.solution-slide.slide-to-left {
animation: slideFromCenterToLeft 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
z-index: 9;
}
@keyframes slideInRight {
to {
transform: translateX(0) scale(1);
@keyframes slideFromCenterToLeft {
from {
left: 0;
opacity: 1;
transform: translateX(0) scale(1);
filter: brightness(1);
}
to {
left: 0;
opacity: 0.5;
transform: translateX(-55%) scale(0.85);
filter: brightness(0.7);
}
}
/* 切换动画 - 从左消失 */
.solution-slide.slide-out-left {
animation: slideOutToLeft 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
z-index: 3;
}
@keyframes slideOutToLeft {
from {
left: 0;
opacity: 0.5;
transform: translateX(-55%) scale(0.85);
}
to {
left: 0;
opacity: 0;
transform: translateX(-80%) scale(0.7);
}
}
/* 切换动画 - 从右侧外进入到右侧位置 */
.solution-slide.slide-in-right {
animation: slideInFromRight 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
z-index: 4;
}
@keyframes slideInFromRight {
from {
left: auto;
right: 0;
opacity: 0;
transform: translateX(80%) scale(0.7);
}
to {
left: auto;
right: 0;
opacity: 0.5;
transform: translateX(55%) scale(0.85);
}
}