Jump to content

Sprite Editor 1.0.0

   (3 reviews)

1 Screenshot

About This File

Commander X16 Sprite Editor

This is a screen snapshot and the executable file of a Commander X16 Sprite Editor which is built from "C" source files I’ve been developing that currently runs on Release 37 of the emulator.



The sprite editor supports all combinations of sprite height and width dimensions up to 64x64. The sprite editor is currently limited to 4 color bits per pixel, but provides the ability to edit the RGB values of the first 16 entries of the color palette. The sprite editor supports a pen mode which reduces the keystrokes required to assign colors to sprite pixels, and the ability to shift the design of the sprite to make more room near the edge of the sprite.

The sprite editor provides the ability to export color palette data as well as sprite data to the terminal in a BASIC program format and also in a format more amenable to importing into a C program. The BASIC program allows the sprite to be rendered and moved around a bit using the W/A/S/D keys. This export capability requires the -echo option when starting the emulator.




Cursor Movement

The arrow keys are used to move the cursor around the sprite pixel edit grid. When width=64 the edit grid can be paged left and right using the less-than and greater-than keys ("<" and ">"), and when height=64 the edit grid can be paged up and down using the comma and period keys ("," and ".").


Assigning Colors to Sprite Pixels

The 0-9/A-F keys are used to assign a color to the sprite bit corresponding to the current edit grid cursor position.

When pen mode is turned on using the P key, the color at the current edit grid cursor position is assigned to the pen, and this color is automatically assigned to pixels as the edit cursor is moved. The pen color can be changed by selecting a new color via the 0-9/A-F keys. Pen mode is manually turned off by pressing the P key a second time, and is automatically turned off when the cursor is moved past the edge of the edit grid and when the edit grid is paged when height=64 or width=64.

The fill command (F5 key) fills the entire sprite with the color at the current edit grid cursor position.


RGB Edit Mode

RGB edit mode provides the ability to edit the RGB values of the first 16 entries of the color palette. RGB edit mode is entered and exited by pressing the F6 key. In RGB edit mode, a right arrow appears to the left of the selected color, and selected color is changed by using the up/down cursor keys. The red, green, and blue components of the selected color are changed by using the R/shift-R, G/shift-G, and B/shift-B keys.


Sprite Design Shifting

The sprite design can be shifted up or down one pixel row using the U and shift-U keys, and can be shifted right or left one pixel column using the R and shift-R keys. This feature is useful when a sprite design is not centered correctly when started and one runs out of space near an edge. The sprite design can be shifted to make more room near the edge which avoids having to start the sprite design over again at a new location.


Sprite Options

V-flip and H-flip (V and H keys) affect the display of the actual sprite but not the sprite edit grid. The palette offset (+/- keys) also only affects the display of the actual sprite (the edit grid colors and remainder of the screen colors are not affected).


Screen Options

The BG and FG options (F3 and F4 keys) provide the ability to change the screen background color and the color of the text on the screen.

There's an anomaly associated with color 0 which is black in the standard color palette. Color 0 is shown as black on the screen and edit grid but is transparent when used in sprites, so the edit grid doesn't match the sprite with respect to color 0.


Exported BASIC Program

The exported BASIC program between line 10 and the DATA statements is constant. Line 10 varies with the height and width of the sprite and the DATA statements vary with the color palette data and design of the sprite.

The SA7 value is based on the enumerated values of the height and width dimensions (0 for 8, 1 for 16, 2 for 32, and 3 for 64) and places these values into the proper position to be populated in the most significant nibble of the last sprite attribute register which has an offset of 7. The least significant nibble of this register is the palette offset which I assumed to be 0. The SA7 value is computed in the C program, but it could have been computed in the BASIC program since the enumerated values can be determined from the height and width which are exported on line 10 and palette offset is assumed to be 0.

I deferred support for saving/loading palette and sprite data because I'm under the impression the emulator currently doesn't support file I/O, but the BASIC program provides a near-term workaround. The palette and sprite data exported in the BASIC program format can be reloaded into the sprite editor via the following steps: (1) start the emulator using the -echo option; (2) paste the BASIC program into the emulator; (3) execute the RUN command; (4) push the Esc key to quit the running program; (5) execute the NEW command; (6) load the sprite editor; and (7) execute the RUN command. The sprite editor will then pick up the palette data that was loaded into the color palette and sprite data that was loaded into the VERA sprite attribute registers and VRAM by the BASIC program.

The following two steps are an alternative to step (2) above: (2a) paste the BASIC program into a text file; and (2b) use the emulator -bas option to load the program from the text file when starting the emulator. This alternative approach is recommended if you're having problems with the emulator corrupting lines when pasting the BASIC program directly into the emulator.

The palette and sprite data are automatically exported when exiting the sprite editor to avoid accidental loss of data. The exported data can be recovered before reloading and restarting the sprite editor as described above.


Potential Future Enhancements

I'm considering enhancements including support for 8 color bits per pixel, saving/loading of palette and sprite data, rotation of sprites, and undo/redo of changes to the sprite graphics data in VRAM.

What's New in Version 1.0.0   See changelog


Added .PRG extension to the file name in attempt to support web emulator "Try it now" feature.




  • Like 7

User Feedback

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.


Chris L

· Edited by Chris L

   2 of 2 members found this review helpful 2 / 2 members

Great program but cannot see how to save the sprite data.  I selected list sprite data but it just shows data lines scrolling below the editor.  When I exit, there is no data showing or can be LISTed.  LIST just shows the SYS 2061.

UPDATE:  I pressed the X in the top right corner and was taken back to the emulator main screen and I can see the data there!

Response from the author:

The sprite data listing should show up in the terminal window that you used to launch the emulator. You shouldn't need to close the emulator to view the sprite data listing, you just need to switch context from the emulator to the terminal window.

Link to review

   1 of 1 member found this review helpful 1 / 1 member

This is a really good Sprite Editor for experimenting and i have also created a Ryu Sprite.


Response from the author:

I'm glad you find the sprite editor useful. Excellent Ryu sprite!

Link to review

· Edited by rje


First, thank you for writing this.  It's going to help me.

I think what would benefit this application is to compress your instructions onto a one-page reminder screen, perhaps with bullet points instead of text.

Also, I believe LOAD and SAVE work now, so being able to save as a binary file would be ... well, excellent.

Thank you!


Link to review
  • Create New...

Important Information

Please review our Terms of Use