# [CSE 340](/courses/cse340/23wi/schedule.html) Lab 2 Winter 23 ## Week 2: Finishing Doodle, Introducing Layout .title-slide-logo[ data:image/s3,"s3://crabby-images/7cae3/7cae3585119b52331102e31a5d2baeeed0bfb350" alt=":img Android phone showing a linear layout of TODOs on a calendar, 15%, width" ] --- # 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 data:image/s3,"s3://crabby-images/6c6d2/6c6d271784719339fdd78f390d4bdf8fdb340e68" alt=":img Challenge for buttons in XML, 20%, width" data:image/s3,"s3://crabby-images/a112a/a112a4380200ae43036343c95053a42990bd448f" alt=":img Challenge with buttons to be added programatically, 10%, width" --- # LinearLayout - LinearLayout organizes its children into a single horizontal or vertical row. - Wrap it in a `ScrollView` to create a scrollbar if the length of the window exceeds the length of the screen. data:image/s3,"s3://crabby-images/775ca/775cacb2e34a8c4e0287bd5a2b6f9dbea9ed264c" alt=":img Linear layout of an email message with to line subject line and message arranged vertically, 15%, width" data:image/s3,"s3://crabby-images/60f7a/60f7a650de9f4bac344cd086002100c13994a53f" alt=":img Horizontal Linear Layout where the screen shows several bars stacked in a horizontal line, 15%, width" data:image/s3,"s3://crabby-images/4cae8/4cae8800f10976a3415330e98edf60af0171eaa6" alt=":img Vertical Linear Layout where the screen shows several bars stacked on top of each other vertically, 15%, width" --- # 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). data:image/s3,"s3://crabby-images/9dfac/9dfaca771b4db2512120e834cc1cb2a9f2d9fefb" alt=":img Challenge for buttons in XML, 15%, width" data:image/s3,"s3://crabby-images/09b36/09b36341a6cae6542f61ce755c75f0b1b809b538" alt=":img Challenge with buttons to be added programatically, 17%, width" --- # TableLayout - Added in API 1 - TableLayout arranges its children into rows and columns - Can leave the cells empty - Found in the Accessibility assignment base code data:image/s3,"s3://crabby-images/34cfe/34cfea1d3f150ea9f9f8e3d83da3e4b54f063795" alt=":img Challenge for buttons in XML, 35%, width" data:image/s3,"s3://crabby-images/8f645/8f64567f35ed85e3b2c279016dd370a3477c7ee3" alt=":img Challenge with buttons to be added programatically, 20%, width" --- # 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 - [Preferable](https://android-developers.googleblog.com/2011/11/new-layout-widgets-space-and-gridlayout.html) to TableLayout (GridLayout added API 14) data:image/s3,"s3://crabby-images/e9543/e9543cd7c68f0543143c09c664d96c8e4318d2ea" alt=":img Challenge for buttons in XML, 10%, width" data:image/s3,"s3://crabby-images/eac19/eac196ae06954a3e075b06e4155294555af3736f" alt=":img Challenge with buttons to be added programatically, 30%, width" --- # Constraint Layout .left-column[ data:image/s3,"s3://crabby-images/a067a/a067a08ff291ad8261995165b01fc6d2db9456ee" alt=":img A simple layout on an android watch with a textview and two buttons (save and discard) and the constraints highlighted,150%,width" ] .right-column70[ - 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 ]