Skip to content

Latest commit

 

History

History
46 lines (34 loc) · 2.57 KB

README.md

File metadata and controls

46 lines (34 loc) · 2.57 KB

React component, using Three.js and react-three-renderer showing a 3D scene with STL femur, tibia and patella models. The scene:

  • allows to load STL files for femur/tibia/patella;
  • allows to set the pose for the bones;
  • allows to set insertions positions for SMCL (Superficial Medical Collateral Ligament);
  • allows to set initial camera position;
  • has trackball controls (pan, tilt, zoom);
  • contains a XY floor grid and global coordinate system helper

This is mainly used to have a real-time feedback from knee-squatting mechanical devices, such as the Oxford-Rig

Ligaments paths are being added, as long as patella.

The component KneeModel has the following props:

  • width, height (int): dimensions of the viewer, in pixels;
  • pixelRatio (int): see this
  • femurFile, tibiaFile, patellaFile (string): URL of STL files (e.g. http://localhost:8081/femur.stl, './femur.stl'); Valid STL files are both ASCII and binary. You have to start a server to avoid CORS warnings.
  • femurToLabPose, tibiaToLabPose, patellaToLabPose (array): flattened version fo the 4x4 affine matrix from femur/tibia/patella to global coordinate system;
  • SMCLPath (array): array of 3-elements arrays representing MSCL insertions positions and via paths (in global coordinate system);
  • showFemur, showTibia, showPatella (bool): whether to show femur/tibia/patella in the scene;
  • screenToLabPose (array): flattened version fo the 4x4 affine matrix from screen to global coordinate system;
  • initCameraPosition (array): 3-elements array representing initial camera position (in screen coordinate system);
  • initCameraLookAt (array): 3-elements array representing initial camera target position (in screen coordinate system);

Keep in mind this:

  • screen coordinate system, in Three.js, is normally: X pointing right, Y up, and Z out of the screen towards the user;

For a live example, click here. Other examples (ex2, ...) may be available.

For a standalone running example, You can find an example in the examples folder. If you have Python installed, you can cd to any example folder, open a console and type:

python -m SimpleHTTPServer 8000

Then, in your favourite non-IE browser, type http://localhost:8000/index.html

If you want to rebuild the example yourself, you have the gulpfile to use.