mirror of
https://github.com/scratchfoundation/scratch-vm.git
synced 2025-01-11 23:30:09 -05:00
Duplicate costume
This commit is contained in:
parent
8e1719b716
commit
75cf6407d4
2 changed files with 51 additions and 1 deletions
|
@ -408,6 +408,17 @@ class RenderedTarget extends Target {
|
||||||
this.sprite.costumes.push(costumeObject);
|
this.sprite.costumes.push(costumeObject);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add a costume at the given index, taking care to avoid duplicate names.
|
||||||
|
* @param {!object} costumeObject Object representing the costume.
|
||||||
|
* @param {!int} index Index at which to add costume
|
||||||
|
*/
|
||||||
|
addCostumeAt (costumeObject, index) {
|
||||||
|
const usedNames = this.sprite.costumes.map(costume => costume.name);
|
||||||
|
costumeObject.name = StringUtil.unusedName(costumeObject.name, usedNames);
|
||||||
|
this.sprite.costumes.splice(index, 0, costumeObject);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Rename a costume, taking care to avoid duplicate names.
|
* Rename a costume, taking care to avoid duplicate names.
|
||||||
* @param {int} costumeIndex - the index of the costume to be renamed.
|
* @param {int} costumeIndex - the index of the costume to be renamed.
|
||||||
|
@ -458,6 +469,17 @@ class RenderedTarget extends Target {
|
||||||
this.runtime.requestTargetsUpdate(this);
|
this.runtime.requestTargetsUpdate(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add a sound, taking care to avoid duplicate names.
|
||||||
|
* @param {!object} soundObject Object representing the sound.
|
||||||
|
* @param {!int} index Index at which to add costume
|
||||||
|
*/
|
||||||
|
addSoundAt (soundObject, index) {
|
||||||
|
const usedNames = this.sprite.sounds.map(sound => sound.name);
|
||||||
|
soundObject.name = StringUtil.unusedName(soundObject.name, usedNames);
|
||||||
|
this.sprite.sounds.splice(index, 0, soundObject);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add a sound, taking care to avoid duplicate names.
|
* Add a sound, taking care to avoid duplicate names.
|
||||||
* @param {!object} soundObject Object representing the sound.
|
* @param {!object} soundObject Object representing the sound.
|
||||||
|
|
|
@ -322,11 +322,39 @@ class VirtualMachine extends EventEmitter {
|
||||||
return loadCostume(md5ext, costumeObject, this.runtime).then(() => {
|
return loadCostume(md5ext, costumeObject, this.runtime).then(() => {
|
||||||
this.editingTarget.addCostume(costumeObject);
|
this.editingTarget.addCostume(costumeObject);
|
||||||
this.editingTarget.setCostume(
|
this.editingTarget.setCostume(
|
||||||
this.editingTarget.sprite.costumes.length - 1
|
this.editingTarget.getCostumes().length - 1
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Duplicate the costume at the given index. Add it at that index + 1.
|
||||||
|
* @param {!int} costumeIndex Index of costume to duplicate
|
||||||
|
*/
|
||||||
|
duplicateCostume (costumeIndex) {
|
||||||
|
const originalCostume = this.editingTarget.getCostumes()[costumeIndex];
|
||||||
|
const clone = Object.assign({}, originalCostume);
|
||||||
|
const md5ext = `${clone.assetId}.${clone.dataFormat}`;
|
||||||
|
loadCostume(md5ext, clone, this.runtime).then(() => {
|
||||||
|
this.editingTarget.addCostumeAt(clone, costumeIndex + 1);
|
||||||
|
this.editingTarget.setCostume(costumeIndex + 1);
|
||||||
|
this.emitTargetsUpdate();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Duplicate the sound at the given index. Add it at that index + 1.
|
||||||
|
* @param {!int} soundIndex Index of sound to duplicate
|
||||||
|
*/
|
||||||
|
duplicateSound (soundIndex) {
|
||||||
|
const originalSound = this.editingTarget.getSounds()[soundIndex];
|
||||||
|
const clone = Object.assign({}, originalSound);
|
||||||
|
loadSound(clone, this.runtime).then(() => {
|
||||||
|
this.editingTarget.addSoundAt(clone, soundIndex + 1);
|
||||||
|
this.emitTargetsUpdate();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Rename a costume on the current editing target.
|
* Rename a costume on the current editing target.
|
||||||
* @param {int} costumeIndex - the index of the costume to be renamed.
|
* @param {int} costumeIndex - the index of the costume to be renamed.
|
||||||
|
|
Loading…
Reference in a new issue