Every 3ds Max Interactive plug-in is defined in a data file with the .stingray_plugin resource type. When you start work on a new plug-in, you have to create one of these files by hand.
This page describes the format of the .stingray_plugin file, and all of the configuration settings you can use.
NOTE: At the moment, engine-only plug-ins do not require a .stingray_plugin file. All that's needed to get an engine-only plug-in to run is to drop its .dll file into the engine's plugin folder. However, in future the .stingray_plugin file will be used for engine plug-ins too, so we recommend always creating one.
The following code block provides a minimal working plug-in definition that you can use as a model to get started developing your own plug-ins. Copy and paste this information into a new text file with the .stingray_plugin extension, and make it visible to the editor's Plugin Manager. See Add and remove plug-ins using the Plugin Manager.
If you're familiar with the package.json format used by node.js, many of these fields will be familiar to you already.
// Required metadata about the plug-in, shown in the Plugin Manager.
//
name = "My Custom Plugin"
version = "1.0.0"
// Optional descriptive metadata about the plug-in.
//
description = "A minimal custom plug-in that triggers some Javascript code."
author = {
    name = "3ds Max Interactive"
    company = "Autodesk inc."
    url = "https://gamedev.autodesk.com/"
}
thumbnail = "my_image.png"
keywords = ["plugin"]
license = {
    type = "MIT"
    url = "https://opensource.org/licenses/MIT"
}
repository = {
    type = "git"
    url = "http://www.github.com/octocat/hello-world.git"
}
// Extensions define the ways the plug-in extends the 3ds Max Interactive system.
// All plug-ins need at least one extension in order to be successfully loaded.
//
extensions = {
    menus = [{
        path = "Edit/Hello world"
        action = {
            type = "js"
            script = """
                console.warn('Hello!')
            """
        }
    }]
}
// Dependencies that your plug-in needs in order to work.
//
platforms = ["win64"]
dependencies = {
    "stingray" = ">=1.6"
}
As an alternative, you could copy the .stingray_plugin file from any of the built-in plug-ins, or from any of the sample plug-ins, for your starting point. Just make sure you change all the configuration values -- especially the unique name.
Every plug-in definition must have the following settings.
name
The name to show for your plug-in in the Plugin Manager.
This name must be unique among all loaded plug-ins, so we recommend using something specific that is not likely to conflict with similar plug-ins made by other third-parties.
version
A string that you can use to distinguish different versions of your plug-in that you release. Use the format <major>.<minor>.<build> format, where each value is an integer that you increase as you update your plug-in. For example, a version numbered 1.2.300 should precede versions numbered 1.2.305, 1.3.0, 2.0.0, etc.
See the documentation for the SemVer Semantic Versioning system.
The following parameters are all optional. They are used only for display purposes in the Plugin Manager.
description
A brief summary of what your plug-in does.
author
Identifies you. This may be either a simple string name, or an object with the following keys (all optional):
name
Your name.
company
The name of your organization.
url
A web address for you or your organization.
An e-mail address where users of your plug-in can reach you.
thumbnail
Specifies an image file for the editor's Plugin Manager to display for your plug-in. The path should be relative to the location of your .stingray_plugin file. Optional; the default is to use a file called thumbnail.png if it is present.
keywords
An array of strings that describe what your plug-in does. The editor uses these to filter different kinds of assets that it finds online:
- plugin identifies a plug-in that shows up in the Get More Plugins list of the Plugin Manager.
- project-example identifies a sample project that shows up in the Online Projects tab of the Project Manager.
- project-template identifies an online template project that shows up in the Templates tab of the Project Manager.
- asset-package identifies an asset or a set of assets that shows up in the Online Assets folder of the Asset Browser.
NOTE: These keywords are currently useful only for packages shared by Autodesk through the Gamedev portal. Customers can't yet share packages through this repository, but we still recommend setting the appropriate keywords now. That way your plug-ins will be ready to upload when you do get access.
The following parameters are all optional. They are intended for future use, but we do recommend including them now even if they have no immediate use.
license
The software license that you want to govern your plug-in. This indicates the rights that other users have to install, use, modify, and redistribute your plug-in. The value of this property may be a single string value from the SPDX license list, or it may be an object that contains the following values:
type
A string description of your license type, usually the name of the license.
url
A web address where a user can read and download a full copy of the license.
repository
A place where users can download or clone the code for your plug-in, if available. If your plug-in is open-source, including this field can help direct people to the right place in order to contribute to the development of your plug-in. This value should be an object with the following fields
type
A string that describes the type of code repository your plug-in uses, like svn, git, bitbucket, etc.
url
A web address where a user can download and potentially contribute to your plug-in's source code.
Extensions define what your plug-in adds to the 3ds Max Interactive system. Every plug-in needs at least one extension in order for the editor to load it successfully.
For more information on how these extensions work and what extensions you can use in your plug-in, see Use extensions to define plug-in behaviors.
3ds Max Interactive is a complex system, with a lot of interactions between different components that change from time to time. It's very likely that you'll intend your plug-in to be used only in some cases -- for example, only on certain platforms, or only against a certain version of 3ds Max Interactive, or only when a certain other plug-in is also installed, etc.
You can use the platforms and dependencies properties to identify exactly what other platforms, plug-ins and versions your plug-in needs.
NOTE: The only dependency that is currently enforced by the editor is the dependency on the base Stingray app. The editor does not yet handle platform dependencies or dependencies on other plug-ins. However, we encourage you to start including them now. Not only will this give you less to do later when 3ds Max Interactive starts to enforce the versioning, but it can also be helpful in general to identify exactly what your plug-in really depends on.
platforms
An array of strings that identify the platforms your plug-in is intended to support. Currently, all plug-ins support only win64 -- see also Alpha SDK Limitations.
dependencies
An array of items that lists which other 3ds Max Interactive plug-ins your plug-in depends on, and which versions of those other plug-ins must be installed. The key of each item must match the name key of another plug-in. Like each plug-in's own version property (described above), the value of each key should be a semver tag that denotes the compatible versions of that plug-in.
For example, "stingray" >= "1.5" means that the base Stingray app must be at least version 1.5 in order to successfully load the plug-in.
In future, if your plug-in makes use of a new feature introduced by the script-editor plug-in in version 1.8 of Stingray, you might also add "Script Editor" >= "1.8.0". Note that for plug-in dependencies, the version number will be the version of the plug-in as listed in that plug-in's .stingray_plugin descriptor file, not the version of Stingray that contains the version of the plug-in you want to match.