This is a basic android question. I have app which need to have different screen design for a phone and a tablet. The phone needs to have a ListView and the Tablet need to have a GridView of items.
I wish to know how can I do this without making two different apps.
Thanks
Basically you have to make different layouts for both android phone and tablets. Android is smart enough to differentiate. For example for large screen you can just make a new folder namer Layout-large. and put your tablet xml in it. Android will pick xml from here and in case of phone it will pick from simple layout folder.
The configuration qualifiers you can use to provide size-specific resources are small, normal, large, and xlarge. For example, layouts for an extra large screen should go in layout-xlarge/.
I would recommend if both phone and tablet screens and totally different you can make two different apks and load on same Id on google play. This way your application will be light weight and will be be fast. Google play automatically can detect that application is for tablet or or phone.You need not to worry about that.
You basically need to provide different layout files for different qualifiers.
As a very brief example, xml layout files places in the layout-sw720dp
(or layout-large
for API level < 13) folder will be used for devices more than 720 dips wide (i.e. 10" tablets).
Check Supporting Multiple Screens and Providing Resources in the Android documentation.
Check this out : http://developer.android.com/guide/practices/screens_support.html
You do not need to make two separate apps.
Here is what I did for the same changing the Recycler View's "app:layoutManager" attribute. Since you are using a list and grid view using the recycler view seems to be the best way to have your scrolling smoothly.
- Create a folder in res "layout-sw600dp".
- Copy the layout file to this folder.
In the original layout file which is in the layout folder, set linear layout manager as the layout manager attribute.
<android.support.v7.widget.RecyclerView
app:layoutManager="android.support.v7.widget.LinearLayoutManager"/>
In the "layout-sw600dp" folder layout file, set GridLayoutManager as the Recycler View attribute.
<android.support.v7.widget.RecyclerView
app:layoutManager="android.support.v7.widget.GridLayoutManager"/>
Do not forget to change the span count because it defaults to a 0 which will be same as the output of the liner layout.
Resources:
How to set RecyclerView app:layoutManager="" from XML?
https://medium.com/google-developers/building-a-responsive-ui-in-android-7dc7e4efcbb3
https://developer.android.com/training/multiscreen/screensizes.html