Download presentation
Presentation is loading. Please wait.
Published byMireya Elmer Modified over 10 years ago
1
Alice in Action with Java Chapter 6 Events
2
Alice in Action with Java2 Objectives Create new events in Alice Create handler methods for Alice events Use events to build interactive stories
3
Alice in Action with Java3 Events Event: action generated by a user or a program –Ex: clicking the Play button will generate When the world starts event Interactive programs, such as games, are event-driven Two steps to making a program respond to an event –Choose or define a method to handle the event Such a method is called an event handler Define an event handler when responsive behavior is complex –Tell Alice to invoke the method when the event occurs
4
Alice in Action with Java4 Events (continued)
5
Alice in Action with Java5 Handling Mouse Clicks: The Magical Doors Goal: add events to world built in Section 5.2.3 –Review: castle door tells random knock-knock jokes Events that will be added to the original program –Right door opens when the user clicks it –Left door tells knock-knock joke when the user clicks it
6
Alice in Action with Java6 The Right Door First step: stop door from automatically telling jokes by making world.my first Method do nothing Recall the two steps to handle an event –Use a predefined method or define a new method –Create an event that invokes the handler Enabling the right door to respond to a mouse event –The door open/close motion feels simple let us choose turn() to handle the event –Add When the mouse is clicked on something –Specify castle1.door as the event source
7
Alice in Action with Java7 The Right Door (continued)
8
Alice in Action with Java8 The Left Door Enabling the left door to respond to a mouse event –Specify castle.door2 as the source of this event –Drag-and-drop world s random joke method as handler Test the program by clicking each door
9
Alice in Action with Java9 The Right Door Revisited Logic error: right door continues to turn with user click Right door should open if closed, and close if open –i.e. exhibiting the two-state behavior General approach for dealing with multi-state behavior –Add an object property variable to store the object state –In object methods, use control flows such as the if statement to generate appropriate actions and perhaps also change the object state value afterwards
10
Alice in Action with Java10 The Right Door Revisited Fix: implement two-state behavior for right door –Add Boolean property rightDoorClosed to castle –Replacement handler: openOrCloseRightDoor() –Build turn logic around the value of rightDoorClosed
11
Alice in Action with Java11 The Right Door Revisited (continued)
12
Alice in Action with Java12 Event Handling is Simultaneous Example: left door tells jokes while right door turns Alice handles simultaneous events well
13
Alice in Action with Java13 More on Events Conflicts can arise when coding parallel event logic –Example: two handlers modify the same property How to avoid conflict –Ensure that handlers modify a property in sequence Event categories –Mouse event: triggered by mouse movement or click –Keyboard event: triggered when user presses a key –Program event: triggered when variable value changes
14
Alice in Action with Java14 Handling Key Presses: A Helicopter Flight Simulator The problem –The mayors cat is lost and city government has halted –You need to use your helicopter to find the cat –Search begins at an airport outside the city
15
Alice in Action with Java15 Event Design Six keys for six types of helicopter movement –a key: ascend –d key: descend –Up arrow key: move forward –Down arrow key: move backward –Left arrow key: turn left –Right arrow key: turn right Keys are chosen for two reasons –Convenient positions and mnemonic values Choosing correct keys improves usability
16
Alice in Action with Java16 Helicopter Flight Simulation Plan the world for a helicopter simulation –Add airport, helicopter, city terrain, buildings, and a cat –Position the helicopter at the airport –Position camera to be peering out in front of helicopter –Set the camera s vehicle property to be helicopter
17
Alice in Action with Java17 Helicopter Flight Simulation Event handling –Observation: feasible helicopter motion depends on its status in air E.g. it can only descend, turn L/R, or move F/B, when it is in air –Define Boolean property inTheAir for helicopter –In event handler methods, check the value of inTheAir and respond accordingly
18
Alice in Action with Java18 Helicopter Flight Simulation Making the helicopter ascend (continued) –Add a When a key is typed event –Change event to While a key is typed event –Associate the A key with the event –Enable the handler to perform while A key is pressed
19
Alice in Action with Java19 Helicopter Flight Simulation
20
Alice in Action with Java20 Helicopter Flight Simulation Making the helicopter descend –Define descend() method for helicopter Method logic mirrors the logic of ascend() Note that the ground provides a floor for the descent –Enable descend() to perform while D key is pressed
21
Alice in Action with Java21 Helicopter Flight Simulation
22
Alice in Action with Java22 Helicopter Flight Simulation Define turnSlightly() to handle left or right turns –helicopter turns only if inTheAir is true –turnSlightly() takes a Left or Right argument –Arrow keys are associated with the method –Depressing arrow key sends a Left or Right argument
23
Alice in Action with Java23 Helicopter Flight Simulation Connect the left and right arrow keys with the method –Depressing arrow key sends a Left or Right argument
24
Alice in Action with Java24 Helicopter Flight Simulation Define go() to handle forward or backward movement –Logic is similar to logic for turnSlightly() method
25
Alice in Action with Java25 Alice Tip: Using 3-D Text Helicopter simulator should have flight instructions Solution: add 3-D text that explains the interface Creating 3-D text for the simulator –Return to the Add Objects screen –Click Create 3D Text (at far end of Local Gallery ) –Add flight instructions in the text box –Click OK –Rename the text object, instructions
26
Alice in Action with Java26 Alice Tip: Using 3-D Text (continued)
27
Alice in Action with Java27 Repositioning Text that is Off-Camera Right-click instructions to access methods Three settings for positioning text in front of camera –Choose methods-> setPointOfView( camera –Choose methods->move(, ) ->FORWARD->10 meters –Choose methods->turn, ) ->LEFT->1/2 revolution Linking text to camera and changing text color –Set instructions.vehicle to camera –Set instructions.color to yellow
28
Alice in Action with Java28 Repositioning Text that is Off-Camera (continued)
29
Alice in Action with Java29 Adding a Background Text for instructions is difficult to read Solution: provide a background for the text One way to add a background to instructions –Insert square object ( Square is in Shapes Folder ) –Resize and reposition square behind instructions –Set square.color property to black –Make light turn to face the instructions –Set the square.vehicle property to instructions
30
Alice in Action with Java30 Adding a Background (continued)
31
Alice in Action with Java31 Making Text Appear or Disappear Another example of two-state behavior Implementation strategy –Add handler to switch value of isShowing property Logic of toggleInstructionVisibility() –Negate the value of isShowing property –Apply negation to both square and instructions Completing the implementation of the handler –Add a When a key is typed event –Associate the toggle method with the spacebar
32
Alice in Action with Java32 Making Text Appear or Disappear (continued)
33
Alice in Action with Java33 Making Text Appear or Disappear (continued)
34
Alice in Action with Java34 Alice Tip: Scene Transitional Effects for the Camera (not covered in CS120) Transition: bridge between two scenes (or shots) Some transition effects –Cut: instantaneous jump from one scene to another –Fade: darken existing scene, light another –Wipe: cover existing scene, uncover new scene Alice does not provide built-in transitional effects Alice does provide building blocks for transitions
35
Alice in Action with Java35 Setup for Special Effects Creating shutters for your camera –Add four square s outside of the viewport –Change names to indicate shutter positions –Change each square color to black –Change each square.vehicle to camera –Move the shutters outside of the viewing area Shutters will be manipulated to create effects
36
Alice in Action with Java36 Setup for Special Effects (continued)
37
Alice in Action with Java37 Setup for Special Effects (continued)
38
Alice in Action with Java38 The Fade Effect A fade effect darkens and then lightens a screen Create effect using complementary methods Overview of implementing fadeToBlack() –Set the topShutter s opacity to zero percent –Move the topShutter to cover the camera viewport –Set topShutter opacity back to 100 percent Overview of implementing fadeFromBlack() –Reverse the actions of fadeToBlack() Use fadeToBlack() and fadeFromBlack() in pairs –The scene changes between method calls
39
Alice in Action with Java39 The Fade Effect (continued)
40
Alice in Action with Java40 The Fade Effect (continued)
41
Alice in Action with Java41 The Barndoor Edge Wipe Effect Edge wipe: edges cover one scene, reveal another Barndoor wipe: shutters slide like doors of a barn –Vertical: doors close and open from sides of screen –Horizontal: doors close and open from top and bottom Create barndoor wipes with complementary methods Implementing verticalBarndoorClose() –Move the left and right shutters into the viewing area Implementing verticalBarndoorOpen() –Move the left and right shutters out of the viewing area
42
Alice in Action with Java42 The Barndoor Edge Wipe Effect (continued)
43
Alice in Action with Java43 The Barndoor Edge Wipe Effect (continued)
44
Alice in Action with Java44 The Box Iris Wipe Effect Iris contains the open area of the screen End one scene by shrinking the iris As iris expands, the new scene is revealed Defining the box iris close effect –Simultaneously move all four shutters onto viewport –Sender specifies duration of the effect –Sender specifies percentage the iris is closed One parameter and two local variables are needed Box iris open effect is complementary to close effect
45
Alice in Action with Java45 The Box Iris Wipe Effect (continued)
46
Alice in Action with Java46 The Box Iris Wipe Effect (continued)
47
Alice in Action with Java47 The Box Iris Wipe Effect (continued)
48
Alice in Action with Java48 Reusing Transition Effects Limitations of save object as… technique –Cannot be used to save properties as objects –Consequence: camera cannot be saved with shutters Solution: define transitions in a template world Contents of template (named TransitionEffects ) –camera, light, ground, and square s Using TransitionEffects template world –Open template as starting world for user story –Use File->Save world as… to save and rename
49
Alice in Action with Java49 Summary Event: action generated by a user or a program User events: keyboard events and mouse events Event handler: method called in response to an event Event-driven program: program directed by events and handlers Two-state behavior: pattern that switches the state of an object Add 3D Text dialog box: tool for inserting text
50
Alice in Action with Java50 Summary (continued) square : convenient shape for creating a text background and transition effects Transition effect: bridge between two scenes Types of transition effects: cut, fade, and wipe A transition effects template world includes ground, light, camera, and effects objects
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.