Hi !
Featured games (90)
games approved by the League of Dukes
Games in Showcase (748)
Games in Android Showcase (226)
games submitted by our members
Games in WIP (834)
games currently in development
News: Read the Java Gaming Resources, or peek at the official Java tutorials
    Home     Help   Search   Login   Register   
Pages: [1]
  ignore  |  Print  
  Creating a transparent image with MIDP 1.0  (Read 2258 times)
0 Members and 1 Guest are viewing this topic.
Offline ancamon1

Innocent Bystander

Java games rock!

« Posted 2003-07-03 04:54:38 »

Does anyone know how to create a transparent image with MIDP 1.0?

I have a problem when creating the sprites for my game. I will try to explain it.

I have a transparent PNG file with all my tiles and sprites. What I want to do is to create subimages of this file in order to have independent images for each sprite or tile.

MIDP 2.0 API has a method to perform this operation, but MIDP 1.0 hasn't it, and I need to use MIDP 1.0.

So I have created this method on my own:

public Image createImage(Image source, int x, int y, int width, int height)

And the code inside the method is as follows:

Image subimage = Image.createImage(width, height);
Graphics g = subimage.getGraphics();
g.drawImage(source, -x, -y, 0);
return subimage;

It works fine if we don't use transparent images... But when I want to create a transparent subimage it doesn't work, because the method "Image.createImage" creates an image with a white background (and this means that the transparencies are transformed to white).

How can I create a transparent image?  Huh

Is it possible?

If not, I think the solution is to use an "empty" transparent PNG file... (and create all tiles and sprites with the same size, the size of the transparent PNG image)

Thanks for your help.
Offline davidaprice

Junior Devvie

« Reply #1 - Posted 2003-07-03 07:15:40 »

You're right, you can't create a mutable (modifiable) transparent Image in MIDP 1.0. (Though if you're just targeting Nokia devices, the proprietary Nokia UI API has this capability).

A solution is to use clipping: draw the whole Image, with a clip window for the region you really want to draw, and the Image offset left and/or up so that the correct region overlaps the clip window. For instance, one of my games has a PNG image per character with all the animation frames for that character in a horizontal row; my Sprite class's 'draw' method then looks like this:
  void draw(Graphics g) {
    g.setClip(x, y, width, height);
                x - width * frameIndex[state][frame], y
                Graphics.TOP | Graphics.LEFT);

You see that the state (i.e. walk-left, walk-right) and frame indices select the correct frame from the image, and the image is drawn offset left by that many times its width, so that the correct frame overlaps the clip region.
Pages: [1]
  ignore  |  Print  

xxMrPHDxx (294 views)
2017-12-31 17:17:51

xxMrPHDxx (89 views)
2017-12-31 17:15:51

xxMrPHDxx (144 views)
2017-12-28 18:11:33

Ecumene (308 views)
2017-09-30 02:57:34

theagentd (490 views)
2017-09-26 18:23:31

cybrmynd (519 views)
2017-08-02 12:28:51

cybrmynd (461 views)
2017-08-02 12:19:43

cybrmynd (443 views)
2017-08-02 12:18:09

Sralse (402 views)
2017-07-25 17:13:48

Archive (1304 views)
2017-04-27 17:45:51
Java Gaming Resources
by philfrei
2017-12-05 19:38:37

Java Gaming Resources
by philfrei
2017-12-05 19:37:39

Java Gaming Resources
by philfrei
2017-12-05 19:36:10

Java Gaming Resources
by philfrei
2017-12-05 19:33:10

List of Learning Resources
by elect
2017-03-13 14:05:44

List of Learning Resources
by elect
2017-03-13 14:04:45

SF/X Libraries
by philfrei
2017-03-02 08:45:19

SF/X Libraries
by philfrei
2017-03-02 08:44:05 is not responsible for the content posted by its members, including references to external websites, and other references that may or may not have a relation with our primarily gaming and game production oriented community. inquiries and complaints can be sent via email to the info‑account of the company managing the website of java‑
Powered by MySQL Powered by PHP Powered by SMF 1.1.18 | SMF © 2013, Simple Machines | Managed by Enhanced Four Valid XHTML 1.0! Valid CSS!