3D Stories is a powerful tool designed to present 3D Models of historic garments from the textile collection at the Germanisches Nationalmuseum Nuremberg. Developed in collaboration with the Urban Complexity Lab of Potsdam, this tool provides an interactive and immersive experience for exploring historic textiles.
- Installation
- Usage
- Features
- Applications Used
- How to Create Your 3D Story (Step-by-Step User Guide)
- Contributing
- License
Ensure you have the following installed:
-
Clone the repository:
git clone https://github.com/yourusername/3D-Stories.git cd 3D-Stories
-
Install the dependencies:
npm install
-
To build under a specific path, e.g.
/3dstories
you also need to specify the full base url in theVITE_URL
variable:VITE_URL=https://your-domain/3dstories npm run build -- --base=/3dstories
-
Preview:
npm run preview -- --base=/3dstories
To start the application, run the following command:
npm run dev
This will launch the development server and open the application in your default web browser.
- Animated Storyline: Animation of 3D objects based on a narrative that guides the user through the object's details.
- Visual Consistency: Link your presentation to a preferable position, rotation, or scale of the 3D/2D objects.
- Flexible Navigation:
- Scrolling
- Points of interest (the model exploration mode).
- Fullscreen menu navigation
- Orbit Tool: Use the orbit tool to explore the 3D Model from different angles (Rotate, Zoom Out/In (Scale), Move).
- Multiple Objects: Animate and explore multiple objects within a single story.
- Modal Windows: Modal windows provide additional images and information related to the text.
- Responsive Design: Optimized for both desktop and mobile devices.
- React Vite: For building a fast and modern web application.
- React Three Fiber: For rendering 3D graphics using Three.js in React.
- Theatre JS: For animation and interactive experiences.
- Blender: For converting 3D Models to glb/gltf format.
You can preview your glTF models using the following tools:
We welcome contributions! If you would like to contribute to this project, please follow these steps:
- Fork the repository.
- Create a new branch (
git checkout -b feature/YourFeature
). - Make your changes and commit them (
git commit -m 'Add some feature'
). - Push to the branch (
git push origin feature/YourFeature
). - Open a Pull Request.
This project is licensed under the GNU Affero General Public License. See the AGPL-3.0 License for details.