forked from 77media/video-flow
319 lines
5.7 KiB
CSS
319 lines
5.7 KiB
CSS
/**
|
|
* 视频编辑功能响应式样式
|
|
*/
|
|
|
|
/* 基础样式 */
|
|
.video-edit-overlay {
|
|
position: absolute;
|
|
inset: 0;
|
|
z-index: 15;
|
|
border-radius: 8px;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.video-edit-point {
|
|
position: absolute;
|
|
z-index: 20;
|
|
cursor: pointer;
|
|
user-select: none;
|
|
}
|
|
|
|
.video-edit-connection {
|
|
position: absolute;
|
|
inset: 0;
|
|
pointer-events: none;
|
|
z-index: 10;
|
|
}
|
|
|
|
.video-edit-input {
|
|
position: absolute;
|
|
z-index: 30;
|
|
min-width: 280px;
|
|
max-width: 400px;
|
|
}
|
|
|
|
/* 大屏幕样式 (桌面端) */
|
|
@media (min-width: 1024px) {
|
|
.video-edit-input {
|
|
min-width: 320px;
|
|
max-width: 450px;
|
|
}
|
|
|
|
.video-edit-point {
|
|
transform-origin: center;
|
|
}
|
|
|
|
.video-edit-point:hover {
|
|
transform: scale(1.1);
|
|
}
|
|
}
|
|
|
|
/* 中等屏幕样式 (平板端) */
|
|
@media (min-width: 768px) and (max-width: 1023px) {
|
|
.video-edit-input {
|
|
min-width: 260px;
|
|
max-width: 350px;
|
|
}
|
|
|
|
.video-edit-point {
|
|
/* 增大点击区域 */
|
|
padding: 4px;
|
|
margin: -4px;
|
|
}
|
|
}
|
|
|
|
/* 小屏幕样式 (手机端) */
|
|
@media (max-width: 767px) {
|
|
.video-edit-input {
|
|
min-width: 240px;
|
|
max-width: calc(100vw - 40px);
|
|
font-size: 14px;
|
|
}
|
|
|
|
.video-edit-point {
|
|
/* 进一步增大点击区域 */
|
|
padding: 6px;
|
|
margin: -6px;
|
|
/* 增大编辑点尺寸 */
|
|
transform: scale(1.2);
|
|
}
|
|
|
|
/* 输入框在小屏幕上的特殊处理 */
|
|
.video-edit-input .input-container {
|
|
padding: 12px;
|
|
}
|
|
|
|
.video-edit-input textarea {
|
|
font-size: 14px;
|
|
line-height: 1.4;
|
|
}
|
|
|
|
.video-edit-input .button-group {
|
|
flex-direction: column;
|
|
gap: 8px;
|
|
}
|
|
|
|
.video-edit-input .submit-button {
|
|
width: 100%;
|
|
justify-content: center;
|
|
}
|
|
}
|
|
|
|
/* 超小屏幕样式 (小手机) */
|
|
@media (max-width: 480px) {
|
|
.video-edit-input {
|
|
min-width: 200px;
|
|
max-width: calc(100vw - 20px);
|
|
font-size: 13px;
|
|
}
|
|
|
|
.video-edit-point {
|
|
/* 最大化点击区域 */
|
|
padding: 8px;
|
|
margin: -8px;
|
|
transform: scale(1.3);
|
|
}
|
|
|
|
/* 连接线在小屏幕上的调整 */
|
|
.video-edit-connection svg {
|
|
stroke-width: 3;
|
|
}
|
|
|
|
/* 输入框头部简化 */
|
|
.video-edit-input .header {
|
|
padding: 8px 12px;
|
|
font-size: 12px;
|
|
}
|
|
|
|
.video-edit-input .footer {
|
|
padding: 8px 12px;
|
|
flex-direction: column;
|
|
align-items: stretch;
|
|
gap: 8px;
|
|
}
|
|
|
|
.video-edit-input .char-count {
|
|
text-align: center;
|
|
font-size: 11px;
|
|
}
|
|
}
|
|
|
|
/* 触摸设备优化 */
|
|
@media (hover: none) and (pointer: coarse) {
|
|
.video-edit-point {
|
|
/* 触摸设备上增大点击区域 */
|
|
min-width: 44px;
|
|
min-height: 44px;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
}
|
|
|
|
.video-edit-point:hover {
|
|
transform: none;
|
|
}
|
|
|
|
.video-edit-point:active {
|
|
transform: scale(0.95);
|
|
}
|
|
|
|
/* 触摸设备上的输入框优化 */
|
|
.video-edit-input textarea {
|
|
font-size: 16px; /* 防止iOS缩放 */
|
|
}
|
|
}
|
|
|
|
/* 高分辨率屏幕优化 */
|
|
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
|
|
.video-edit-connection svg {
|
|
/* 高分辨率屏幕上的线条优化 */
|
|
shape-rendering: geometricPrecision;
|
|
}
|
|
|
|
.video-edit-point {
|
|
/* 高分辨率屏幕上的边框优化 */
|
|
border-width: 0.5px;
|
|
}
|
|
}
|
|
|
|
/* 暗色模式适配 */
|
|
@media (prefers-color-scheme: dark) {
|
|
.video-edit-input {
|
|
--bg-color: rgba(0, 0, 0, 0.8);
|
|
--border-color: rgba(255, 255, 255, 0.2);
|
|
--text-color: rgba(255, 255, 255, 0.9);
|
|
--text-secondary: rgba(255, 255, 255, 0.6);
|
|
}
|
|
}
|
|
|
|
/* 亮色模式适配 */
|
|
@media (prefers-color-scheme: light) {
|
|
.video-edit-input {
|
|
--bg-color: rgba(255, 255, 255, 0.9);
|
|
--border-color: rgba(0, 0, 0, 0.1);
|
|
--text-color: rgba(0, 0, 0, 0.9);
|
|
--text-secondary: rgba(0, 0, 0, 0.6);
|
|
}
|
|
}
|
|
|
|
/* 减少动画的用户偏好 */
|
|
@media (prefers-reduced-motion: reduce) {
|
|
.video-edit-point,
|
|
.video-edit-input,
|
|
.video-edit-connection {
|
|
animation: none !important;
|
|
transition: none !important;
|
|
}
|
|
|
|
.video-edit-point:hover {
|
|
transform: none;
|
|
}
|
|
}
|
|
|
|
/* 横屏模式优化 */
|
|
@media (orientation: landscape) and (max-height: 600px) {
|
|
.video-edit-input {
|
|
max-height: 80vh;
|
|
overflow-y: auto;
|
|
}
|
|
|
|
.video-edit-input textarea {
|
|
max-height: 100px;
|
|
}
|
|
}
|
|
|
|
/* 竖屏模式优化 */
|
|
@media (orientation: portrait) and (max-width: 768px) {
|
|
.video-edit-input {
|
|
max-width: 90vw;
|
|
}
|
|
|
|
/* 确保输入框不会超出屏幕 */
|
|
.video-edit-overlay {
|
|
padding: 10px;
|
|
}
|
|
}
|
|
|
|
/* 可访问性优化 */
|
|
@media (prefers-contrast: high) {
|
|
.video-edit-point {
|
|
border-width: 2px;
|
|
border-color: currentColor;
|
|
}
|
|
|
|
.video-edit-connection svg {
|
|
stroke-width: 3;
|
|
stroke: currentColor;
|
|
}
|
|
|
|
.video-edit-input {
|
|
border-width: 2px;
|
|
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
|
|
}
|
|
}
|
|
|
|
/* 打印样式 */
|
|
@media print {
|
|
.video-edit-overlay,
|
|
.video-edit-point,
|
|
.video-edit-input,
|
|
.video-edit-connection {
|
|
display: none !important;
|
|
}
|
|
}
|
|
|
|
/* 工具类 */
|
|
.video-edit-hidden {
|
|
display: none !important;
|
|
}
|
|
|
|
.video-edit-visible {
|
|
display: block !important;
|
|
}
|
|
|
|
.video-edit-fade-in {
|
|
animation: videoEditFadeIn 0.3s ease-out;
|
|
}
|
|
|
|
.video-edit-fade-out {
|
|
animation: videoEditFadeOut 0.3s ease-out;
|
|
}
|
|
|
|
@keyframes videoEditFadeIn {
|
|
from {
|
|
opacity: 0;
|
|
transform: translateY(-10px) scale(0.95);
|
|
}
|
|
to {
|
|
opacity: 1;
|
|
transform: translateY(0) scale(1);
|
|
}
|
|
}
|
|
|
|
@keyframes videoEditFadeOut {
|
|
from {
|
|
opacity: 1;
|
|
transform: translateY(0) scale(1);
|
|
}
|
|
to {
|
|
opacity: 0;
|
|
transform: translateY(-10px) scale(0.95);
|
|
}
|
|
}
|
|
|
|
/* 脉冲动画 */
|
|
@keyframes videoEditPulse {
|
|
0%, 100% {
|
|
opacity: 0.6;
|
|
transform: scale(1);
|
|
}
|
|
50% {
|
|
opacity: 0.2;
|
|
transform: scale(1.5);
|
|
}
|
|
}
|
|
|
|
.video-edit-pulse {
|
|
animation: videoEditPulse 2s ease-in-out infinite;
|
|
}
|