Alice in Action with Java Chapter 6 Events. Alice in Action with Java2 Objectives Create new events in Alice Create handler methods for Alice events Use.

Slides:



Advertisements
Similar presentations
Alice in Action with Java Chapter 6 Events. Alice in Action with Java2 Objectives Create new events in Alice Create handler methods for Alice events Use.
Advertisements

Space Man Sam: Grammar Mistakes By Aleis Murphy Duke University, Under the direction of Professor Susan Rodger July 2010.
Skater World: Part One By Deborah Nelson Duke University Under the direction of Professor Susan Rodger May 29,
Review of Chapter 4 Sections 1 and 2 World-level methods involve two or more objects break a large problem into smaller, logical units follow a design.
PIIT Computer Science Summer Camp - Alice July 11, 2012 Brenda Parker Computer Science Department MTSU.
Alice Inheritance and Event Handling. Inheritance Concept Consider this hierarchy; parents describe properties of children Animals Vertebrates MammalsFish.
Events Chapter 7. Interactivity The real world is interactive User determines order of actions instead of programmer.
Events Chapter 7. Interactive Real world is interactive User determines order of actions instead of programmer.
Alice in Action with Java Chapter 6 Events. Alice in Action with Java2 Objectives Create new events in Alice Create handler methods for Alice events Use.
Alice in Action with Java
Chapter 2: The Visual Studio.NET Development Environment Visual Basic.NET Programming: From Problem Analysis to Program Design.
CS320n –Visual Programming Interactive Programs Mike Scott (Slides 5-1)
Distributing (Fun + Learning): The Distributive Property By: Peggy Li Under the direction of Professor Susan Rodger Duke University, June
Line up By Melissa Dalis Professor Susan Rodger Duke University June 2011.
Visual Basic Chapter 1 Mr. Wangler.
Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley This week: Whew!!! The last homework was tough! The homework for this week.
Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Starting Out with Alice: A Visual Introduction to Programming First Edition.
Working with Numbers in Alice - Converting to integers and to strings - Rounding numbers. - Truncating Numbers Samantha Huerta under the direction of Professor.
by Chris Brown under Prof. Susan Rodger Duke University June 2012
Programming Alice Alice is named in honor of Lewis Carroll’s Alice in Wonderland.
Getting Started With Alice By Ruthie Tucker under the direction of Prof. Susan Rodger Duke University, July
Making a Boat Racing Game in Alice By Jenna Hayes Under the direction of Professor Susan Rodger Duke University, July 2010.
Programming with Alice Computing Institute for K-12 Teachers Summer 2011 Workshop.
Alice Learning to program: Part Three Camera Control, Invisibility, and 3-D Text By Ruthie Tucker and Jenna Hayes, Under the direction of Professor Rodger.
Changing Camera Views! Part 2: Simple Scene Change & Lighting Fixes By Bella Onwumbiko under the direction of Professor Susan Rodger Duke University July.
Events Chapter 7 Part 2. While a Key is Pressed Event Specialized event An event occurs when you press a key and continues until you take your finger.
Events (2) (Alice In Action, Ch 6) Slides Credit: Joel Adams, Alice in Action CS 120 Lecture September 2012.
Today’s Agenda 1.Collect Pre-Lab 5 2.Collect Alice project storyboards 3.Events 4.Dummy Objects 5.Assign pair programming teams and meet upstairs for Lab.
Chapter One An Introduction to Visual Basic 2010 Programming with Microsoft Visual Basic th Edition.
Microsoft Access 2010 Chapter 8 Advanced Form Techniques.
Skater World: Part Two By Deborah Nelson Duke University Under the direction of Professor Susan Rodger June 1,
PowerPoint Practice Exercise 1 1.Save this file in your AV-TECH Folder as PowerPoint Practice Exercise 1. 2.Open this file in PowerPoint. 3.Edit each slide.
Events (Alice In Action, Ch 6) Slides Credit: Joel Adams, Alice in Action CS 120 Lecture September 2012.
Making Billboards By Deborah Nelson Duke University, Under the direction of Professor Susan Rodger, July 14, 2008.
Alice in Action with Java Chapter 5 Lists and Arrays.
Balancing the scales: Inequalities By Melissa Dalis Professor Susan Rodger Duke University June 2011.
Copyright © 2009 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 4: Events Programming with Alice and Java First Edition by John Lewis.
Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Starting Out with Alice: A Visual Introduction to Programming Third Edition.
Skater World: Part Three By Deborah Nelson Duke University Under the direction of Professor Susan Rodger June 2009.
Tutorial 7 Creating Animations. XP Objectives Learn about animation Create a timeline Add AP divs and graphics to a timeline Move and resize animation.
5 Event Handling Interactive Programming Suggested Reading Interaction: Events and Event Handling, Supplemental Text for CPSC 203 Distributed this term.
Methods (part 1) Alice In Action, Ch 2 Slides Credit: Joel Adams, Alice in Action CS120 Lecture August 2012.
CompSci 4 Chap 5 Sec 1 and 2 Oct 14, 2010 Prof. Susan Rodger.
Headshots in Alice Duke University Professor Susan H. Rodger Gaetjens Lezin July 2008.
Presenter: Carol Liss Timberlane Regional Middle School 6 th and 7 th grade Tech. Educator Co presenters:
Alice in Action with Java Chapter 1 Getting Started with Alice.
Microsoft Visual C# 2010 Fourth Edition Chapter 3 Using GUI Objects and the Visual Studio IDE.
Making Billboards By Deborah Nelson Duke University, Under the direction of Professor Susan Rodger, July 14, 2008.
Creating a Simple Game in Scratch Barb Ericson Georgia Tech May 2009.
Chapter 2: The Visual Studio.NET Development Environment Visual Basic.NET Programming: From Problem Analysis to Program Design.
Alice in Action with Java Chapter 2 Methods. Alice in Action with Java2 Objectives Build world-level methods to help organize a story into scenes and.
Creating a UFO Rescue Game in Alice
Chapter 2: The Visual Studio .NET Development Environment
Professor Susan Rodger
EE 200 Design Tools Laboratory 14
Scratch for Interactivity
Alice Learning to program: Part Three Camera Control, Invisibility, and 3-D Text By Ruthie Tucker and Jenna Hayes, Under the direction of Professor Rodger.
Chapter 1: An Introduction to Visual Basic 2015
Getting started in Alice
Introduction to Events
Creating a UFO Rescue Game in Alice
Learning Java with Alice 3.0 Game Design Kathy Bierscheid
Skater World: Part Three
Alice in Action with Java
Learning to Program: Part 3 Camera Control, Invisibility and 3-D Text
Headshots in Alice Duke University Professor Susan H. Rodger
Presentation transcript:

