Skip to content
kevingadd edited this page Apr 14, 2012 · 12 revisions

JSILc includes a set of profiles for XNA 3.1 and XNA 4.0. If it detects that the project you're building is an XNA game (you'll need to feed it your .sln file, not your executable), it will automatically load the appropriate profile and use it to process your game content.

How it works

JSILc looks for a project containing the targets from XNA Game Studio 3.1 or 4.0. This means that the Windows Game Project template should be detected.

The XNA profile scans your project for one or more content projects (.contentproj files) and processes the ones that your game project referenced. Each content project processed produces one or more browser-ready output files, along with a manifest (Foo.contentproj.manifest.js) that you can include into a page in order to give the JSIL preloader (JSIL.Browser.js) the information it needs to load that content.

When combined with the appropriate application manifests (Foo.exe.manifest.js, etc) and the right stub libraries (JSIL.XNACore.js followed by JSIL.XNA3.js or JSIL.XNA4.js, as appropriate) your application should work with no additional changes.

##Configuration In addition to the standard configuration options for JSILc, the XNA profiles have additional options that you can set by adding a 'ProfileSettings' key to your configuration file, like so:

{
  "OutputDirectory": "%configpath%",
  "ProfileSettings": {
    ...
  }
}

The ProfileSettings dictionary can contain the following setting keys:

Key Type Default Value Description
ContentOutputDirectory String null If specified, sets the location for converted XNA content. If this is not set, no content will be converted! A good choice is "%configpath%/Content".
JPEGQuality Integer 90 The quality level to use when converting textures to JPEG. 1-100.
MP3Quality String -V 3 The quality parameter(s) to pass to LAME when generating MP3s.
OGGQuality String -q 6 The quality parameter(s) to pass to OggEnc when generating Ogg Vorbis files.
UsePNGQuant Boolean false If true, JSILc will attempt to use PNGQuant to optimize the PNGs it generates from your textures by converting them to 8-bit RGBA. This will dramatically reduce their size at the expense of adding dithering artifacts.
PNGQuantColorCount Integer 256 Configures the number of colors PNGQuant will attempt to produce when compressing images. If you lower this, the images will probably get a bit smaller.
PNGQuantOptions String You can use this to pass extra options to PNGQuant.
FileSettings Dictionary A dictionary containing a list of settings for each individual content file in your project. See the 'File Settings' section below.
ForceCopyXNBImporters Array of Strings Allows you to specify one or more XNB file importers that, if seen in a project, should trigger JSILc to convert the raw output .XNB file to your content directory. See 'Raw XNB Files' below.
ForceCopyXNBProcessors Array of Strings Allows you to specify one or more XNB file processors that, if seen in a project, should trigger JSILc to convert the raw output .XNB file to your content directory. See 'Raw XNB Files' below.

##File Settings

##Raw XNB Files

##Dependencies

  • MP3 conversion requires the console version of LAME to be located where JSILc can find it. Currently, it looks in ..\Upstream\LAME\lame.exe.
  • OGG conversion requires the console version of OggEnc to be located where JSILc can find it. Currently, it looks in ..\Upstream\OggEnc\oggenc2.exe.
  • If your sound files are not stored in .WAV (for example, if you added an .MP3 to your content project), JSILc will attempt to use FFMPEG to decode them before converting them to OGG and MP3. It currently looks in ..\Upstream\FFMPEG\ffmpeg.exe.
  • If PNGQuant is enabled, JSILc looks for it at .\PNGQuant.exe.
Clone this wiki locally