# CSE 340 Lab 2 (Spring 2021) ## Week 2: Final Doodle Requirements and Layout Review .title-slide-logo[ ![:img Android phone showing a linear layout of todos on a calendar, 15%, width](img/android-linear.png) ] --- # Doodle and Layout Timeline - Doodle lock: Friday, January 14th @ 10:00pm - Peer evaluations will be assigned by end of day - Doodle peer evaluation (NO LATE DAYS) and Reflection due Sunday, January 16th @ 10:00pm - Reflection LOCK Monday, January 17th @ 10:00pm - Layout part 1-2 due/locked: Thursday, January 20th @ 10:00pm (**NO LATE DAYS**) - Part 3-5 (code + reflection) due: Thursday, January 27th @ 10:00pm, lock: January 29th @ 10:00pm --- # Section 3 Objectives - Review reflection examples - Brief overview of different layout types in Android - Practice Problem - Layout Lab practice --- # Wrapping Up Doodle... - Submit 3 peer reviews by navigating to Canvas > Assignments - Submit Doodle video. Rubric will be on the Canvas assignment page. - Submit Reflection to Gradescope --- # Reflections Rubric What did you learn from reading the peer evaluation about the user experience of your doodle? Please rate the following reflections out of 3 points using the rubric on the next page. - [How to Write a Reflection](https://courses.cs.washington.edu/courses/cse340/22wi/assignments/reflection.html) - You will be able to see this rubric when you submit and match your pages to the questions. --- # Rubric (also on [Gradescope](https://www.gradescope.com/courses/335435)) - (+1) Student gives at least a minimum answer to all parts of the guiding question. - (+1) Clear/concise but descriptive examples are given throughout the response. An uninformed reader can create a mental picture of the situation being described. Abstract concepts are explained accurately. - (+1) Student elaborates on the significance and meaning of the examples; why they are important / how it changed their thinking process / implications for future work. - (+1) Extra cred: particularly insightful reflection (rarely given) --- # Gradescope: IMPORTANT Please match all uploaded pages on Gradescope before hitting submit. ![:img Gradescope homework submission interface. The words Doodle Reflection is bolded in black at the top. Below the title is a two-column screen showing a preview of pages the user is submitting on the right and rubric questions on the left. The left column is titled 'Question Outline: Select a Question or a Page'. The rubric questions include: 1) Designs (sketches and storyboards) 3 points 2) Changes from Design 3 points 3) Animating view vs redraw? 3 points 4) Adding Interactivity 3 points 5) Learning from mistakes 3 points 6) Acknowledgments 1 point., 95%, width](img/gradescope_match_page.png) --- # Sample Reflection 1 People said they liked how I used a rainbow gradient effect on my triangle shapes and a bouncing effect to my CircleViews in the animation. People didn’t like the lack of a central aesthetic theme. --- # Sample Reflection 2 My peer reviewers said that they liked the overall use of my object transformations. --- # Sample Reflection 3 Users found my app too jarring; animations were too abrupt to comprehend, part of the text was cut off on the side, and there were intense flashing colors that increased eye strain and might induce seizures. I would change my doodle to have less sudden animations and less contrasting colors. --- # Reflection Answers Reflection 1 (2/3): Provided some detailed descriptions, but could have mentioned the significance of people’s feedback or what they could improve on for future apps. Reflection 2 (1/3): Answers what they got from feedback, but does not provide enough details that would be understandable to an “uninformed reader.” Reflection 3 (3/3): Answered all parts of the question, mentioned how aspects of the app could have negatively impacted the user, and what they would change. --- exclude: true # Possible Extra credit - +1 possible extra credit examples: - I was surprised to learn that some of my peers felt physically sick from watching the animations. - My feedback relates to the lecture on animation pacing; my animation didn’t mimic the real world (objects moving randomly/abruptly), so people may have found it “jarring”. - Next time, I would have a second person give their opinion about my app before putting out a final product to avoid alienating users with my assumptions. --- exclude: true # Tips for Projects moving forwards... - Students should read starter code and understand what all the variables and methods are for, the architecture of the class, the logic of the implementation before starting! - Start EARLY so you can go to OH and utilize Ed - Read the entire spec and write down questions you have about it - Understand the class hierarchy --- exclude: true # Tips for Projects moving forwards... - Students should read starter code and understand what all the variables and methods are for, the architecture of the class, the logic of the implementation before starting! - Start EARLY so you can go to OH and utilize Ed - Read the entire spec and write down questions you have about it - Understand the class hierarchy - What is onCreate() doing? (Check inside the class that extends AppCompatActivity) --- exclude: true # Tips for Projects moving forwards... - Students should read starter code and understand what all the variables and methods are for, the architecture of the class, the logic of the implementation before starting! - Start EARLY so you can go to OH and utilize Ed - Read the entire spec and write down questions you have about it - Understand the class hierarchy - What is onCreate() doing? (Check inside the class that extends AppCompatActivity) - Work through the TODOs. You will not have to work beyond the TODOs. - Reread the spec before turning in --- # Layout Types in Android (1/2) - [FrameLayout](https://developer.android.com/reference/android/widget/FrameLayout) - good for position views on top of each other, or encapsulating a bunch of views. Used in [Doodle](https://courses.cs.washington.edu/courses/cse340/21wi/assignments/doodle.html). - [LinearLayout](https://developer.android.com/reference/android/widget/LinearLayout) - places views one after the other in order according to the orientation (Horizontal or Vertical). Used in [Layout](/assignments/layout). - [RelativeLayout](https://developer.android.com/reference/android/widget/RelativeLayout) - Positions of the children are described in relation to one another --- # Some more Layout Types in Android (2/2) - [TableLayout](https://developer.android.com/reference/android/widget/TableLayout.html) - Rows and columns style way of declaring a layout. Used in Accessibility assignment. - [GridLayout](https://developer.android.com/reference/android/widget/GridLayout.html) - Uses an [*adapter*](https://developer.android.com/reference/android/widget/Adapter) that provides items to display in a grid - [ConstraintLayout](https://developer.android.com/reference/androidx/constraintlayout/widget/ConstraintLayout) Lets you use constraints to specify how things should lay out. Used in [Layout](../../assignments/layout). - More on https://developer.android.com/guide/topics/ui/declaring-layout.html --- # FrameLayout - FrameLayout is designed to block out an area on the screen to display a single item. - Can add multiple children to a FrameLayout and control their position by assigning gravity to each child (android:layout_gravity attribute) - Child views are drawn in a stack, with the most recently added child on top ![:img Challenge for buttons in XML, 20%, width](img/framelayout_1.png) ![:img Challenge with buttons to be added programatically, 20%, width](img/framelayout_2.png) --- # LinearLayout - LinearLayout organizes its children into a single horizontal or vertical row. - Creates a scrollbar if the length of the window exceeds the length of the screen. ![:img Linear layout of an email message with to line subject line and message arranged vertically, 20%, width](img/linearlayout.png) --- # RelativeLayout - Enables you to specify the location of child objects relative to each other (child A to the left of child B) or to the parent (aligned to the top of the parent). ![:img Challenge for buttons in XML, 20%, width](img/relativelayout_1.png) | ![:img Challenge with buttons to be added programatically, 17%, width](img/relativelayout_2.png)| --- # TableLayout - TableLayout arranges its children into rows and columns - Can leave the cells empty - Why choose this over GridLayout? - Not much data, fixed - Will be encountering this in the Accessibility assignment ![:img Challenge for buttons in XML, 40%, width](img/tablelayout_1.png) | ![:img Challenge with buttons to be added programatically, 40%, width](img/tablelayout_2.png)| --- # GridLayout - GridLayout places its children in a rectangular grid - Must define the number of rows and columns first, then populate with Views - Why choose this over TableLayout? - Easy to arrange lots of data because you don’t need to specify each View’s width and height ![:img Challenge for buttons in XML, 20%, width](img/gridlayout_1.png) | ![:img Challenge with buttons to be added programatically, 50%, width](img/gridlayout_2.png)| --- # Constraint Layout .left-column[ ![:img A simple layout on an android watch with a textview and two buttons (save and discard) and the constraints highlighted,150%,width](img/constraint-editor.png) ] .right-column70[ - ConstraintLayout is a ViewGroup that allows you to position widgets in a flexible way - Useful for building responsive interfaces in Android. - You can see little lines connecting the `textView` to its container and it's sibling (the `linearLayout`). - This specifies how it's attached (can change type by clicking on right) - If you were to change the interface (e.g. a different sized screen), it would stay attached and keep filling the space ] --- # Previous exam problem of Layout - Worksheet: https://tinyurl.com/2p8bch66 --- # Worksheet: Interactor Hierarchy What would be the Component Tree for the Layout Part 1-2 program? .left-column50[ ![:img diagram of the interactor hierarchy shown on the next slide in graphic form, 100%,width](img/LayoutSpec.png) ] -- .right-column50[
graph TD LL(LinearLayout) --> S[StatusBar] LL --> RL[RelativeLayout] RL --> SV[ScrollView] RL --> BN[BottomNav] SV --> CL[ConstraintLayout] CL --> V2[ImageView] CL --> V3[...] CL --> V4[ImageView] class LL,RL,SV,CL darkblue class S,SV,BN,V2,V3,V4 blue
] --- # Previous Exam Question Solution **What is the basic idea you have for how to fix it?** > Constrain the top of the scroll to the bottom of the text view. **Which view would you need to modify (provide the value you would set `android:id` to)?** > `@+id/scrollView` **What one line of XML would you add? Pseudocode ok here, you don't have to use exact names.** > `app:layout_constraintTop_toBottomOf="@id/textView"` --- # (Optional) Practice with [Layout Lab](https://github.com/harshitha-akkaraju/layoutlab) - Clone [https://gitlab.cs.washington.edu/cse340/exercises/layoutlab/](https://gitlab.cs.washington.edu/cse340/exercises/layoutlab/) - Switch between the challenges via the `AndroidManifest.xml` - Try getting the four buttons to show on the screen using only XML, then using Java (harder). - [Solution](https://gitlab.cs.washington.edu/cse340/exercises/layoutlab/-/tree/jay-solution-with-comments): don't peek until you've tried first! --- # Section 2 Exercise Take a screenshot of any app and draw the screen's interactor hierarchy. Submit your screenshot and drawing on [Ed Lessons](https://edstem.org/us/courses/16206/lessons/26127/slides/152237).
![:img Exercise example, 50%, width](img/Lab2Ex.jpg)