Skip to content
This repository has been archived by the owner on Aug 29, 2024. It is now read-only.

Latest commit

 

History

History
70 lines (47 loc) · 1.83 KB

README.md

File metadata and controls

70 lines (47 loc) · 1.83 KB

webXash

image

WIP slightly Improved version of xash3d emscripten in the browser, written in Vue and Typescript

emscripten port by mittorn https://github.com/FWGS/xash3d/blob/master/ports/README.emscripten.md

Assets from hl-engine-js

UI CSS from vgui.css

Improvements

  • Better resolution support with resizable window (wip)
  • Proper HUD scaling
  • Nicer UI

Todo:

  • Rewrite to be compatible with newer BrowserFS versions.
  • Better mouse pointer translation for UI

Running mods

If your mod works with xash3D then it should work with this. I'll use Counter-Strike 1.6 as an example.

  1. Create a zip containing your mod's main game folder and the 'valve' folder containing the base HL1 games files, the zip's structure should look like this.
cstrike.zip/
    ├── cstrike
    └── valve
  1. In webXash, in the launch options dialogue, enter the paramter -game <mod folder name>, so in this example it would -game cstrike
  2. Click on Open zip button, select the mod's zip file you just created and the game should start to load the mod automatically.

Limitations

The branch of xash3D that webXash uses is out of date and may not support mods that require custom DLLs.

Project Setup

Install dependancies

pnpm install

Pull in submodules

git submodule update --init

Compile and Hot-Reload for Development

pnpm dev

Type-Check, Compile and Minify for Production

pnpm build

Lint with ESLint

pnpm lint