gifuct+gif实现gif动画帧解析可视化编辑拖拽换位导出动画代码
代码语言:html
所属分类:动画
代码描述:gifuct+gif实现gif动画帧解析可视化编辑拖拽换位导出动画代码,gifuct负责解析gif动画一个个帧图片,gif插件负责将编辑后的多个帧图片导出新的gif动画。
代码标签: gifuct gif gif 动画 帧 解析 可视化 编辑 拖拽 换位 导出 动画 代码
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>GIF动画帧编辑器</title>
<style>
* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: 'Arial', sans-serif; background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); padding: 20px; min-height: 100vh; }
.container { max-width: 1400px; margin: 0 auto; background: white; border-radius: 20px; padding: 30px; box-shadow: 0 20px 60px rgba(0,0,0,0.3); }
h1 { text-align: center; color: #333; margin-bottom: 30px; font-size: 2.5em; text-shadow: 2px 2px 4px rgba(0,0,0,0.1); }
.upload-section { text-align: center; margin-bottom: 30px; padding: 40px; border: 3px dashed #667eea; border-radius: 15px; background: #f8f9ff; transition: all 0.3s; }
.upload-section:hover { border-color: #764ba2; background: #f0f1ff; }
.upload-btn { display: inline-block; padding: 15px 40px; background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); color: white; border: none; border-radius: 50px; cursor: pointer; font-size: 16px; font-weight: bold; transition: transform 0.2s; }
.upload-btn:hover { transform: scale(1.05); }
input[type="file"] { display: none; }
.controls { display: flex; gap: 15px; margin-bottom: 30px; flex-wrap: wrap; justify-content: center; }
.btn { padding: 12px 25px; border: none; border-radius: 8px; cursor: pointer; font-size: 14px; font-weight: bold; transition: all 0.3s; color: white; }
.btn-primary { background: #667eea; }
.btn-success { background: #10b981; }
.btn-danger { background: #ef4444; }
.btn-warning { background: #f59e0b; }
.btn:hover { transform: translateY(-2px); box-shadow: 0 5px 15px rgba(0,0,0,0.2); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; box-shadow: none; }
.preview-section { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; margin-bottom: 30px; }
.original-preview, .new-preview { text-align: center; }
.preview-title { font-size: 18px; font-weight: bold; margin-bottom: 15px; color: #333; }
canvas { border: 2px solid #ddd; border-radius: 10px; max-width: 100%; height: auto; background: #f9f9f9; }
.frames-container { background: #f9f9f9; padding: 20px; border-radius: 15px; margin-bottom: 30px; }
.frames-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 15px; }
.frame-item { position: relative; border: 3px solid #ddd; border-radius: 10px; padding: 10px; background: white; cursor: move; transition: all 0.3s; }
.frame-item:hover { transform: translateY(-5px); box-shadow: 0 5px 20px rgba(0,0,0,0.15); }
.frame-item.selected { border-color: #667eea; box-shadow: 0 0 20px rgba(102, 126, 234, 0.5); }
.frame-item.dragging { opacity: 0.4; transform: scale(1.05); }
.frame-item.drag-over { border-style: dashed; border-color: #764ba2; }
.frame-canvas { width: 100%; border-radius: 5px; background-image: linear-gradient(45deg, #eee 25%, transparent 25%), linear-gradient(-45deg, #eee 25%, transparent 25%), linear-gradient(45deg, transparent 75%, #eee 75%), linear-gradient(-45deg, transparent 75%, #eee 75%); background-size: 20px 20px; background-position: 0 0, 0 10px, 10px -10px, -10px 0px; }
.frame-number { text-align: center; margin-top: 8px; font-weight: bold; color: #666; font-size: 12px; }
.frame-delay { text-align: center; margin-top: 5px; }
.frame-delay input { width: 60px; padding: 4px; border: 1px solid #ddd; border-radius: 4px; text-align: center; }
.frame-actions { display: flex; justify-content: center; gap: 5px; margin-top: 8px; }
.frame-btn { padding: 5px 10px; font-size: 12px; border: none; border-radius: 5px; cursor: pointer; transition: all 0.2s; }
.frame-btn-delete { background: #ef4444; color: white; }
.frame-btn-duplicate { background: #10b981; color: white; }
.frame-btn:hover { transform: scale(1.1); }
.settings { background: #f9f9f9; padding: 20px; border-radius: 15px; margin-bottom: 20px; display: flex; align-items: center; justify-content: ce.........完整代码请登录后点击上方下载按钮下载查看
















网友评论0