联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> Java编程Java编程

日期:2020-09-25 09:02

Lab 4: Unique turtles

In this week's lab, you will create a collage of "turtle tracks" that are left as multiple turtles with

unique shapes and colors move from top-to-bottom across the canvas (like footprints left in the

snow). The animation of the turtles drawing the collage resembles a colorful version of code rain

from The Matrix.

The goals this week are to:

● Learn how to use objects using the familiar turtle module.

● Practice using return values and multiple assignment.

● Practice conditionals.

● Practice reading code documentation to discover new functions that are needed to

complete a task.

● Lab 4: Unique turtles

○ Tasks

■ L1. The setup

■ L2. Make Screen and Turtle objects

■ L2a: Create a Screen object

■ L2b: Make the screen appear

■ L2c: Create one Turtle object

■ L2d: Make a few Turtle objects

■ L3: Reset the position of each turtle

■ L3a: Write the reset_turtle function

■ L3b: In main, place your turtles on the starting line

■ L4: Turtle tracks

■ L5: Make your collage

■ L6: Scorekeeper: A turtle with a different job

■ L6a: Keeping count of strides

■ L6b: Make a function to write text to the screen

■ L6c: Have a new Turtle write the stride count on-screen

○ Get started with the project

- © 2020 Oliver Layton

Tasks

L1. The setup

Create a Lab04 folder on your computer where you store CS151 projects and labs, hopefully

somewhere that is backed up (e.g. in Dropbox, Google Drive, Microsoft One Drive, etc.)

Open VS Code. Create a new Python source code file calledlab4.py. Import the random and

turtle modules.

