Android开发第3-2课:支持不同的屏幕
来源:互联网 发布:数据流程图的组成要素 编辑:程序博客网 时间:2024/04/28 23:20
This lesson teaches you to
- Create Different Layouts
- Create Different Bitmaps
You should also read
- Designing for MultipleScreens
- Supporting MultipleScreens
- Iconography design guide
Android categorizes device screens using two general properties: size and density. You should expect that your app will be installed on devices with screens that range in both size and density. As such, you should include some alternative resources that optimize your app’s appearance for different screen sizes and densities.
- There are four generalized sizes: small, normal, large, xlarge
- And four generalized densities: low (ldpi), medium (mdpi), high (hdpi), extra high(xhdpi)
To declare different layouts and bitmaps you'd like to use for different screens, you must placethese alternative resources in separate directories, similar to how you do for different languagestrings.
Also be aware that the screens orientation (landscape or portrait) is considered a variation ofscreen size, so many apps should revise the layout to optimize the user experience in eachorientation.
Create Different Layouts
To optimize your user experience on different screen sizes, you should create a unique layout XMLfile for each screen size you want to support. Each layout should be saved into the appropriate resources directory, named with a-<screen_size>
suffix. For example, a unique layout for large screens should be saved underres/layout-large/
.
Note: Android automatically scales your layout in order toproperly fit the screen. Thus, your layouts for different screen sizes don'tneed to worry about the absolute size of UI elements but instead focus on the layout structure thataffects the user experience (such as the size or position of important views relative to siblingviews).
For example, this project includes a default layout and an alternative layout forlargescreens:
MyProject/ res/ layout/ main.xml layout-large/ main.xml
The file names must be exactly the same, but their contents are different in order to providean optimized UI for the corresponding screen size.
Simply reference the layout file in your app as usual:
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main);}
The system loads the layout file from the appropriate layout directory based on screen size of the device on which your app is running. More information about how Android selects theappropriate resource is available in theProviding Resourcesguide.
As another example, here's a project with an alternative layout for landscape orientation:
MyProject/ res/ layout/ main.xml layout-land/ main.xml
By default, the layout/main.xml
file is used for portrait orientation.
If you want to provide a special layout for landscape, including while on large screens, thenyou need to use both thelarge
and land
qualifier:
MyProject/ res/ layout/ # default (portrait) main.xml layout-land/ # landscape main.xml layout-large/ # large (portrait) main.xml layout-large-land/ # large landscape main.xml
Note: Android 3.2 and above supports an advanced method of defining screen sizes that allows you to specify resources for screen sizes based onthe minimum width and height in terms of density-independent pixels. This lesson does not coverthis new technique. For more information, read Designing for MultipleScreens.
Create Different Bitmaps
You should always provide bitmap resources that are properly scaled to each of the generalizeddensity buckets: low, medium, high and extra-high density. This helps you achieve good graphicalquality and performance on all screen densities.
To generate these images, you should start with your raw resource in vector format and generate the images for each density using the following size scale:
- xhdpi: 2.0
- hdpi: 1.5
- mdpi: 1.0 (baseline)
- ldpi: 0.75
This means that if you generate a 200x200 image for xhdpi devices, you should generate the same resource in 150x150 for hdpi, 100x100 for mdpi, and 75x75 for ldpi devices.
Then, place the files in the appropriate drawable resource directory:
MyProject/ res/ drawable-xhdpi/ awesomeimage.png drawable-hdpi/ awesomeimage.png drawable-mdpi/ awesomeimage.png drawable-ldpi/ awesomeimage.png
Any time you reference @drawable/awesomeimage
, the system selects the appropriate bitmap based on the screen's density.
Note: Low-density (ldpi) resources aren’t always necessary. Whenyou provide hdpi assets, the system scales them down by one half to properly fit ldpiscreens.
For more tips and guidelines about creating icon assets for your app, see the Iconography design guide.
- Android开发第3-2课:支持不同的屏幕
- Android开发第3-1课:支持不同的语言
- Android:支持不同的屏幕
- Android开发第3-3课:支持不同的平台版本
- Android官方开发文档Training系列课程中文版:多样屏幕之支持不同的屏幕尺寸
- Android官方开发文档Training系列课程中文版:多样屏幕之支持不同的屏幕密度
- Android应用程序支持大小不同的屏幕
- Android:支持不同分辨率的屏幕设计
- 让android支持不同的语言、屏幕
- Android培训---支持不同的屏幕
- Android Developers:支持不同的屏幕大小
- Android Developers:支持不同的屏幕密度
- Android 支持不同屏幕的方法
- Android支持不同屏幕尺寸的手机
- Android官方文档---支持不同的屏幕
- Android Developers:支持不同的屏幕密度
- 支持不同的屏幕
- 支持不同的屏幕
- 2008新版眼保健操图解
- 合并排序
- Android开发第3-1课:支持不同的语言
- QT不规则窗体图形(代码+详解)
- C#获取当前时间日期
- Android开发第3-2课:支持不同的屏幕
- 分步学习Struts(四) 自己写Struts框架
- [小代码]设置并振动手机
- 详细剖析:ThinkPHP中实例化模型的四种方法详解
- AVRmeg16单片机实现按键控制LCD1602的数据显示
- 《C++程序设计教程》 钱能
- 【IPC通信】基于管道的popen和pclose函数
- JAVA设计模式-Singleton
- Android开发第3-3课:支持不同的平台版本