- Project Description
- Features
- Technologies and Tools
- Control Panel
- Device Support
- Project Structure
- Installation and Setup
- License
- Research
- Screenshots
Twist Space is a web application that allows you to upload and interact with 3D models in .glb
format. You can rotate, zoom, and scale models, adjust brightness and other parameters. The app comes preloaded with a model of the character Ganyu.
- Upload Custom Models: Upload your own 3D models in
.glb
format. - Interactive Model Controls: Rotate, scale, and adjust the brightness and contrast of models.
- Control Panel: A control panel in the top-left corner allows you to manage the model and upload new ones. The panel can be hidden.
- Cross-Platform Support: The app is optimized for all device types, including mobile phones.
- Lightweight Routing: Wouter is used for minimalist and fast routing.
React Three Fiber is a library that allows you to use Three.js with React. In Twist Space, it is used to render 3D scenes and interact with them. It makes it easy to manage 3D objects and animations using React's declarative approach.
TailwindCSS is a utility-first CSS framework that lets you quickly customize styles for your application. In Twist Space, TailwindCSS is used to customize the user interface, providing a convenient and flexible way to style elements.
Framer Motion is a library for creating animations in React, and Motion Three Fiber extends its capabilities to work with 3D objects. These tools are used in the project to create smooth animations and interactions with 3D models.
Wouter is a minimalist and lightweight router for React. It provides fast and easy-to-use routing, which is especially important for mobile devices and high-performance applications.
The control panel is located in the top-left corner of the screen and allows you to:
- Upload new 3D models.
- Rotate, scale, and adjust the current model's parameters.
- Hide and show the control panel.
Twist Space is fully responsive and supports use on any device—from desktops to mobile phones. The interface and functionality are optimized to ensure smooth and convenient interaction regardless of screen size.
Here is the project file structure:
TwistSpace/
│
├── node_modules/
├── public/
├── src/
│ ├── Animation/
│ ├── assets/
│ │ └── Styles/
│ │ ├── _mixins.scss
│ │ ├── colors.scss
│ │ ├── global.scss
│ │ └── Main.scss
│ ├── components/
│ │ ├── Checkbox/
│ │ ├── ControlPanel/
│ │ │ ├── AboutMe.tsx
│ │ │ ├── ControlPanel.tsx
│ │ │ ├── HiddenButton.tsx
│ │ │ └── RenderControl.tsx
│ │ ├── DefaultCanvas/
│ │ │ └── DefaultCanvas.tsx
│ │ ├── DragAndDrop/
│ │ │ ├── DragAndDrop.tsx
│ │ │ └── fileUpload.ts
│ │ ├── RangeInput/
│ │ │ └── RangeInput.tsx
│ │ ├── RenderModel/
│ │ │ └── RenderModel.tsx
│ ├── hooks/
│ │ └── MousePosition/
│ │ └── useMousePosition.ts
│ ├── pages/
│ │ └── ErrorPage/
│ ├── store/
│ ├── App.tsx
│ ├── main.tsx
│ ├── vite-env.d.ts
├── .gitattributes
├── .gitignore
├── eslint.config.js
└── index.html
To run the project locally, follow these steps:
-
Clone the repository:
git clone https://github.com/your-repo/TwistSpace.git
-
Navigate to the project directory:
cd TwistSpace
-
Install the dependencies:
npm install
-
Run the project in development mode:
npm run dev
-
To build the project, use:
npm run build
-
For a production preview of the build:
npm run preview
This project is licensed under the MIT License.
Research | Result | Comments |
---|---|---|
🚀 Model Load Time | < 2 seconds | Using lightweight libraries. |
📱 Mobile Performance | 60 FPS | Fully optimized for mobile. |
🌍 Browser Support | 99% of browsers | Cross-browser compatibility. |
Here are some screenshots of the application: