Avara

She/Her
Seen 9 Hours Ago
Posted 18 Hours Ago
1,276 posts
9.1 Years
Inserting Custom Sprites in Pokéemerald
-----------------------------------------------------------------------------------------------------------------------------------------------------
I'm going to assume you already have Pokéemerald set up. If you're unsure of how to do that, check out ProjectRevoTPP's tutorial. The sprite editing process is the same for Pokéruby if you'd prefer to use that but why would you.
A tool named GraphicsGale makes editing images and palettes for GBA ridiculously easy, you can get yourself a copy here.
You'll also want Notepad++ for editing files (optional).
-----------------------------------------------------------------------------------------------------------------------------------------------------
Indexing Sprites

I've already covered how to index sprites in another thread already, but it seems like people were skimming past the sentence where I linked it here, so I'll just repost in the spoiler below.

Spoiler:
The first thing you'll want to do is open your sprite in GraphicsGale, highlight "All Frames", then hit "Color Depth".



We want to set this to 4bpp as seen above.
When you've done that, you'll notice that your palette has been trimmed down to 16 colours.
Select your entire image at this stage, and hit Ctrl+C to copy. Don't forget to do this!
Even though your image now has a total of 16 colours - technically, your image can only use 15 of those.
Why? The first colour in the palette index will serve as our transparent colour, as per the GBA requirements.



Notice that in the above image our first colour is black; not the green that we want to be our background colour.
How do we fix this? Simply click on the colour, in our case black, drag & drop the values around with our green. We'll end up with this:



Paste/Ctrl+V over it, and boof, it now looks normal again! Sorted.
Export, insert into your ROM, and test.



Replacing Sprites

This method can be used to replace a wide variety of sprites with your own - such as the bags, item icons, etc. Any 16 colour sprite. The method is the same for Pokémon, the only difference there is that you need an extra palette for the shiny version, so I didn't think Pokémon sprites needed their own guide. Although if there are any requests for that, I'll make an addition to this tutorial. For example purposes we'll refer to trainer sprites.

To get started, grab an indexed sprite you want to insert (should be in .png format) and rename the file to give it the same name as the sprite you'd like to replace. For tutorial purposes, I'm using my own hiker trainer sprite to update the standard one, so I'll name it “hiker_front_pic”. The trainer sprites are located in “pokeemerald\graphics\trainers\front_pics”. Open your sprite in GraphicsGale.


Click the little arrow outlined in red above and hit “Save Palette”. Navigate to “pokeemerald\graphics\trainers\palettes”. Save your new palette over the top of the one you want to replace. For me, that's “hiker.pal”. Now go back to the “front_pics” folder. Delete the original sprite (“hiker_front_pic.png” for tutorial reference) and replace it with your own. Compile, test and... yeah, you're done!
If that didn't work for you for whatever reason, click the spoiler and try this way... longer winded but foolproof.
Spoiler:
After you've replaced the .pal file, open the sprite you want to replace - “hiker_front_pic.png” for me. Click that little arrow again and hit "Load Palette". Load your new palette.


You'll get a screen that looks like the above, comparing your new palette with the current one. Click "All" and the default image will now include the new colours. All that's left to do now is Ctrl+A to "Select All" on your new sprite, then "Ctrl+V" to paste it on top of the default one. Save, compile and test.



-----------------------------------------------------------------------------------------------------------------------------------------------------
Inserting New Trainer Backsprites

The method for trainer backsprites is pretty much the same. There's just an extra little thing to be aware of: player backsprites actually use the same palette as the player front sprites. If you’re happy for your back and front hero/heroine sprites to share a palette, all you have to do is overwrite “brendan.pal” or “may.pal” with your new palette. After you've done that, overwrite the old sprite(e.g. “brendan_back_pic”) with your new one, compile, test and you're done!

But I don’t want my trainer backsprite to share a palette with its front sprite! Fear not, it’s really easy to de-link them and it’ll only take you a few minutes; it’s just a matter of editing three files. Read on or if you're viewing this as a single post click here.

Avara

She/Her
Seen 9 Hours Ago
Posted 18 Hours Ago
1,276 posts
9.1 Years
De-linking Palette Sharing Between Player Back & Front Sprites

OK, so firstly you’ll want to save your new backsprite pals from the indexed image to the “palettes” folder in “graphics\trainers”. For easiness, I’ve named mine “brendan_back” and “may_back” to go with the sprite names. The next thing we have to do is define the new labels we'll use for our separate backsprite palettes. Navigate to “pokeemerald\include”. Open "graphics.h" in Notepad++ and add the following two lines:
extern const u32 gTrainerBackPicPalette_Brendan[];
extern const u32 gTrainerBackPicPalette_May[];


