TOPIC 7 MODIFYING PIXELS IN A MATRIX NESTED FOR LOOPS 1 Notes adapted from Introduction to Computing and Programming with Java: A Multimedia Approach by.

Slides:



Advertisements
Similar presentations
Two-Dimensional Arrays Chapter What is a two-dimensional array? A two-dimensional array has “rows” and “columns,” and can be thought of as a series.
Advertisements

TOPIC 5 INTRODUCTION TO PICTURES 1 1 Notes adapted from Introduction to Computing and Programming with Java: A Multimedia Approach by M. Guzdial and B.
ManipulatingPictures-Mod6-part21 Manipulating Pictures, Arrays, and Loops part 2 Barb Ericson Georgia Institute of Technology.
TOPIC 12 CREATING CLASSES PART 1 1 Notes adapted from Introduction to Computing and Programming with Java: A Multimedia Approach by M. Guzdial and B. Ericson,
Georgia Institute of Technology Manipulating Pictures, Arrays, and Loops part 1.
Introduction to Computers and Programming Lecture 10: For Loops Professor: Evan Korth New York University.
Multimedia Data Introduction to Image Data Dr Mike Spann Electronic, Electrical and Computer Engineering.
Georgia Institute of Technology Two-Dimensional Arrays and Nested Loops – part 6 Barb Ericson Georgia Institute of Technology August 2005.
TOPIC 9 MODIFYING PIXELS IN A MATRIX: COPYING, CROPPING 1 Notes adapted from Introduction to Computing and Programming with Java: A Multimedia Approach.
Chapter 6: Modifying Pixels by Position. Chapter Learning Goals.
NestedLoops-part11 Nested Loops – part 1 Barb Ericson Georgia Institute of Technology Nov 2009.
CS 112 Introduction to Programming Variable Scoping; Nested Loops; Parameterized Methods Yang (Richard) Yang Computer Science Department Yale University.
CSC1401 Viewing a picture as a 2D image - 1. Review from the last week We used a getPixels() to get all of the pixels of a picture But this has been somewhat.
02-RangesInPictures1 Barb Ericson Georgia Institute of Technology Oct 2010 Working with ranges in pictures.
ManipulatingPictures-part11 Manipulating Pictures, Arrays, and Loops part 1 Barb Ericson Georgia Institute of Technology Nov 2009.
Creative Commons Attribution Non-Commercial Share Alike License sa/3.0/
TOPIC 11 RETURNING VALUES FROM METHODS PICTURE TRANSFORMATIONS 1 Notes adapted from Introduction to Computing and Programming with Java: A Multimedia Approach.
Georgia Institute of Technology Manipulating Pictures, Arrays, and Loops Barb Ericson Georgia Institute of Technology August 2005.
TOPIC 6 MODIFYING PICTURES USING LOOPS 1 Notes adapted from Introduction to Computing and Programming with Java: A Multimedia Approach by M. Guzdial and.
CS 112 Introduction to Programming Graphics; Animation Yang (Richard) Yang Computer Science Department Yale University 308A Watson, Phone:
Georgia Institute of Technology Two-Dimensional Arrays and Nested Loops – part 5 Barb Ericson Georgia Institute of Technology August 2005.
NestedLoops-part41 Nested Loops – part 4 Barb Ericson Georgia Institute of Technology Nov 2009.
NestedLoops-Mody7-part51 Two-Dimensional Arrays and Nested Loops – part 5 Rotations Barb Ericson Georgia Institute of Technology May 2007.
TOPIC 5 INTRODUCTION TO PICTURES 1 1 Notes adapted from Introduction to Computing and Programming with Java: A Multimedia Approach by M. Guzdial and B.
CPSC1301 Computer Science 1 Chapter 4 Manipulating Pictures, Arrays, and Loops part 5.
TOPIC 10 THE IF STATEMENT 1 Notes adapted from Introduction to Computing and Programming with Java: A Multimedia Approach by M. Guzdial and B. Ericson,
Nested for loops.
Printing with for Loops To print a character multiple times, use a for loop. for (int j = 1; j
1 Arrays of Arrays An array can represent a collection of any type of object - including other arrays! The world is filled with examples Monthly magazine:
NestedLoops-part21 Nested Loops – part 2 Barb Ericson Georgia Institute of Technology Nov 2009.
Copyright © Curt Hill Further Picture Manipulation Considering position.
ManipulatingPictures-part31 Manipulating Pictures, Arrays, and Loops part 3 Barb Ericson Georgia Institute of Technology Nov 2009.
Copyright 2008 by Pearson Education 1 Nested loops reading: 2.3 self-check: exercises: videos: Ch. 2 #4.
1 BUILDING JAVA PROGRAMS CHAPTER 2 PRIMITIVE DATA AND DEFINITE LOOPS.
04-ManipulatingPictures-part21 Manipulating Pictures, Arrays, and Loops part 2 Barb Ericson Georgia Institute of Technology June 2008.
TOPIC 8 MORE ON WHILE LOOPS 1 Notes adapted from Introduction to Computing and Programming with Java: A Multimedia Approach by M. Guzdial and B. Ericson,
Georgia Institute of Technology Two-Dimensional Arrays and Nested Loops – part 2 Barb Ericson Georgia Institute of Technology August 2005.
Barbara Ericson Georgia Tech Sept 2005
Topic 9 Modifying Pixels in a Matrix: Copying, Cropping
Topic 6 Modifying Pictures Using Loops
Barb Ericson Georgia Institute of Technology Dec 2009
Topic 10 The if statement Notes adapted from Introduction to Computing and Programming with Java: A Multimedia Approach by M. Guzdial and B. Ericson,
Workshop for Programming And Systems Management Teachers
Manipulating Pictures, Arrays, and Loops part 2
Working with ranges in pictures
Two-Dimensional Arrays and Nested Loops – part 1
Barb Ericson Georgia Institute of Technology August 2005
Two-Dimensional Arrays and Nested Loops – part 2
Two-Dimensional Arrays and Nested Loops – part 5
Two-Dimensional Arrays and Nested Loops – part 1
Gray Scale picture def pixBW(pixel): # given a pixel, change to BW
Building Java Programs
Building Java Programs
Two-Dimensional Arrays and Nested Loops – part 6
Two-Dimensional Arrays and Nested Loops – part 2
Manipulating Pictures, Arrays, and Loops
Two-Dimensional Arrays and Nested Loops – part 6
Georgia Institute of Technology
Building Java Programs
CSC1401 Viewing a picture as a 2D image - 2
Two-Dimensional Arrays and Nested Loops – part 6
CS 101: Introduction to Computing
Building Java Programs
Building Java Programs
Building Java Programs
Building Java Programs
Building Java Programs
Building Java Programs
Chapter 2 Lecture 2-2: The for Loop reading: 2.3
Presentation transcript:

TOPIC 7 MODIFYING PIXELS IN A MATRIX NESTED FOR LOOPS 1 Notes adapted from Introduction to Computing and Programming with Java: A Multimedia Approach by M. Guzdial and B. Ericson, and instructor materials prepared by B. Ericson.

Outline 2  Nested loops  Using nested loops to process data in a matrix (2- dimensional array)  More advanced ways of manipulating pictures in Java programs

Nested Loops 3  Suppose we want to print a line of 40 dots ………………………………….  We can do this with a for loop: for (int i=1; i<=40; i++) { System.out.print(“.”); } System.out.println();

Nested loops 4  Now suppose we want to print 5 rows of 40 dots each  We can use a for loop to count the rows: for (int row = 1; row <= 5; row ++) { // print 40 dots in a row for (int i=1; i<=40; i++) { System.out.print(“.”); } System.out.println(); }

Nested loops 5  The for loop to print a row of dots is part of the body of the loop that counts the rows  This is an example of nested loops  The loop that counts the rows is called the outer loop  The loop that prints each row of dots is called the inner loop

Nested loops 6  Another example: print a triangle of dots... … …. …..  The outer loop will count the rows  The inner loop will print the appropriate number of dots

Nested loops 7 for (int row = 1; row <= 5; row ++) { // print dots in a row for (int i=1; i<=??; i++) { System.out.print(“.”); } System.out.println(); }

Exercise 8  What would you change in the code of the previous slide so that it prints ….. …. …...

Picture manipulation 9  So far, we have used a single loop when modifying a picture  We had a one-dimensional array of Pixels returned by the method getPixels()  But this technique is only useful for simple picture manipulations that change every pixel the same way  For example, decreaseRed(), negate(), etc.

More advanced picture manipulation 10  We can only go so far in processing pictures without knowing where certain pixels are in an image, for example:  Cropping a picture  Copying just part of a picture  Performing reflections  Performing rotations  We will now consider a picture as a matrix or two dimensional array

Review: Pictures as a grid of pixels 11  Recall that pictures are organized as a grid of pixels  The grid has columns and rows  Each pixel has an (x, y) position in the grid  x specifies the column  y specifies the row  We will now call this grid a matrix or 2-D array X Y

Pictures as 2-D arrays 12  To access each pixel in the picture (i.e. in the 2-D array), we will use nested loops  We can access pixels row by row: The outer loop moves horizontally along rows Then to get each pixel in a row, the inner loop moves vertically along columns  Or we can access pixels column by column: The outer loop moves vertically along columns Then to get each pixel in a column, the inner loop moves horizontally along rows

Nested loops 13  To get all the pixels in a picture using their x and y values row-wise (left to right, top to bottom) x=0, y=0 x=1, y=0 x=2, y=0 … x=0, y=1 x=1, y=1 x=2, y=1 … x=0, y=2 x=1, y=2 x=2, y=2 …  We have nested loops:  The outer loop counts rows: y from 0 to (height – 1)  The inner loop counts columns: x from 0 to (width – 1)

Nested loop template (row-wise) 14 // Loop through the rows (y direction) for (int y = 0; y < this.getHeight(); y++) { // Loop through the columns (x direction) for (int x = 0; x < this.getWidth(); x++) { // Get the current pixel pixelObj = this.getPixel(x,y); // Do something to its color // Set the new color pixelObj.setColor(colorObj); }

Alternative nested loops 15  To get all the pixels in a picture using their x and y values column-wise (top to bottom, left to right ) x=0, y=0 x=0, y=1 x=0, y=2 … x=1, y=0 x=1, y=1 x=1, y=2 … x=2, y=0 x=2, y=1 x=2, y=2 …  We again have nested loops:  The outer loop counts columns: x from 0 to (width – 1)  The inner loop counts rows: y from 0 to (height – 1)

Nested loop template (column-wise) 16 // Loop through the columns (x direction) for (int x = 0; x < this.getWidth(); x++) { // Loop through the rows (y direction) for (int y = 0; y < this.getHeight(); y++) { // Get the current pixel pixelObj = this.getPixel(x,y); // Do something to its color // Set the new color pixelObj.setColor(colorObj); }

Lightening an image 17  Earlier, we saw how to lighten an image by accessing pixels through getPixels()  This time, we will use nested loops  We will do a column-wise implementation  Exercise: write the row-wise version

Lightening an image public void lighten2() { Pixel pixelObj = null; Color colorObj = null; // loop through the columns (x direction) for (int x = 0; x < this.getWidth(); x++) { // loop through the rows (y direction) for (int y = 0; y < this.getHeight(); y++) { 18

Continued 19 // get pixel at the x and y location pixelObj = this.getPixel(x,y); // get the current color colorObj = pixelObj.getColor(); // get a lighter color colorObj = colorObj.brighter(); // set the pixel color to the lighter color pixelObj.setColor(colorObj); } //end of inner loop } // end of outer loop }

Exercise: Changing to Nested Loops 20  Change the method clearBlue() to use nested for loops to loop through all the pixels  Check that the blue values are all 0 using the explore() method

More advanced picture manipulations 21  We will now consider image manipulations that do not alter all the pixels in a picture:  Vertical mirroring  Horizontal mirroring  Others (textbook) Cropping Rotating Scaling

Vertical mirroring 22  We place a mirror in the middle of a picture

Vertical mirroring 23  To do this, we want to take the mirror image of the left half of the caterpillar and copy it to the right half

Vertical mirroring 24  Left half:  Copy to right half:

Vertical mirroring 25 Width is 329 X ranges from 0 to 328 Height is 150 Y ranges from 0 to 149 Midpoint = 329/2=164 Left half: Width is 164 X ranges from 0 to 163

Vertical mirroring 26  Bad approach: copy column 0 to column 164, column 1 to column 165, etc.

Algorithm 27 (0,0)(1,0)(2,0)(3,0)(4,0) (0,1)(1,1)(2,1)(3,1)(4,1) (0,2)(1,2)(2,2)(3,2)(4,2)  Loop through the rows (y values)  Loop from x starting at 0 and going to just before the midpoint (mirror) value Get the left pixel, at x and y Get the right pixel, at (width -1 - x) and y Set the color for the right pixel to be the color of the left pixel (0,0)(1,0)(2,0)(3,0)(4,0) (0,1)(1,1)(2,1)(3,1)(4,1) (0,2)(1,2)(2,2)(3,2)(4,2)

Algorithm to code 28  We are going to need the midpoint int midpoint = this.getWidth() / 2;  Loop through the rows (y values) for (int y = 0; y < this.getHeight(); y++) {  Loop through x values (starting at 0) for (int x = 0; x < midpoint; x++) { Set right pixel color to left pixel color Pixel leftPixel = this.getPixel(x, y); Pixel rightPixel = this.getPixel(this.getWidth() x, y); rightPixel.setColor(leftPixel.getColor());

Mirror vertical method 29 public void mirrorVertical() { int mirrorPoint = this.getWidth() / 2; Pixel leftPixel = null; Pixel rightPixel = null; // loop through the rows for (int y = 0; y < this.getHeight(); y++) { // loop from 0 to just before the mirror point for (int x = 0; x < mirrorPoint; x++) {

Continued 30 leftPixel = this.getPixel(x, y); rightPixel = this.getPixel(this.getWidth() – 1 – x, y); rightPixel.setColor(leftPixel.getColor()); }

Trying the method 31  Create the picture Picture p1 = new Picture( FileChooser.getMediaPath("caterpillar.jpg"));  Call the method on the picture p1.mirrorVertical();  Show the picture p1.show();

Horizontal mirroring 32  Next: mirroring horizontally, i.e. around a mirror held horizontally in the vertical center of the picture

Algorithm 33 (0,0)(1,0)(2,0) (0,1)(1,1)(2,1) (0,2)(1,2)(2,2)  We will need the horizontal midpoint this time  Loop through the columns (x values )  Loop from y=0 to y < midpoint Get the top pixel, at x and y Get the bottom pixel, at x and (height -1 - y) Set the color for the bottom pixel to be the color of the top pixel (0,0)(1,0)(2,0) (0,1)(1,1)(2,1) (0,2)(1,2)(2,2)

Exercise 34  Write the method to mirror the top half of the picture to the bottom half  This is the motorcycle image in redMotorcycle.jpg  Next: mirroring bottom to top

Useful Mirroring 35  The Temple of Hephaistos in Athens, Greece has a damaged pediment. Goal: fix the temple.

Useful Mirroring 36  We can’t just mirror the left half onto the right  We don’t mirror all pixels  How can we accomplish this?  Choose a point to mirror around vertically  Start with the row of pixels at the top of the pediment  End with the row of pixels at the bottom of the pediment

Determining the region 37

Result 38  Before and after: how can you tell that the picture has been digitally manipulated?

Summary 39  Nested loops  Pictures as 2-D arrays of pixels  Algorithms on Pictures:  Vertical mirroring  Horizontal mirroring