Like any simple typescript repository everything start with.
git clone https://github.com/BabylonJS/Spector.js.git
cd spector
npm install
Then you can use the following npm commands to speed your development:
npm start
Will compile and run a local server with a watch command so that you can directly try your changes (TS or scss). Navigate to the the embedded sample to start playing with the dev tools.npm run build
Will create and build a new version of the dist folder files.npm run clean
Will clean all the generated files from the repo.
If you are looking for the temporary generated .js or .map files, they are all available in the built folder which is not under source control.
I would recommend developping on VsCode as the entire setup is present so that if you install the chrome debugger extension you can directly debug from your typescript files by pressing F5.
As Tslint is part of the build checks, please run it locally before any PR. The easiest is to install the TsLint plugin in VsCode.
npm run build:tslint
Once npm start
has been launched, you can access the following samples to try your new features:
- Exception: Test of exception during capture.
- No Render: Test to capture if no frame are detected.
- No command: Simple use case containing a frame with no webgl commands.
- Simple: A basic use case validating state changes.
- Lights: Simple BabylonJS scene with three lights.
- Texture 2d: BabylonJS scene containing materials with texture.
- Texture cube: BabylonJS scene containing a cube texture.
- Render Target Texture: Test to do a capture containing render target textures.
- Float Render Target Texture: Test to do a capture containing float render target textures.
- MSAA Render Buffer: Test to do a capture containing an msaa render buffer.
- Buffer View Texture: Test to do a capture containing a cube texture created from bufferview data.
- Instanced: Test to do a capture of instanced objects.
- Float sized FrameBuffer: Test to do a capture containing a none integer based sized FrameBuffer.
- Uniform Command: Test to do a capture a uniform with a value matching a webgl constant.
- Custom Metadata: Test to do a capture containing custom metadata.
- Custom Marker: Test to do a capture containing custom marker.
- Custom Shader Name in define SHADER_NAME: Test to do a capture containing custom marker.
- Uniform Array: Test to do a capture containing uniform array values.
- Quick Capture: Test to do a quick capture not containing visual states.
- Depth Range: Test redundant depth range states.
- setTimeout Parameters: Test parameters of setTimeout functions.
- Viewport: Test viewport capture in Render Targets.
- Offscreen: Test Offscreen canvas support.
- Scissor Clear: Test scissor redundant calls when clearing.
- Custom Log: Test the custom log functionnality.
- Pixelated Nearest: Test visual texture capture being pixelated on nearest.
You can also add &noSpy=1 at the end of the previous Urls to test without enabling the full spy before starting your rendering engine.
To add a new sample, simply add a new script in the sample/js
folder. To launch it you can use the following url by replacing the fileName
by your new file name without the .js
extension.
http://localhost:1337/sample/index.html?sample=fileName
As stated on the extension documentation, you can side load the extension. The main use cases to try out to test the captures are:
- BabylonJS playground: Test a few of the available scenes.
- Sketchfab
- Sketchfab WebGL 2
- Play Canvas Over the flood
- 5000 Commands