I’ve //commented the lines in the picture for the sake of this guide so you can see where I’ve put them.
Now go to “pokeemerald\src\data\graphics\trainers.h”. Add the following two lines:
const u32 gTrainerBackPicPalette_Brendan[] = INCBIN_U32("graphics/trainers/palettes/brendan_back.gbapal.lz");
const u32 gTrainerBackPicPalette_May[] = INCBIN_U32("graphics\trainers\palettes\may_back.gbapal.lz");


Finally, navigate to “pokeemerald\src\data\trainer_graphics\back_pic_tables.h” and add your new palette references here. For example, change this:
const struct CompressedSpritePalette gTrainerBackPicPaletteTable[] = 
{
    gTrainerPalette_Brendan, 0,
    gTrainerPalette_May, 1, 
To this:
const struct CompressedSpritePalette gTrainerBackPicPaletteTable[] = 
{
    gTrainerBackPicPalette_Brendan, 0,
    gTrainerBackPicPalette_May, 1, 
Like so:



Compile, test, and there you have it! You should now have separate palettes for your player back and front sprites, so you don't have to worry about colours between the two matching.
Male
Seen 6 Days Ago
Posted June 12th, 2020
7 posts
4.7 Years
Hey,

Don't know where else to really ask this, but where in the pokeemerald depository could one edit the palettes of the "walking, surfing..." from the overworld sprite of character?
Pokemon an trainer battle sprites I get , but I don't know where the palettes of those sprites are stored and how to adjust them?

Thanks in advance, and happy belated Bunny day!
Seen 2 Weeks Ago
Posted 2 Weeks Ago
1,334 posts
6.8 Years
So the various palettes are in
graphics/object_events/palettes
, and the particular palettes used by each animation are listed in
src/data/object_events/object_event_graphics_info.h
.

For example:
const struct ObjectEventGraphicsInfo gObjectEventGraphicsInfo_BrendanNormal = {0xFFFF, OBJ_EVENT_PAL_TAG_8, OBJ_EVENT_PAL_TAG_10, 512, 16, 32, 0, SHADOW_SIZE_M, FALSE, FALSE, TRACKS_FOOT, &gObjectEventBaseOam_16x32, gObjectEventSpriteOamTables_16x32, gObjectEventImageAnimTable_BrendanMayNormal, gObjectEventPicTable_BrendanNormal, gDummySpriteAffineAnimTable};

const struct ObjectEventGraphicsInfo gObjectEventGraphicsInfo_MayNormal = {0xFFFF, OBJ_EVENT_PAL_TAG_17, OBJ_EVENT_PAL_TAG_10, 512, 16, 32, 0, SHADOW_SIZE_M, FALSE, FALSE, TRACKS_FOOT, &gObjectEventBaseOam_16x32, gObjectEventSpriteOamTables_16x32, gObjectEventImageAnimTable_BrendanMayNormal, gObjectEventPicTable_MayNormal, gDummySpriteAffineAnimTable};
Brendan's regular walking animation uses palette 8, and (IIRC) his reflection uses palette 10, whereas May uses 17 and 10.
Seen 1 Day Ago
Posted April 22nd, 2020
5 posts
7.8 Years
Hi, I tried to do that but when I replace the sprite the compiler won't take into account the new file. Everytime I need to force it with -B to recompile everything to make it work (which of course takes time). Do you have any idea why ?

Also, when the sprite is imported the background appears in white even though it is transparent in photoshop. I am not very familiar with palettes and sprites so maybe I missed something ?
Note that when imported in a clean ROM using old-fashioned ways (Advanced Sprite Editor) the transparent background works.

Edit: I tried with the Gale software from your guide before asking. Same result
Edit2: Found out about the transparency, it is because the transparency color in the palette is the last oneinstead of the first. No idea how to fix this, I've been looking for hours for a tool to switch palette order without destroying the image but no luck
Edit3: Fixed transparency issue by opening the image in GraphicsGale then All Frame > Color Depth > 16 Colors. This creates an image with the correct palette
Seen 10 Hours Ago
Posted August 5th, 2020
11 posts
1.8 Years
Hi, I tried to do that but when I replace the sprite the compiler won't take into account the new file. Everytime I need to force it with -B to recompile everything to make it work (which of course takes time). Do you have any idea why?
It's likely a dependency issue with make. I've had success with manually deleting the .4bpp/.gbapal files to trigger a rebuild.

Lunos

Random Uruguayan User

Male
Montevideo (Uruguay)
Seen 13 Hours Ago
Posted 1 Day Ago
2,701 posts
12.3 Years
How do you change the actual player icon sprites
What do you mean by "player icon sprites"? The overworld sprites of Brendan and May? They're located in pokeemerald\graphics\object_events\pics\people.
To modify them, you can use your favorite image editing software. Just keep in mind they must have a maximum of 16 colors (with the color in the first slot of its palette being the same one used as the background color).

Hanu P

DRAGON GOD<3

Age 15
Male
India
Seen 2 Days Ago
Posted 2 Weeks Ago
37 posts
2 Years
how?
Me:Yveltal use Oblivion wing
Yveltal💣💥🤬
Opponent:😱😱