mirror of
https://github.com/scratchfoundation/scratch-vm.git
synced 2025-01-12 07:45:41 -05:00
Merge pull request #1849 from fsih/addCostumeFromLibrary
Add addCostumeFromLibrary
This commit is contained in:
commit
fe375fa672
1 changed files with 19 additions and 3 deletions
|
@ -584,13 +584,14 @@ class VirtualMachine extends EventEmitter {
|
||||||
* @property {number} rotationCenterY - the Y component of the costume's origin.
|
* @property {number} rotationCenterY - the Y component of the costume's origin.
|
||||||
* @property {number} [bitmapResolution] - the resolution scale for a bitmap costume.
|
* @property {number} [bitmapResolution] - the resolution scale for a bitmap costume.
|
||||||
* @param {string} optTargetId - the id of the target to add to, if not the editing target.
|
* @param {string} optTargetId - the id of the target to add to, if not the editing target.
|
||||||
|
* @param {string} optVersion - if this is 2, load costume as sb2, otherwise load costume as sb3.
|
||||||
* @returns {?Promise} - a promise that resolves when the costume has been added
|
* @returns {?Promise} - a promise that resolves when the costume has been added
|
||||||
*/
|
*/
|
||||||
addCostume (md5ext, costumeObject, optTargetId) {
|
addCostume (md5ext, costumeObject, optTargetId, optVersion) {
|
||||||
const target = optTargetId ? this.runtime.getTargetById(optTargetId) :
|
const target = optTargetId ? this.runtime.getTargetById(optTargetId) :
|
||||||
this.editingTarget;
|
this.editingTarget;
|
||||||
if (target) {
|
if (target) {
|
||||||
return loadCostume(md5ext, costumeObject, this.runtime).then(() => {
|
return loadCostume(md5ext, costumeObject, this.runtime, optVersion).then(() => {
|
||||||
target.addCostume(costumeObject);
|
target.addCostume(costumeObject);
|
||||||
target.setCostume(
|
target.setCostume(
|
||||||
target.getCostumes().length - 1
|
target.getCostumes().length - 1
|
||||||
|
@ -598,7 +599,22 @@ class VirtualMachine extends EventEmitter {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
// If the target cannot be found by id, return a rejected promise
|
// If the target cannot be found by id, return a rejected promise
|
||||||
return new Promise.reject();
|
return Promise.reject();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add a costume loaded from the library to the current editing target.
|
||||||
|
* @param {string} md5ext - the MD5 and extension of the costume to be loaded.
|
||||||
|
* @param {!object} costumeObject Object representing the costume.
|
||||||
|
* @property {int} skinId - the ID of the costume's render skin, once installed.
|
||||||
|
* @property {number} rotationCenterX - the X component of the costume's origin.
|
||||||
|
* @property {number} rotationCenterY - the Y component of the costume's origin.
|
||||||
|
* @property {number} [bitmapResolution] - the resolution scale for a bitmap costume.
|
||||||
|
* @returns {?Promise} - a promise that resolves when the costume has been added
|
||||||
|
*/
|
||||||
|
addCostumeFromLibrary (md5ext, costumeObject) {
|
||||||
|
if (!this.editingTarget) return Promise.reject();
|
||||||
|
return this.addCostume(md5ext, costumeObject, this.editingTarget.id, 2 /* optVersion */);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in a new issue