Skip to content

Latest commit

 

History

History
78 lines (63 loc) · 2.9 KB

README.md

File metadata and controls

78 lines (63 loc) · 2.9 KB

csx3dif

A complete rewrite of csx2dif in Rust, fixing the critical issues.
Converts Torque Constructor CSX files to Torque DIF interior format.

Usage

Usage: csx3dif.exe [OPTIONS] <FILEPATH>

Arguments:
  <FILEPATH>

Options:
  -s, --silent
          Silent, don't print output
  -d, --dif-version <DIF_VERSION>
          Dif version to export to [default: 0]
  -e, --engine-version <ENGINE_VERSION>
          Engine version to export to [default: mbg] [possible values: mbg, tge, tgea, t3d]
      --mb <MB>
          Make DIF optimized for Marble Blast [default: true] [possible values: true, false]
      --bsp <BSP>
          BSP algorithm to use [default: exhaustive] [possible values: sampling, exhaustive, none]
      --epsilon-point <EPSILON_POINT>
          Epsilon for points to be considered the same [default: 0.000001]
      --epsilon-plane <EPSILON_PLANE>
          Epsilon for planes to be considered the same [default: 0.00001]
  -h, --help
          Print help
  -V, --version
          Print version

Features

  • Exports malformed brushes without compromise!
  • Entity support
  • PathedInterior support (as subobjects), path_node entities will belong to the Door_Elevator entity that was added before those path_nodes.
  • Automatic splitting of large CSX files into multiple DIF files
  • (mostly) Working balanced BSP tree for raycasts.
  • Target any version of the Torque Game Engine/Torque3D

Not supported features

  • Lighting and Lightmaps
  • Zones and Portals
  • Static Meshes
  • Vehicle Collision

FAQ

Conversion times are too long

This is because creating the BSP tree for raycasts takes a while, you can skip building the BSP tree with --bsp none. You will not be able to raycast, but conversion will be much faster. If your map does not need any raycasts, this option is advisible to reduce the filesize.

Raycasts are not working for some faces

This is because of the epsilon value of planes being too small, increase them with --epsilon-plane <EPSILON_PLANE>. However, this can cause some faces to be incorrectly merged with other faces, causing collision bugs. So you need to find a balance between working collision and working raycasts.

In marble blast, where do raycasts happen?

Marble Blast Gold/Platinum does not make use of raycasts. PlatinumQuest makes use of raycasts for drawing the cannon trajectory as well as the "Drop to Ground" option in the editor.

What about map2dif rewrite?

Unfortunately due to the significant shortcomings of the .map format, one of them being lack of complete information in the file format itself, it is not feasible to write a full map2dif rewrite. Torque Constructor can be used to convert .map to .csx as a middleware to convert .map to .dif

Build

Terminal

cargo build --release

Web

cd csx3dif-web
wasm-pack build --target web
cd js/csx3dif-web
npm run dev

Credits

Thanks to HiGuy for the libdif library to parse/write dif files.