Skip to content

aiko-tv/ui

Repository files navigation

aikotv

Aikotv is a modern web-based application designed to deliver immersive 3D experiences, chat functionalities, and dynamic content. Built with Vite, React, and Three.js, it provides a platform for interactive 3D streaming and social features.

Project Structure

The project includes several essential components and contexts:

  • ThreeScene.tsx: Core component for rendering 3D scenes using @react-three/fiber
  • SceneWrapper.tsx: Wrapper component for managing scene layouts and transitions
  • constants.ts: Configuration for BGM, scenes, and environment settings
  • SceneEngineContext.tsx: Context provider for scene rendering logic
  • ScenesContext.tsx: Manages multiple scenes and their states

Key Features

  • 3D model rendering with VRM support
  • Scene configuration system
  • Background music management
  • Interactive camera controls
  • Multi-agent support
  • Solana wallet integration

Technology Stack

  • Frontend Framework: React 18 with TypeScript
  • Build Tool: Vite
  • 3D Libraries: Three.js, @react-three/fiber, @react-three/drei
  • Styling: Tailwind CSS
  • State Management: React Context API
  • Web3: Solana Web3.js

Getting Started

Prerequisites

  • Node.js
  • npm or yarn
  • Bun (for server)

Installation

  1. Clone the repository:

    git clone https://github.com/your-repo/aikotv.git
  2. Install dependencies:

    cd aikotv
    npm install
  3. Start the development server:

    npm run dev
  4. Visit http://localhost:5173 to view the application.

Development Scripts

  • npm run dev: Start development server
  • npm run build: Build for production
  • npm run preview: Preview production build
  • npm run lint: Run ESLint
  • npm run server: Start Bun server

Scene Configuration

The application supports dynamic scene configuration through a JSON-based system. Scene configurations include:

  • Model positioning
  • Camera angles
  • Environment settings
  • Animation states
  • Background music selection

To create a new scene:

  1. Use the in-app scene editor (Window button between fullscreen and share)
  2. Use WASD + QE for camera movement
  3. Use IJKL + UO for model movement and rotation
  4. Use numbers 1-9 to select models
  5. Copy the generated configuration from console
  6. Add to the scenes configuration in constants.ts

Contributing

We welcome contributions to improve Aikotv. Please follow these steps:

  1. Fork the repository
  2. Create a feature branch
  3. Commit your changes
  4. Push to your branch
  5. Create a Pull Request

License

This project is licensed under the MIT License. See the LICENSE file for details.

Releases

No releases published

Packages

No packages published