/* * JSwiff is an open source Java API for Macromedia Flash file generation * and manipulation * * Copyright (C) 2004-2006 Ralf Terdic (contact@jswiff.com) * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ package com.jswiff.swfrecords; import com.jswiff.io.InputBitStream; import com.jswiff.io.OutputBitStream; import java.io.IOException; /** * Represents a 24-bit RGB color. */ public final class RGB extends Color { /** Black */ public static final RGB BLACK = new RGB(0, 0, 0); /** White */ public static final RGB WHITE = new RGB(255, 255, 255); private short red; private short green; private short blue; /** * Creates a new RGB instance. * * @param red red value (between 0 and 255) * @param green green value (between 0 and 255) * @param blue blue value (between 0 and 255) */ public RGB(short red, short green, short blue) { this.red = red; this.green = green; this.blue = blue; } /** * Creates a new RGB instance. Convenience constructor which can be used to * avoid annoying type casts with literals like<br> * new RGB((short) 0, (short) 0, (short) 0); * * @param red red value (between 0 and 255) * @param green green value (between 0 and 255) * @param blue blue value (between 0 and 255) */ public RGB(int red, int green, int blue) { this.red = (short) red; this.green = (short) green; this.blue = (short) blue; } /** * Reads an instance from a bit stream. * * @param stream source bit stream * * @throws IOException if an I/O error has occured */ public RGB(InputBitStream stream) throws IOException { red = stream.readUI8(); green = stream.readUI8(); blue = stream.readUI8(); } /** * Returns the blue value. * * @return blue value (between 0 and 255) */ public short getBlue() { return blue; } /** * Returns the green value. * * @return green value (between 0 and 255) */ public short getGreen() { return green; } /** * Returns the red value. * * @return red value (between 0 and 255) */ public short getRed() { return red; } /** * Returns the string representation of the instance. * * @return string representation of color */ public String toString() { return "RGB (" + red + "; " + green + "; " + blue + ")"; } /** * Writes the instance to a bit stream. * * @param stream the target bit stream * * @throws IOException if an I/O error has occured */ public void write(OutputBitStream stream) throws IOException { stream.writeUI8(red); stream.writeUI8(green); stream.writeUI8(blue); } }