Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Android Layout design principles [closed]

I have been doing a lot of research on the best ways to design layouts for different screen sizes, screen density and orientations and I am getting increasingly confused.

1. Design Density vs Screen Size
I have read this link

Now when designing for gingerbread what should be considered. Layouts in each folder say LDPI, HDPI and MDPI. But that increases the size of the entire application.

Now i have stopped considering for LDPI. But now we also have XHDPI and XXHDPI. So how do we go about designing for all pages and yet keep the size reasonable?

And what should be given more preference screen size, density or resolution?

FOr images 9-patch images can be used . What is the best tool to create them?

2.Landscape vs Potrait.

Now in this layout equation if we include different layouts for screen orientation, the application becomes bulkier and the work tedious.

Creating smaller xmls and including them is one good solution but even then ,considering all the different types it still becomes tedious. Specially for Android 4 and above with each fragment having a different layout,

My question is-- what is the best and most efficient way to design layouts considering all the above.

like image 808
D-D Avatar asked Dec 20 '22 14:12

D-D


2 Answers

You can try folling links: Question seems to be broad. but you can read this.

  1. Welcome to Android Design,

  2. Is there a standard layout for an Android app or should I design mine from first principles?,

  3. 10 Tips For Android UI Design,

for 9-patch images you can see this post by me.

  1. Utility of android nine patch

  2. Education Guidelines

For supporting multipal device layout based,

please go through Supporting Multiple Screens this link:

For multpal layout component

res/layout/my_layout.xml             // normal screen size ("default")
res/layout-small/my_layout.xml       // small screen size
res/layout-large/my_layout.xml       // large screen size
res/layout-xlarge/my_layout.xml      // Hd tablet

for orientation.

        res/layout/              # default (portrait)
            main.xml
        res/layout-land/         # landscape
            main.xml
        res/layout-large/        # large (portrait)
            main.xml
        res/layout-large-land/   # large landscape
            main.xml


1. You can also use `qualifier` for having multipal resource. 
like image 50
Lavekush Agrawal Avatar answered Dec 22 '22 02:12

Lavekush Agrawal


The Play Store allows you to publish multiple APKs' targeting devices with different hardware. The device property that you are targeting is specified in the manifest of each different APK. For different screen densities, you use the <compatible-screens> element. For instance, an application targeting small-sized devices with ldpi resolution would include:

<compatible-screens>

    <screen android:screenSize="small" android:screenDensity="ldpi" />

</compatible-screens>

In this way, you compile & build different APKs' for the same application targeting different devices, and you include different-sized images in your res/drawable directory depending on the device resolution that each individual APK is aimed at. The different APKs' can be published on the Play Store under the same application heading and will be automatically filtered by the Play Store Services APK (i.e. the Play Store app present on every Android device) based on that device's hardware.

References:

1. Multiple APK Support.

2. Distributing to Specific Screens.

3. Filters on Google Play.

like image 26
Y.S Avatar answered Dec 22 '22 04:12

Y.S