Home | History | Annotate | Download | only in patterns
      1 page.title=Multi-pane Layouts
      2 @jd:body
      3 
      4 <p>When writing an app for Android, keep in mind that Android devices come in many different screen
      5 sizes and types. Make sure that your app consistently provides a balanced and aesthetically pleasing
      6 layout by adjusting its content to varying screen sizes and orientations.</p>
      7 <p><em>Panels</em> are a great way for your app to achieve this. They allow you to combine multiple views into
      8 one compound view when a lot of horizontal screen real estate is available and by splitting them up
      9 when less space is available.</p>
     10 <h2 id="combining-views">Combining Multiple Views Into One</h2>
     11 
     12 <p>On smaller devices your content is typically divided into a master grid or list view and a detail
     13 view. Touching an item in the master view opens a different screen showing that item's detail
     14 information.</p>
     15 
     16 <img src="{@docRoot}design/media/multipane_views.png">
     17 
     18 <p>Because tablets have more screen real estate than phones, you can use panels to combine the related
     19 list and detail views into a single compound view. This uses the additional space more efficiently
     20 and makes navigating the app easier. </p>
     21 
     22 <img src="{@docRoot}design/media/multipane_view_tablet.png">
     23 
     24 <p>In general, use the pane on the right to present more information about the item you selected in the
     25 left pane. Make sure to keep the item in the left pane selected in order to establish the
     26 relationship between the panels.</p>
     27 <h2 id="orientation">Compound Views and Orientation Changes</h2>
     28 
     29 <p>Screens should have the same functionality regardless of orientation. If you use a compound view in
     30 one orientation, don't split it up when the user rotates the screen. There are several techniques
     31 you can use to adjust the layout after orientation change while keeping functional parity intact.</p>
     32 
     33 <div class="layout-content-row">
     34   <div class="layout-content-col span-8">
     35 
     36     <img src="{@docRoot}design/media/multipane_stretch.png">
     37     
     38   </div>
     39   <div class="layout-content-col span-5">
     40 
     41 <h4>Stretch/compress</h4>
     42 <p>Adjust the column width of your left pane to achieve a balanced layout in both orientations.</p>
     43 
     44   </div>
     45 </div>
     46 
     47 <div class="layout-content-row">
     48   <div class="layout-content-col span-8">
     49 
     50     <img src="{@docRoot}design/media/multipane_stack.png">
     51     
     52   </div>
     53   <div class="layout-content-col span-5">
     54 
     55 <h4>Stack</h4>
     56 <p>Rearrange the panels on your screen to match the orientation.</p>
     57 
     58   </div>
     59 </div>
     60 
     61 <div class="layout-content-row">
     62   <div class="layout-content-col span-8">
     63 
     64     <img src="{@docRoot}design/media/multipane_expand.png">
     65     
     66   </div>
     67   <div class="layout-content-col span-5">
     68 
     69 <h4>Expand/collapse</h4>
     70 <p>When the device rotates, collapse the left pane view to only show the most important information.
     71 Provide an <em>expand</em> control that allows the user to bring the left pane content back to its original
     72 width and vice versa.</p>
     73 
     74   </div>
     75 </div>
     76 
     77 <div class="layout-content-row">
     78   <div class="layout-content-col span-8">
     79 
     80     <img src="{@docRoot}design/media/multipane_show.png">
     81     
     82   </div>
     83   <div class="layout-content-col span-5">
     84 
     85 <h4>Show/hide</h4>
     86 <p>After rotating the device, show the right pane in fullscreen view. Use the Up icon in the action bar
     87 to show the left panel and allow navigation to a different email. Hide the left panel by touching
     88 the content in the detail panel.</p>
     89 
     90   </div>
     91 </div>
     92 
     93 <h2 id="checklist">Checklist</h2>
     94 
     95 <ul>
     96 <li>
     97 <p>Plan in advance on how your app scales to different screen sizes and screen orientations.</p>
     98 </li>
     99 <li>
    100 <p>Identify the most appropriate method for the panels in your compound views to reorganize
    101   themselves when screen orientation changes.</p>
    102 </li>
    103 <li>
    104 <p>Look for opportunities to consolidate your views into multi-panel compound views.</p>
    105 </li>
    106 <li>
    107 <p>Make sure that your screens provide functional parity after the screen orientation
    108   changes.</p>
    109 </li>
    110 </ul>
    111