Open up a Terminal (e.g. Control+` in VS Code) and change the directory (cd) to the Lab04

folder.

L2. Make Screen and Turtle objects

This week, we will use objects to divide up the labor of creating a canvas and drawing shapes

with turtle. The division of labor occurs among 2 types of objects:

1. Screen: You will create a Screen object that represents the canvas (pop-up window in

which each the turtle draws stuff). This object will allow you to store and change

information relating to the canvas window ("screen") (i.e. its height and width, whether it

stays up waiting for you to click, its background color, etc.)

2. Turtle: You can now create more than one turtle that draws on the screen at once! Each

turtle is a different object that you create. You will control each independently and

customize each one with unique properties: each can have different pen widths, colors,

shapes, and locations.

In this task, you will create an object for the screen and several different turtles.

L2a: Create a Screen object

Write a function in lab4.py that has the following docstring:

It may be helpful to have class notes and the turtle documentation open as you work. Your

function should accomplish the following:

● Create a Screen object.

● Set the height and width of the screen.

● Set the background color.

● Set the title

● Return the screen object that you created.

Reminder: With objects, you call functions ON THEM, not on the turtle module (e.g.

screen.setup(width, height), not:

turtle.setup(width, height), assuming your Screen object is called screen).

L2b: Make the screen appear

Make a main function in lab4.py. In it, call your make_screen function and remember to assign a

variable to the Screen object that make_screen returns. For example,

screen = make_screen(<plug in your 3 or 4 parameters here>). You can pass in whatever

parameter values that you like when you call make_screen. Here are some suggestions:

● A good starting point for the screen size is 500 pixels (width) x 400 pixels (height). You

may change this later based on your preferences.

● Give the window a title string. Again, you can change this later.

● You can leave the background color its default value (black) or change it.

Call the exitonclick method on your Screen object at the end of your main function.

Create the usual conditional statement for main code at the bottom of lab4.py (i.e.

if __name__ == '__main__':). Call main in it.

Running lab4.py should give you a blank window like this, with your custom size and title (my

background color is black and I used the Screen title "Turtle Tracks"):

Spend a moment to play with your title, window size, and background color to get a sense of

how each property controls how the screen looks.

L2c: Create one Turtle object

Write a function that creates a single Turtle object that will appear on the canvas (represented

by your Screen object) with the following docstring:

Your function should do the following (again, it probably will be helpful to look at lecture notes

and the turtle documentation):

● Create one Turtle object (calling your make_turtle function multiple times later on will

allow you to create multiple, uniquely customized turtles).

● Set the shape of the turtle object based on the parameter that you pass in.

● Set the pen color of the turtle object based on the parameter that you pass in.

● Set the turtle object's pen in the ‘up’ mode. We want each turtle to leave their "tracks" as

they move, not a connected line.

● Return the Turtle object that you created.

Reminder: You should NOT be typing turtle.<stuff> except for the first line where you create the

Turtle object! Instead, call methods on your turtle object.

L2d: Make a few Turtle objects

After creating your Screen object in main, but before you call exitonclick, call make_turtle 3

times. This will create 3 turtles that show up on your canvas. Like you did with make_screen,

remember to assign the returned object from each make_turtle call to a distinct variable so that

you can control each one later (e.g. turt1, turt2, turt3).

Move your first turtle to (x, y) = (-200, 0) by calling the goto method on it, the second turtle to

(-50, -50), and the third turtle to (100, 100) (by calling the goto method on each of them).

Running your code should give you something that looks like:

Take a moment to have some fun playing with shapes and colors of each turtle. What do each

of the built-in turtle shapes look like?

L3: Reset the position of each turtle

Let's start to create a colorful collage of the "tracks" left behind by each turtle as they move from

top-to-bottom across the screen. First, you need to place each turtle in their starting position at

the top of the screen.

L3a: Write the reset_turtle function

Write your function with the following signature:

def reset_turtle(turt, screen_width, screen_height):

Your function should do the following with the Turtle object passed in as a parameter (turt):

● Place the turtle at a random position along the top edge of the screen (see hint below).

● Reset the turtle's heading so that it is facing south (Hint: if you forget the heading angle

convention, check out the documentation for setheading).

● Set the turtle's pen color to a random RGB tuple, each component ranging between 0 to

1 (Remember the parentheses).

Hint: The center of the screen is position (0, 0).

The x-coordinate of the left edge of the screen is -screen_width/2 and that of the right edge of

the screen is screen_width/2.

The y-coordinate of the bottom edge of the screen is -screen_height/2 and that of the top edge

of the screen is screen_height/2.

L3b: In main, place your turtles on the starting line

Call your reset_turtle function 3 times in main, once on each of the 3 turtles. You should get

something that looks like this (your positions will be different due to randomness):

Tip: If one or more of your turtles are not showing up, try placing them 10 pixels or so below the

top of the screen (e.g. screen_height/2 - 10). It is possible that they are up there, but just are not

visible because they are slightly off-screen.

L4: Turtle tracks

Write a function with the following signature that should move the turtle turt forward by distance

and then stamp to leave a track.

def move_and_stamp(turt, distance):

In main, call move_and_stamp once on each turtle. Have your 3 turtles move different

distances: 40, 30, 20, respectively. You should see something that looks like:

L5: Make your collage

In main, repeat the process of moving all 3 turtles forward and having them leave a stamp 1000

times. If any of the turtles moves off the bottom of the screen (the y coordinate is too small), call

your reset_turtle function on that turtle.

If everything is working when you run your code, you should see a collage like the one at the top

of this page being created!

Once you get the collage working, have some fun and try:

● Speeding up the animations. Call the speed method on your Turtle object when you

make it.

● Add some variety to the distance traveled by each Turtle during each movement:

randomly move each turtle between 0 and 10 units farther than the default distance.

L6: Scorekeeper: A turtle with a different job

In this last task, you will make another Turtle object — but it will have the unique job of writing

text on the screen (rather than leaving tracks or drawing shapes).

L6a: Keeping count of strides

In main, define a counter variable that starts at 0 and gets incremented by 1 whenever any one

of your turtles completes a stride from top-to-bottom of the screen and gets reset. In other

words, this variable should keep track of how many times you call reset_turtle.

I suggest printing out the variable when you update it (i.e. add one to it) to help you debug / help

convince yourself that your code is working.

L6b: Make a function to write text to the screen

This function will have a Turtle object write your current stride count on the screen.

Make a function with the following signature:

def writeNumStrides(turt, numStrides):

It should do three things:

● Call the clear method on the turt Turtle object. This will have the turtle erase the previous

number to prepare to write the current one. For example, if numStrides was previously 1

(and 1 is shown on the screen), clear will erase that so that a new number (e.g. 2) can

be written.

● Copy and paste the line:

turt.write(numStrides, font=('Arial', 30, 'normal')).

This will have the turtle write the number on the screen in a nice, large font.

● Call the hideturtle method on the Turtle object. This will make the turtle shape go

invisible so that it does not block the number it just wrote!

L6c: Have a new Turtle write the stride count on-screen

In main, create one new Turtle object — the shape does not matter, but I suggest using a white

pen color if you are keeping the default screen background color of black (you want to be able

to see the text on your background color!).

Place the new Turtle object somewhere on the screen (not the top). For example, I placed mine

in the middle, 10 pixels higher than the bottom of the screen.

Whenever you call reset_turtle and increment your stride counter (i.e. assign it to one more than

its current value), call the writeNumStrides function to have the latest stride count always

appear on the screen.

Test out your collage with the new counter. You should see the stride count on screen and it

should increase by 1 whenever a turtle reaches the bottom of the screen.

Get started with the project

Once you are done with each of the lab tasks, you may start on the project.

© 2020 Oliver Layton

Project 4: Turtle race

In this project, you will practice creating objects that have unique roles and properties. You will

be making a scene where two turtles are racing each other in a race course that you design.

Aside from the Screen object, you will create different Turtle objects, each of whom perform

different roles:

● Race on the track.

● Draw the background scene (showing the race track, the audience, etc.).

● Show the score — how many laps each turtle completes (there are two Turtle "score

keepers", one per racer).

Extension points are awarded for complex scenes, especially those that show me that you can

integrate concepts from lecture into making your scenes and take things to the next level!

Tasks

● Project 4: Turtle race

○ Tasks

■ 0. Design your race course

■ 1. Create object_shapelib.py

■ 1a. goto function

■ 1b. Create functions that you need to draw your race track scene

■ 1c. draw_race_scene

■ 1d. Test your race track scene

■ 2. Create race.py

■ 2a. Copy over make_turtle from lab into race.py

■ 2b. Make a main function

■ 2c. Create the move_turtle function

■ 2d. Move your racing turtles around the track

■ 3. Race!

■ 3a. Randomly jitter each racing turtle's speed

■ 3b. Keep score

○ Check reproducibility

○ Extensions

○ Submission checklist

- © 2020 Oliver Layton

0. Design your race course

Decide on the shape of your race course. It doesn't need to be fancy. Keep in mind that your

turtles will need to be able to go around the race course multiple times (i.e. to complete "laps").

Some ideas are:

● circular (simplest and recommended)

● linear (e.g. back-and-forth either side of the screen)

● around a simple shape (e.g. square, diamond, etc.)

1. Create object_shapelib.py

Just like better_shapelib from last week, object_shapelib.py will contain all your

functions that draw shapes and the race scene. You're welcome to add as much

complexity as you would like, but minimally it should contain the following functions.

For full credit, all these functions should only use a Turtle object to do the

drawing. I should not see turtle.<blah> anywhere, except on the line where you create

your Turtle object!

1a. goto function

Copy-and-paste the goto function that you have from better_shapelib, and update it to

have the function signature:

def goto(turt, x, y, heading=0):

Do the following:

● Update the code so that it entirely consists of method calls done on the Turtle

object turt.

● If you previously did not have a parameter for heading, make sure that you set

turt's heading to the parameter heading.

1b. Create functions that you need to draw your race track scene

The ones you need depend on your race track design and your concept for your race

scene. For example, if you were using a circular track, you might use a circle function to

draw the racing lanes (e.g. their outlines, fill, inner and outer lane dividers, road

markers, etc.):

def circle(turt, x, y, radius, penWidth=3, fill=True, fillColor='brown'):

Keep it simple! You can always add complexity later. At minimum, each of your shape

functions should have:

● A parameter for the Turtle object that draws your shape (e.g. turt above).

● Position parameters (e.g. x and y).

● Keyword arguments to control the appearance (e.g. penWidth above).

Feel free to copy-and-paste and adapt code from previous projects!

1c. draw_race_scene

This is the function that should draw your race track scene. It does NOT need to have

(x, y, scale) parameters — I suggest only putting in the work to do this if you plan to

take advantage of repositioning and scaling your scene as part of a larger extension.

Here is an overview of what the draw_race_scene function should do:

● Create a Turtle object that will draw your scene.

● Call your functions from Task 1b to draw the lanes/course in which your two

turtles will race one another.

● Customize the rest of the scene as much as you'd like (e.g. add bleachers, a

crowd of fans, trees, etc.). You can skip this for now until you get the rest of the

project working.

1d. Test your race track scene

Copy-and-paste your make_screen function from lab into object_shapelib.py.

Add main code to if __name__ == '__main__': in object_shapelib.py to test out your race

scene. It should make a Screen object and draw your race scene.

Run object_shapelib.py to produce your race scene.

Take a screenshot —

This is Required Image 1 in your project report.

2. Create race.py

This file will place your turtles in their racing lanes and have them race. The following

subtasks walk you through the general setup.

2a. Copy over make_turtle from lab into race.py

Call this function when you need to create a Turtle object.

2b. Make a main function

Your function should:

● Make a Screen object

● Draw your race scene

● Create 4 Turtle objects: 2 racing turtles and 2 "score keepers" (they will show

how many laps racing Turtle 1 and Turtle 2 complete, respectively).

● Place the racing turtles at the "starting line" of your race track (where ever you

decide that to be). Make sure they are facing the right way to start racing on your

track!

● The placement of the two score keeper turtles is up to you.

Important notes:

● Make sure that the two racing turtles look distinct (e.g. different colors, shapes,

etc.).

● The score keeper turtles should have a color that will make their written scores

readable against your background color.

Add a if __name__ == '__main__': statement in race.py that calls your main function.

If you run your code now, you should see your racing scene drawn on the screen and

your two racing turtles should show up at the starting line in their respective lanes.

2c. Create the move_turtle function

Each racing turtle will move at a different speed, which means that you move them

speed units on each time step of your simulation (e.g. in a loop coming up later). The

move_turtle function should have one of your turtles (turt) take one "step" (the size of

step is speed) and should have a signature that looks like:

def move_turtle(turt, speed):

'''Moves the `Turtle` object `turt` `speed` units '''

Feel free to customize the parameters to suit your race course concept.

Hint (if using a circular course): The turtle circle method has a keyword argument that

allows you to specify how much of a circle (angle) that you want to move around.

2d. Move your racing turtles around the track

After the code that you have already written in main, move each of the racing turtles

1000 times. Give Turtle 1 a speed of 5 and Turtle 2 a speed of 4.9.

If you run your code, you should see each turtle move around the track (not deviating

from it). Turtle 1 should complete laps faster than Turtle 2.

Hint: If your race course requires the turtles or go back-and-forth or turn corners, you

will need to change their heading after they move a certain distance or reach the end of

the screen.

3. Race!

Make the race more interesting by adding the following elements.

3a. Randomly jitter each racing turtle's speed

Every time that you move one of the turtles, randomly shift its speed by at most

±1\pm1±1 unit.

3b. Keep score

Create variables to keep track of each turtle's "score": how many laps each turtle has

completed.

Detect when a turtle completes a lap, increment the appropriate turtle's score, and

display the updated score on the screen (somewhere in your scene). You may

repurpose any relevant code from lab.

Take a screenshot of your final race scene in action

(showing two turtles racing on your track with their

scores shown). This is Required Image 2 to be

included in your report.

Check reproducibility

In order to grade your project, we need to be able to run your code and get the same

results as you do! Here is a summary of the expected outputs from each of the source

code files that you created:

● python3 race.py: Draws your racing scene and has two turtles move along the

race course that you designed. The number of laps completed by each turtle

racer should be displayed and updated.

If you use command-line arguments in an extension,

explain what they are and provide an example way to

run your code in both code comments and your

report.

Extensions

Congratulations on completing the core tasks! If your code and report meet the above

expectations, you’ve already earned up to 26/30 points for this project.

The remaining 4/30 are a chance for you to earn credit for exploring parts of this project

and digging deeper to express your creativity! This is entirely optional; 26/30 is a B and

is a perfectly respectable place to stop. Extensions are open-ended and exist to

compliment the structured core project. Explore and learn something new that interests

you!

Concentrating your energy on 1-2 "deep" extensions that challenge

you will earn you more points than many small, "shallow" extensions.

You can pick your own topics that interest you. Here are a few examples:

1. Creative or complex scenes above and beyond the basic expectations count as

extensions.

2. Make the animation of your turtles making the collage from lab look more like

code rain. Some ideas are to draw letters and numbers rather than turtle shapes,

randomize which letters or numbers are drawn, have the "stamps" disappear

after each the turtle has moved a certain number of times.

3. Learn about lists and use them to improve the conciseness of your code.

4. Add additional racing turtles.

5. Design a more complex race track shape (e.g. a spiral, maze, etc.)

6. Designate a winning turtle: the first turtle to complete N laps. Analyze how

differences in the turtle speeds and the amount of randomness influences the

chance that they win.

7. Related to the previous extension, learn about the Gaussian distribution and use

it to generate the random variations in the turtle speed. Analyze how factors

related to how randomness is created influences the chance that either turtle

wins.

8. Make it so that you can position and scale your race scene. Do something

interesting that takes advantage of this.

9. Create a new scene and/or scenario that involves multiple Turtle objects in an

interesting way.

Submission checklist

To turn in your project, make sure you do all of the following:

● Check the rubric in Google Classroom and make sure your report and code

contain all the required parts.

● Move your lab folder inside your project folder (i.e. drag the Lab04 folder inside

Project04).

● Create a zip file of your project.

● Attach (drag) the zip file to the posted project assignment on Google Classroom.

● Click Turn In on your Google Doc report on Google Classroom.

© 2020 Oliver Layton


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp