mirror of
https://github.com/ninjamuffin99/Funkin.git
synced 2025-01-25 14:07:42 +00:00
80 lines
1.9 KiB
Haxe
80 lines
1.9 KiB
Haxe
package funkin.play.character;
|
|
|
|
import flixel.graphics.frames.FlxFramesCollection;
|
|
import funkin.modding.events.ScriptEvent;
|
|
import funkin.play.character.CharacterData.CharacterRenderType;
|
|
import funkin.util.assets.FlxAnimationUtil;
|
|
|
|
/**
|
|
* A PackerCharacter is a Character which is rendered by
|
|
* displaying an animation derived from a Packer spritesheet file.
|
|
*/
|
|
class PackerCharacter extends BaseCharacter
|
|
{
|
|
public function new(id:String)
|
|
{
|
|
super(id, CharacterRenderType.Packer);
|
|
}
|
|
|
|
override function onCreate(event:ScriptEvent):Void
|
|
{
|
|
trace('Creating Packer character: ' + this.characterId);
|
|
|
|
loadSpritesheet();
|
|
loadAnimations();
|
|
|
|
super.onCreate(event);
|
|
}
|
|
|
|
function loadSpritesheet():Void
|
|
{
|
|
trace('[PACKERCHAR] Loading spritesheet ${_data.assetPath} for ${characterId}');
|
|
|
|
var tex:FlxFramesCollection = Paths.getPackerAtlas(_data.assetPath);
|
|
if (tex == null)
|
|
{
|
|
trace('Could not load Packer sprite: ${_data.assetPath}');
|
|
return;
|
|
}
|
|
|
|
this.frames = tex;
|
|
|
|
if (_data.isPixel)
|
|
{
|
|
this.isPixel = true;
|
|
this.antialiasing = false;
|
|
pixelPerfectRender = true;
|
|
pixelPerfectPosition = true;
|
|
}
|
|
else
|
|
{
|
|
this.isPixel = false;
|
|
this.antialiasing = true;
|
|
}
|
|
|
|
this.setScale(_data.scale);
|
|
}
|
|
|
|
function loadAnimations():Void
|
|
{
|
|
trace('[PACKERCHAR] Loading ${_data.animations.length} animations for ${characterId}');
|
|
|
|
FlxAnimationUtil.addAtlasAnimations(this, _data.animations);
|
|
|
|
for (anim in _data.animations)
|
|
{
|
|
if (anim.offsets == null)
|
|
{
|
|
setAnimationOffsets(anim.name, 0, 0);
|
|
}
|
|
else
|
|
{
|
|
setAnimationOffsets(anim.name, anim.offsets[0], anim.offsets[1]);
|
|
}
|
|
}
|
|
|
|
var animNames = this.animation.getNameList();
|
|
trace('[PACKERCHAR] Successfully loaded ${animNames.length} animations for ${characterId}');
|
|
}
|
|
}
|