Through this article, we will learn to create a Cocos Creator extension and execute a custom script through the extension.
Click Extension -> Create Extension in the menu bar of the editor, and select Global/Project to create a extension package.
-
If selecting Global, the extension will be applied to all Cocos Creator projects. The path of Global is:
-
Windows:
%USERPROFILE%\.CocosCreator\extensions
-
MacOS:
$HOME/.CocosCreator/extensions
-
-
If selecting Project, this will apply the extension to the specified Cocos Creator project. The path of Project is:
$Your project address/extensions
When creating an extension, there will be a prompt whether to enable the extension directly or not, choose as needed (in the example, choose Enable):
Then click Extension -> Extension Manager-> Project/Global in the top menu bar to see the extension just created, with the default name simple-timestamp
:
- : Open the extension package in the operating system's file manager.
- : Refresh the extension.
- : Delete the extension.
- : Enable/Disable the extension.
Click the button to open the extension package, which has the following directory structure:
Every extension needs a package.json
file to describe the purpose of the extension. Only after the description file package.json
is fully defined, can Cocos Creator know the specific functions defined in this extension, loading entry and other information.
Although the definition of many fields in package.json
is similar to that of node.js
's npm package, they are obviously customized for different products and services. The npm module downloaded from the npm community cannot be directly put into Cocos Creator to become an extension, but one can use the modules in the npm community in the Cocos Creator extension.
To continue creating an extension, open the package.json
file and see the following:
{
"name": "simple-1634093231454",
"package_version": 2,
"version": "1.0.0",
"description": "A Simple Extension",
"author": "Unknown",
"main": "browser.js"
}
Replace it with the following:
{
"name": "hello-world",
"package_version": 2,
"version": "1.0.0",
"description": "A Simple Extension",
"author": "Unknown",
"main": "browser.js",
"contributions": {
"menu": [{
"path": "Develop",
"label": "test",
"message": "log"
}],
"messages": {
"log": {
"methods": ["log"]
}
}
}
}
The meanings of the fields are as follows:
-
name
String -- Defines the package name, which is globally unique and relates to the login name on the official website server in the future.Note: if the plugin will be uploaded to the Cocos Store, there are certain restrictions on the package name. The
name
only allows lowercase letters, numbers, hyphens (-
), underscores (_
), dots (.
), and begin with a lowercase letter or number. -
version
String -- The version number. We recommend using the semver standard to manage the package versions. -
main
String (optional) -- The entry file -
description
String (optional) -- Describe the package in one sentence. -
contributions
Object (optional) -- Configuration objects that extend the existing functionality of the editor.menu
array -- Define amenu
array incontributions
to provide basic information of a menu to the menu component. Finally, bind this menu to a message. For more details, please refer to the Menu documentation.messages
: Object -- It is necessary to define amessages
object incontributions
, which is the method of editor message registration. This message can be bound to one or more methods defined in the extension. For more definition data, please refer to the Message documentation.
For a detailed package.json
format definition, please refer to the Extension documentation.
After defining the description file, the next step is to write the entry program browser.js
.
Open the browser.js
file and write the following:
'use strict';
// The method defined in the extension
exports.methods = {
log() {
console.log('Hello World');
},
};
// Execute when the extension is enabled
exports.load = function() {};
// Execute when the extension is disabled
exports.unload = function() {};
The methods defined in exports.methods
will be used as the operation interface, which can be called across extensions through messages or communicate with the panel.
This entry program is the main process of the extension and will be loaded during Cocos Creator startup. Because Creator will launch each extension when it starts, the main process of the extension will be loaded when the extension is launched.
Go back to the editor and click the Extension -> Extension Manager-> Project/Global in the top menu bar to find the extension created before. Click the button on the right side of the extension to make the above changes take effect, and we can see that the name of the extension has been changed to hello-world.
If the extension is enabled, a Develop menu will appear in the top menu bar of Creator with a test menu option. Clicking test will trigger a message sending according to the definition, and execute the corresponding method in the extension according to the message definition, and then print the log message "Hello World" in the Console.