-
Notifications
You must be signed in to change notification settings - Fork 83
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Decompile pl_batt_obj NARC, document related battle_icon.c #269
base: main
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Some preliminary comments on the assets before I dig into code. Overall, I'd like to re-evaluate the structure and have a good strategy for both how we build these files back into a single NARC and also how we present them to users.
res/battle/graphic/pl_batt_obj/prebuilt/pl_batt_obj_00000078.NANR
Outdated
Show resolved
Hide resolved
res/battle/graphic/pl_batt_obj/sprites/pl_batt_obj_00000127.png
Outdated
Show resolved
Hide resolved
res/battle/graphic/pl_batt_obj/sprites/pl_batt_obj_00000133.png
Outdated
Show resolved
Hide resolved
res/battle/graphic/pl_batt_obj/sprites/pl_batt_obj_00000175.png
Outdated
Show resolved
Hide resolved
res/battle/graphic/pl_batt_obj/sprites/pl_batt_obj_00000205.png
Outdated
Show resolved
Hide resolved
res/battle/graphic/pl_batt_obj/sprites/pl_batt_obj_00000208.png
Outdated
Show resolved
Hide resolved
res/battle/graphic/pl_batt_obj/sprites/pl_batt_obj_00000250.png
Outdated
Show resolved
Hide resolved
res/battle/graphic/pl_batt_obj/sprites/pl_batt_obj_00000253.png
Outdated
Show resolved
Hide resolved
res/battle/graphic/pl_batt_obj/sprites/battle_terrain_cave_opponent.png
Outdated
Show resolved
Hide resolved
src/battle/ov16_02268520.c
Outdated
__attribute__((aligned(4))) static const u16 ov16_BattlePlatformIndexToNARCMember[] = { | ||
* Maps a battle terrain index to the NARC member in pl_batt_obj containing a sprite for it. | ||
*/ | ||
__attribute__((aligned(4))) static const u16 ov16_BattleTerrainIndexToNARCMember[] = { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
polish: Same suggestion about types/classes applies here; there is a set of terrain constants defined in consts/terrain.json
, which gets compiled to build/consts/terrain.h
.
...and looking at the names there, it will likely be better for us to align the names there with the names from these terrain blobs.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Some suggestions for cleaning up names
src/overlay012/ov12_02235E94.c
Outdated
@@ -134,26 +135,26 @@ static BOOL ov12_02237474(BallRotation *param0); | |||
* These NARC members describe the sprite, palette, cell, and anim to use for that ball. | |||
*/ | |||
static const int ov12_BallIndexToNARCMembers[][4] = { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
static const int ov12_BallIndexToNARCMembers[][4] = { | |
static const int sThrownBallSpriteResources[][4] = { |
Also check if it's possible to turn this into an array of structs like these (this name is likely not unique):
struct SpriteResource {
int tiles;
int palette;
int cells;
int animation;
};
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I might need some advice on this one, the array gets used later as sThrownBallSpriteResources[v0][param1]
, so if I convert it to an array of struct the [param1]
would be trying to index that struct as if it's an array
I can do something like the below and then have the array access use the array part of the union but idk if this is good style. Or is there a better alternative to make this work?
typedef union AnimatedSpriteResource {
struct AnimatedSpriteResource_s {
int tiles;
int palette;
int cells;
int animation;
};
int AnimatedSpriteResource_a[4];
} AnimatedSpriteResource;
Started looking at NCER/NANR, will require a couple nitrogfx changes which I will note here |
pl_batt_obj_00000247.ncgr | ||
pl_batt_obj_00000248.ncer | ||
pl_batt_obj_00000249.nanr |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
these 3 files (along with pl_batt_obj_00000079.nclr
) appear to be a duplicate of the poke_ball_throw components; have not found where they are used in the code to validate
pl_batt_obj_00000267.ncer | ||
pl_batt_obj_00000268.ncer | ||
pl_batt_obj_00000269.ncer | ||
pl_batt_obj_00000270.ncer | ||
pl_batt_obj_00000271.ncer | ||
pl_batt_obj_00000272.ncer | ||
pl_batt_obj_00000273.ncer | ||
pl_batt_obj_00000274.ncer | ||
pl_batt_obj_00000275.nanr | ||
pl_batt_obj_00000276.nanr | ||
pl_batt_obj_00000277.nanr | ||
pl_batt_obj_00000278.nanr | ||
pl_batt_obj_00000279.nanr | ||
pl_batt_obj_00000280.nanr | ||
pl_batt_obj_00000281.nanr | ||
pl_batt_obj_00000282.nanr |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
these are almost certainly corresponding with the player_..._back
sprites, but have not found where they are used in the code to confirm
742b0cf
to
0ef8173
Compare
res/battle/graphic/meson.build
Outdated
@@ -0,0 +1 @@ | |||
subdir('pl_batt_obj') |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
suggestion: Can we name the internal folder something more meaningful? Maybe res/battle/graphics/objects
? We generally try to avoid using the actual NARC names outside of where strictly necessary for matching (e.g., on NARC names)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've renamed the directory, I considered renaming some of the other files (pl_batt_obj.ignore
, pl_batt_obj.order
) but these are more directly related to the final NARC name so I've left them as-is
@@ -0,0 +1,228 @@ | |||
healthbox_doubles_opponent_2.NCER |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
suggestion: Maybe we want to discuss with red about adding lz
encoding as a switch on nitrogfx
outputs so that we can avoid having huge ignore
files like these.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yeah, this would probably be helpful. i suspect there will be other large NARCs in the project with lots of compressed files
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'll write up a PR to implement this over the course of the next couple of days.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks generally mergeable to me at this juncture. Resolve the conflict in tools/scripts/meson.build
and it should be good. I'll hold off on approval until we have the new nitrogfx
option to automatically LZ-encode an output file so that we can clean up the ignore
file.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'll hold off on approval until we have the new nitrogfx option to automatically LZ-encode an output file so that we can clean up the ignore file.
I'm going to retract this requirement and approve this PR for merge, pending resolution of the merge conflicts. After scoping out the work for such an option, I don't feel comfortable making it available until we can programmatically determine what directionality to use on the LZ encoding.
Let's file that away as a future enhancement and unblock this PR in the interim.
this needs one more nitrogfx change red031000/nitrogfx#19, some of the NCER in this PR are inconsistent with the spec. |
nitrogfx change still required for some NCERs
@@ -0,0 +1,228 @@ | |||
healthbox_doubles_opponent_2.NCER |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
question: Is it possible to use a .include
file for the NCGR,etc. files that must be included, then replace all of these entries with *.NCGR
, etc.? Presuming that that list would be shorter, of course.
TODO:
this is my first contribution, tried my best to keep it to a similar style as the rest of the code but I probably scuffed it a little :)