Color Difference : Color « 2D Graphics GUI « Java






Color Difference

        
 


import java.awt.Color;
import java.awt.Dimension;
import java.awt.Graphics;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

import javax.swing.JComponent;
import javax.swing.JFrame;
import javax.swing.SwingUtilities;
import javax.swing.Timer;

/*
 * ColorDifference.java
 *
 * Created on May 3, 2007, 7:12 AM
 *
 * Copyright (c) 2007, Sun Microsystems, Inc
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 *   * Redistributions of source code must retain the above copyright
 *     notice, this list of conditions and the following disclaimer.
 *   * Redistributions in binary form must reproduce the above
 *     copyright notice, this list of conditions and the following
 *     disclaimer in the documentation and/or other materials provided
 *     with the distribution.
 *   * Neither the name of the TimingFramework project nor the names of its
 *     contributors may be used to endorse or promote products derived
 *     from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

/**
 * 
 * @author Chet
 */
public class ColorDifference extends JComponent implements ActionListener {

  private Color largeRectColors[] = { Color.BLACK, new Color(3, 3, 3) };

  private Color smallRectColors[] = { Color.BLACK, Color.WHITE };

  private int colorIndex = 0;

  private static int FADE_X = 0;

  private static int BLANK_X = 0;

  /** Creates a new instance of ColorDifference */
  public ColorDifference() {
    Timer timer = new Timer(1000, this);
    timer.start();
    setPreferredSize(new Dimension(300, 200));
  }

  /**
   * Displays our component with the animating colors of the areas on the left
   * and right, separated by an area of white in the middle
   */
  @Override
  protected void paintComponent(Graphics g) {
    int fadeX = 0;
    int blankX = getWidth() / 3;
    int bigRectW = getWidth() / 3;

    // Fill left-side rectangle with current animating color
    g.setColor(largeRectColors[colorIndex]);
    g.fillRect(0, 0, bigRectW, getHeight());

    // Fill middle area with white
    g.setColor(Color.WHITE);
    g.fillRect(bigRectW, 0, bigRectW, getHeight());

    // Fill right-side rectangle with black, with a white square
    // in the middle
    int bigRectX = 2 * bigRectW;
    int smallRectW = 4;
    int smallRectH = 4;
    int smallRectX = bigRectX + (bigRectW / 2) - (smallRectW / 2);
    int smallRectY = (getHeight() / 2) - (smallRectH / 2);
    g.setColor(Color.BLACK);
    g.fillRect(2 * getWidth() / 3, 0, getWidth() / 3, getHeight());
    g.setColor(smallRectColors[colorIndex]);
    g.fillRect(smallRectX, smallRectY, smallRectW, smallRectH);
  }

  /**
   * Handles Timer events by toggling the colorIndex used to fill the left-side
   * rectangle
   */
  public void actionPerformed(ActionEvent ae) {
    colorIndex++;
    colorIndex = colorIndex % 2;
    repaint();
  }

  private static void createAndShowGUI() {
    JFrame f = new JFrame("Color Difference");
    f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    f.setSize(300, 200);
    ColorDifference component = new ColorDifference();
    f.add(component);
    f.pack();
    f.setVisible(true);
  }

  /**
   * @param args
   *          the command line arguments
   */
  public static void main(String[] args) {
    Runnable doCreateAndShowGUI = new Runnable() {
      public void run() {
        createAndShowGUI();
      }
    };
    SwingUtilities.invokeLater(doCreateAndShowGUI);
  }
}

 

   
    
    
    
    
    
    
    
  








Related examples in the same category

1.Color class is used to work with colors in Java 2D
2.Color Utilities: common color operations
3.Rainbow ColorRainbow Color
4.XOR colorXOR color
5.Color Gradient
6.Common color utilities
7.Drawing with Color
8.Color fading animation
9.140 colors - defined for X Window System listed in O'Reilly html pocket reference 87pp
10.Color Util
11.Color Factory
12.An efficient color quantization algorithm
13.Utility for checking colors given either hexa or natural language string descriptions.
14.Derives a color by adding the specified offsets to the base color's hue, saturation, and brightness values
15.Map colors into names and vice versa.
16.Converts a given string into a color.
17.If the color is equal to one of the defined constant colors, that name is returned instead.
18.Converts the String representation of a color to an actual Color object.
19.Returns blue-yellow-red color scale
20.Returns green-yellow-red-black color scale
21.Returns black-red-yellow-green color scale
22.Returns color based on 0-9 scale ranging from green to yellow
23.Returns color based on 0-9 scale ranging from yellow to red
24.Returns color based on 0-9 scale ranging from black to green
25.Returns n-dimensional array of colors for given nx3 integer array of RGB values
26.Web color enum
27.Utility class for managing resources such as colors, fonts, images, etc.
28.Make a color transparent
29.Return a Color object given a string representation of it
30.Return a string representation of a color
31.Serializes a color to its HTML markup (e.g. "#ff0000" for red)
32.Parses a java.awt.Color from an HTML color string in the form '#RRGGBB' where RR, GG, and BB are the red, green, and blue bytes in hexadecimal form
33.Performs a somewhat subjective analysis of a color to determine how dark it looks to a user
34.Lightens a color by a given amount
35.Darkens a color by a given amount
36.Blend two colors
37.Utility for working with natively-ordered integer-packed RGBA-format colours.
38.HSV to RGB
39.A widget to manipulate an RGBA colour.