Alice in Action with Java Chapter 6 Events

Alice in Action with Java2 Objectives Create new events in Alice Create handler methods for Alice events Use events to build interactive stories

Alice in Action with Java3 Events Interactive program: processes data input by a user Event: action generated by a user or a program –Ex: When the world starts caused by Play click Two steps to making a program respond to an event –Choose (or define) a method to handle the event –Tell Alice to invoke the method when the event occurs Event handler: method called in response to an event Event-driven program: based on events and handlers

Alice in Action with Java4 Events (continued)

Alice in Action with Java5 Handling Mouse Clicks: The Magical Doors Goal: add events to world built in Section –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 First step: stop door from automatically telling jokes

Alice in Action with Java6 Handling Mouse Clicks: The Magical Doors (continued)

Alice in Action with Java7 The Right Door How to handle a mouse event –Choose or define a method Define a method when responsive behavior is complex –Create an event that invokes the handler Enabling the right door to respond to a mouse event –Add When the mouse is clicked on something –Specify castle1.door as the event source –Use a turn() message to handle the event

Alice in Action with Java8 The Right Door (continued)

Alice in Action with Java9 The Right Door (continued)

Alice in Action with Java10 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

Alice in Action with Java11 The Left Door (continued)

Alice in Action with Java12 The Right Door Revisited Two-state behavior –Describes one of two states that an object can occupy –The state is determined by the value of a property –An if statement controls switching between states Logic error: right door continues to turn with user click Right door should open if closed, and close if open 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

