Title: Introducing Graphics
 1Introducing Graphics
- There are generally two types of graphics 
 facilities in Java
- Drawing 
- GUIs 
- We concentrate on drawing here 
- To draw, create a Graphics object and pass it 
 drawing messages
- A Graphics object can only be created within 
 certain contexts including GUI components and
 Applets, we will use GUI components
- There is some overhead needed to do this, for now 
 we will find the simplest approach and just use
 it rather than worry about why or how it is done
2The Basic Idea
- Create a JPanel which is one of the GUI 
 components that includes a Graphics context
- Draw on the JPanel as desired 
- Use such messages as drawLine, drawRect, 
 fillRect, setColor, drawString, etc
- Insert the JPanel into a JFrame 
- Show the JFrame 
- Unfortunately, to do this requires at least two 
 separate class definitions and at least 3 methods
- A skeleton is given next, we will use this for 
 our graphics programs, at least for now, where
 all you have to do is fill in the paintComponent
 method with your Graphics messages
3Graphics Skeleton
import java.awt. import javax.swing. public 
class AGraphicsClass  private static final int 
X_SIZE  500, Y_SIZE  500 public static void 
main(String  args)  JFrame jf  new 
JFrame("Graphics Example") jf.setSize(X_SIZE, 
Y_SIZE) GraphicsPanel gp  new 
GraphicsPanel() jf.getContentPane( 
).add(gp) jf.pack( ) jf.show( 
) jf.setDefaultCloseOperation(JFrame.EXIT_ON_CL
OSE)  private static class GraphicsPanel 
extends JPanel  public GraphicsPanel( 
)  setPreferredSize(new Dimension(X_SIZE, 
Y_SIZE)) repaint( )  public void 
paintComponent(Graphics g)  // messages to 
g (the Graphics object) go here   
Alter the size of the Graphics window here
Heres where your Graphics code will go 
 4Message Passing
- Recall that we use message passing when we want 
 to command an object to perform some action
- For a String, we did things like 
 name.toUpperCase( ) and the random number
 generator was generator.nextInt( ), and so forth
- Graphics is a class, and we will use a Graphics 
 object, so we will have to send it messages
- The Graphics object is automatically created for 
 us by the JPanel, so all we have to do is get
 ahold of it (in a method called paintComponent)
 and pass it messages
- Example (assume the Graphics object is called 
 g)
- g.drawLine(5,10,25,30) // draws a line from 
 lt5,10gt to lt25,30gt
- There are numerous Graphics messages, we look at 
 the important ones next
5Graphics Messages
- drawLine(x1, y1, x2, y2) 
- ltx1, y1gt is the source point, ltx2, y2gt is the 
 destination point
- drawRect(x1, y1, x2, y2) and fillRect(x1, y1, x2, 
 y2)
- The two points denote the upper left and lower 
 right points of a rectangle that is either drawn
 (outline) or filled in (solid)
- draw3DRect/fill3DRect(x1, y1, width, height, 
 bool)
- Bool is true or false denoting whether the 
 rectangle is raised (true) or indented (false)
- drawRoundRect/fillRoundRect(x1, y1, width, 
 height, awd, aht)
- The corners of the rectangle are rounded using 
 awd and aht as the height and width of the arc
 for the corners
- drawOval/fillOval(x1, y1, width, height) 
- draws or fills an oval that fills a bounded box 
 starting at point ltx1, y1gt with height and width
 as specified
- drawString(str, x1, y1) 
- prints the String str at point ltx1, y1gt 
- NOTE x1, y1, x2, y2, width, height, awd and aht 
 are all int values
6Additional Graphics Messages
- setColor(col) 
- changes the current drawing color, col must be of 
 type Color and is usually denoted as Color.name
 such as Color.blue or Color.red (see page x for
 list of Color names)
- setFont(ft) 
- changes the font for drawString commands to a 
 different font, ft must be of type Font (see page
 y)
- drawPolygon/fillPolygon(x , y , num) 
- draws/fills a polygon of ltx, ygt points where each 
 point is stored as one element in each of arrays
 x and y, and where there are num points
- drawArc/fillArc(x, y, width, height, sAngle, 
 aAngle)
- like draw/fillOval but only draws a portion based 
 on the two angles provided
- drawImage(src, x, y, width, height, col, obsv) 
- used to display an image src (gif, jpg)  col is 
 the background color for any transparent pixels,
 and obsv is an ImageObserver, use this
7Some Graphics Examples
public void paintComponent(Graphics 
g)  g.setColor(Color.blue) g.drawRoundRect(10,
 10, 200, 200, 25, 25) g.setColor(Color.green) 
 g.drawRoundRect(40, 40, 140, 140, 15, 
15) g.setColor(Color.red) g.drawRoundRect(70, 
70, 80, 80, 10, 10) g.setColor(Color.yellow) g
.fillRoundRect(100, 100, 20, 20, 5, 5) 
public void paintComponent(Graphics 
g)  g.setColor(new Color(128, 64, 
128)) g.draw3DRect(10, 10, 100, 100, 
false) g.draw3DRect(20, 20, 80, 80, 
true) g.setColor(new Color(255, 0, 
64)) g.fill3DRect(30, 30, 60, 60, 
true) g.setColor(Color.white) g.fill3DRect(40,
 40, 40, 40, false)  
 8More Examples
public void paintComponent(Graphics 
g)  g.setFont(new Font("Ariel", Font.BOLD, 
20)) g.drawString("Hello", 10, 
20) g.setFont(new Font("Chicago", Font.ITALIC, 
28)) g.drawString("Goodbye", 10, 40) 
public void paintComponent(Graphics 
g)  g.setColor(Color.red) int  x  15, 30, 
60, 25, 35, 45, 10, 30, 45, 20, 10, 25 int  
y  10, 25, 40, 55, 30, 15, 30, 45, 60, 45, 30, 
10 g.fillPolygon(x, y, 12)  
 9And More Examples
public void paintComponent(Graphics 
g)  ImageIcon icon  new ImageIcon("flag.gif") 
 Image image  icon.getImage( ) g.drawImage(imag
e, 10, 10, 300, 200, Color.white, this) 
public void paintComponent(Graphics 
g)  g.setColor(Color.blue) g.fillArc(10, 10, 
100, 100, 0, 45) g.setColor(Color.red) g.fillA
rc(10, 10, 100, 100, 45, 45) g.setColor(Color.gr
een) g.fillArc(10, 10, 100, 100, 90, 
45) g.setColor(Color.yellow) g.fillArc(10, 
10, 100, 100, 135, 45)  
 10Some Comments
- The paintComponent method is automatically called 
 whenever
- your code calls repaint( ) 
- the JFrame first appears on the screen 
- so you dont need to call repaint( ), but its a 
 good habit to get into
- the JFrame is resized or altered on the screen 
- You cannot automatically generate a Graphics 
 object, so you must rely on the JPanel doing it
 for you
- this is inconvenient and causes you to include 
 all the JFrame and JPanel code that we dont
 normally want
- or we would have to generate the drawing in an 
 Applet, which is just as much work
- It is helpful to work out the size of your 
 drawing components before starting
- you need to know the size for the JFrame, JPanel 
 and the values used in your messages
- Sizes, dimensions, end points, etc are all in 
 terms of pixels, starting at lt0,0gt in the upper
 left hand corner of the JPanel