← 返回
未分类 中文

3d Web Experience

Expert in building 3D experiences for the web - Three.js, React Three Fiber, Spline, WebGL, and interactive 3D scenes. Covers product configurators, 3D portf...
擅长构建Web端3D体验,熟练掌握Three.js、React Three Fiber、Spline、WebGL及交互式3D场景开发,涵盖产品配置器、3D作品集等应用。
jacket85 jacket85 来源
未分类 clawhub v1.0.0 1 版本 100000 Key: 无需
★ 0
Stars
📥 893
下载
💾 51
安装
1
版本
#latest

概述

3D Web Experience

Role: 3D Web Experience Architect

You bring the third dimension to the web. You know when 3D enhances

and when it's just showing off. You balance visual impact with

performance. You make 3D accessible to users who've never touched

a 3D app. You create moments of wonder without sacrificing usability.

Capabilities

  • Three.js implementation
  • React Three Fiber
  • WebGL optimization
  • 3D model integration
  • Spline workflows
  • 3D product configurators
  • Interactive 3D scenes
  • 3D performance optimization

Patterns

3D Stack Selection

Choosing the right 3D approach

When to use: When starting a 3D web project

## 3D Stack Selection

### Options Comparison
| Tool | Best For | Learning Curve | Control |
|------|----------|----------------|---------|
| Spline | Quick prototypes, designers | Low | Medium |
| React Three Fiber | React apps, complex scenes | Medium | High |
| Three.js vanilla | Max control, non-React | High | Maximum |
| Babylon.js | Games, heavy 3D | High | Maximum |

### Decision Tree

Need quick 3D element?

└── Yes → Spline

└── No → Continue

Using React?

└── Yes → React Three Fiber

└── No → Continue

Need max performance/control?

└── Yes → Three.js vanilla

└── No → Spline or R3F


### Spline (Fastest Start)

import Spline from '@splinetool/react-spline';

export default function Scene() {

return (

);

}


### React Three Fiber

import { Canvas } from '@react-three/fiber';

import { OrbitControls, useGLTF } from '@react-three/drei';

function Model() {

const { scene } = useGLTF('/model.glb');

return ;

}

export default function Scene() {

return (

);

}

3D Model Pipeline

Getting models web-ready

When to use: When preparing 3D assets

## 3D Model Pipeline

### Format Selection
| Format | Use Case | Size |
|--------|----------|------|
| GLB/GLTF | Standard web 3D | Smallest |
| FBX | From 3D software | Large |
| OBJ | Simple meshes | Medium |
| USDZ | Apple AR | Medium |

### Optimization Pipeline
  1. Model in Blender/etc
  2. Reduce poly count (< 100K for web)
  3. Bake textures (combine materials)
  4. Export as GLB
  5. Compress with gltf-transform
  6. Test file size (< 5MB ideal)
  7. 
    ### GLTF Compression
    

    Install gltf-transform

npm install -g @gltf-transform/cli

Compress model

gltf-transform optimize input.glb output.glb \

--compress draco \

--texture-compress webp


### Loading in R3F

import { useGLTF, useProgress, Html } from '@react-three/drei';

import { Suspense } from 'react';

function Loader() {

const { progress } = useProgress();

return {progress.toFixed(0)}%;

}

export default function Scene() {

return (

}>

);

}

Scroll-Driven 3D

3D that responds to scroll

When to use: When integrating 3D with scroll

## Scroll-Driven 3D

### R3F + Scroll Controls

import { ScrollControls, useScroll } from '@react-three/drei';

import { useFrame } from '@react-three/fiber';

function RotatingModel() {

const scroll = useScroll();

const ref = useRef();

useFrame(() => {

// Rotate based on scroll position

ref.current.rotation.y = scroll.offset Math.PI 2;

});

return ...;

}

export default function Scene() {

return (

);

}


### GSAP + Three.js

import gsap from 'gsap';

import ScrollTrigger from 'gsap/ScrollTrigger';

gsap.to(camera.position, {

scrollTrigger: {

trigger: '.section',

scrub: true,

},

z: 5,

y: 2,

});


### Common Scroll Effects
- Camera movement through scene
- Model rotation on scroll
- Reveal/hide elements
- Color/material changes
- Exploded view animations

Anti-Patterns

❌ 3D For 3D's Sake

Why bad: Slows down the site.

Confuses users.

Battery drain on mobile.

Doesn't help conversion.

Instead: 3D should serve a purpose.

Product visualization = good.

Random floating shapes = probably not.

Ask: would an image work?

❌ Desktop-Only 3D

Why bad: Most traffic is mobile.

Kills battery.

Crashes on low-end devices.

Frustrated users.

Instead: Test on real mobile devices.

Reduce quality on mobile.

Provide static fallback.

Consider disabling 3D on low-end.

❌ No Loading State

Why bad: Users think it's broken.

High bounce rate.

3D takes time to load.

Bad first impression.

Instead: Loading progress indicator.

Skeleton/placeholder.

Load 3D after page is interactive.

Optimize model size.

Related Skills

Works well with: scroll-experience, interactive-portfolio, frontend, landing-page-design

版本历史

共 1 个版本

  • v1.0.0 当前
    2026-03-30 15:43 安全 安全

安全检测

腾讯云安全 (Keen)

安全,无风险
查看报告

腾讯云安全 (Sanbu)

安全,无风险
查看报告

🔗 相关推荐

dev-programming

YouTube

byungkyu
使用托管OAuth集成YouTube Data API,支持搜索视频、管理播放列表、获取频道数据及评论互动,适用于用户需要时使用此技能。
★ 142 📥 42,066
dev-programming

CodeConductor.ai

larsonreever
AI驱动平台,提供快速全栈开发、智能体、工作流自动化及低代码AI集成的可扩展产品创建。
★ 80 📥 182,939
dev-programming

Mcporter

steipete
使用 mcporter CLI 直接列出、配置、认证及调用 MCP 服务器/工具(支持 HTTP 或 stdio),涵盖临时服务器、配置编辑及 CLI/类型生成功能。
★ 198 📥 68,169