Skip to content

clapppp/psh

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

73 Commits
 
 
 
 
 
 

Repository files navigation

PSH

Overview

PSH is a personal web platform designed as a playground for my experimental web services.

Tech Stack

  • Framework: Next.js (Custom Server)
  • Graphics: Three.js / React Three Fiber
  • Styling: Tailwind CSS
  • Real-time Communication: WebSocket

Service 1: 3D Multiplayer Space

An interactive virtual environment where visitors can control avatars and interact in real-time.

Features

  • 3D Skeleton Avatar: Users control a 3D character powered by Three.js.
  • Real-time Sync: Multiple users can see each other's movement simultaneously via WebSockets.
  • Responsive Controls: Optimized navigation for both desktop and mobile devices.

Architecture

Custom Server

I implemented a Custom Node.js Server that wraps the Next.js application.

  • HTTP Requests: Delegated to the Next.js renderer.
  • WebSocket Requests: Intercepted by the custom server to handle real-time connection upgrades and message broadcasting, enabling multiplayer features without external PaaS dependency.

Challenges & Improvements

Optimization of Real-time Movement

  • Issue: Initially, I applied Linear Interpolation (Lerp) to smooth out avatar movements. However, tuning the interpolation factor proved difficult, causing the avatar to "rubber-band" or slide excessively.
  • Current Workaround: To mitigate this, I increased the WebSocket transmission frequency to minimize the gap between updates. While this improved smoothness, it significantly increased network bandwidth usage.

168.107.4.68:4000

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published