Alice in Action with Java13 The Right Door Revisited (continued)

Alice in Action with Java14 The Right Door Revisited (continued)

Alice in Action with Java15 The Right Door Revisited (continued)

Alice in Action with Java16 Event Handling is Simultaneous Example: left door tells jokes while right door turns Alice handles simultaneous events well 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

Alice in Action with Java17 Event Handling is Simultaneous (continued)

Alice in Action with Java18 Categorizing Events Mouse event: triggered by mouse movement or click Keyboard event: triggered when user presses a key Program event: triggered when variable value changes

Alice in Action with Java19 Handling Key Presses: A Helicopter Flight Simulator The problem –The mayor’s 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

Alice in Action with Java20 Design Six keys for six types of 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 position and mnemonic values Choosing correct keys improves usability

Alice in Action with Java21 Programming in Alice Setting up 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 Making the helicopter’s propeller spin –Use heli blade() to handle the press of Play button Making the helicopter ascend –Define Boolean property inTheAir for helicopter –Define helicopter. ascend()

Alice in Action with Java22 Programming in Alice (continued)

Alice in Action with Java23 Programming in Alice (continued) 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 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

Alice in Action with Java24 Programming in Alice (continued)

Alice in Action with Java25 Programming in Alice (continued)

Alice in Action with Java26 Programming in Alice (continued)

Alice in Action with Java27 Programming in Alice (continued) Let arrow keys move event –Not appropriate for controlling helicopter movement –helicopter would move while on the ground Define turnSlightly() to handle left or right turns –turnSlightly() takes a Left or Right argument –helicopter turns only if inTheAir is true –Arrow keys are associated with the method –Depressing arrow key sends a Left or Right argument Define go() to handle forward or backward movement –Logic is similar to logic for turnSlightly() method

Alice in Action with Java28 Programming in Alice (continued)

Alice in Action with Java29 Programming in Alice (continued)

Alice in Action with Java30 Programming in Alice (continued)

Alice in Action with Java31 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

Alice in Action with Java32 Alice Tip: Using 3-D Text (continued)

Alice in Action with Java33 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

Alice in Action with Java34 Repositioning Text that is Off-Camera (continued)

Alice in Action with Java35 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

Alice in Action with Java36 Adding a Background (continued)

Alice in Action with Java37 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

Alice in Action with Java38 Making Text Appear or Disappear (continued)

Alice in Action with Java39 Making Text Appear or Disappear (continued)

Alice in Action with Java40 Alice Tip: Scene Transitional Effects for the Camera 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

Alice in Action with Java41 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

Alice in Action with Java42 Setup for Special Effects (continued)

Alice in Action with Java43 Setup for Special Effects (continued)

Alice in Action with Java44 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

Alice in Action with Java45 The Fade Effect (continued)

Alice in Action with Java46 The Fade Effect (continued)

Alice in Action with Java47 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

Alice in Action with Java48 The Barndoor Edge Wipe Effect (continued)

Alice in Action with Java49 The Barndoor Edge Wipe Effect (continued)

Alice in Action with Java50 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

Alice in Action with Java51 The Box Iris Wipe Effect (continued)

Alice in Action with Java52 The Box Iris Wipe Effect (continued)

Alice in Action with Java53 The Box Iris Wipe Effect (continued)

Alice in Action with Java54 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

Alice in Action with Java55 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

Alice in Action with Java56 Summary (continued) Add 3D Text dialog box: tool for inserting text 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