Learning Outcomes
On completion of this lesson you will know to proportionally scale a quadrilateral.
Go to topOn completion of this lesson you will know to proportionally scale a quadrilateral.
Go to topThis is possibly the easiest lesson in this group. We only need to modify the function drawShape(), which we have renamed scaleShape(). To modify it we simply replaced the trigonometry with addition.
We are also using a simple method of scaling: we are simply adding the same values to the width and height of the quadrilateral for each frame.
Go to topAs in the previous example we build our quadrilateral is built around the origin, (0, 0). We supply only the value of the one vertex. From that, using only addition and subtraction, we work out the other three vertices.
Also following the previous example we shall look at how the coordinates of the other three vertices are calculated once the first vertex is supplied. We shall use the starting value of 200 pixels
This value is supplied to the function through the argument currentSize at line 12. At line 14 this value is copied into the x coordinate of the first vertex, x1. The value of y1 is calculated at line 15 as one eighth of x1.
As before, at lines 16 and 17, the values of x3 and y3 are calculated as the negatives of x1 and y1.
At lines 18 and 19 the value of x2 is calculated as the negative of x1 while the value of y2 is calculated as the same as y1. At lines 20 and 21 the values of x4 and y4 are calculated as the negatives of x2 and y2.
At lines 23 to 30 all eight coordinates have their values adjusted so that now they are centered around the point (400, 400).
Fig 1 above shows how the coordinates of the vertices are positioned around (0, 0) and then adjusted so that they are centered around (400, 400).
Go to topThe for loop at line 102 controls the creations of our frames. The current value of the loop counter size is passed as the first argument to the function scaleShape() and determines the size of the quadrilateral that is to be drawn. The smallest size is 20 pixels and this increases by increments of 6 as far as 380. This will result in 61 frames where the quadrilateral increases in size in each successive frame.
Go to topTwo sets of frames have been put back to back here to give the impression of a quadrilateral ever increasing and decreasing in size.
Go to topScaling is a simple process of adding or subtracting the same values to the width and height of a shape. This is a simple method of scaling and is not the only method available. The method used here is the simplest and is used to illustrate the concept of scaling.
Go to topModify the program so that the quadrilateral is scaled by multiplying the width and height by a scale factor. The scale factor should be a value between 0 and 2. The quadrilateral should start at 200 pixels and increase to 400 pixels in size.
Go to top