重拾Android之路之开发准备


引言

本篇内容就整理一下开发Android的琐事细节。

主要分为以下几个主题:

  • Android固定横屏、竖屏
  • 横竖屏切换的问题
  • AppTheme属性设置集合
  • Android Theme 主题总结

Android固定横屏、竖屏

要实现这个目的,只需要在AndroidManifest.xml里声明Activity的时候加上一个属性:

android:screenOrientation="portrait"

属性取值landscape为固定横屏、portrait为固定竖屏。

上面的方式是通过修改AndroidManifest.xml的属性来修改每个activity的横竖屏设置。

下面来看看代码设置横竖屏:

setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);

对于单个Activity禁用横竖屏切换是很简单的,但是实际项目中会有很多的Activity,如果每个都设置一下就太麻烦了。有没有一处设置全局有效的方法呢?答案是有的,只要对第二种方式稍微改造一下即可。我们可以写一个如下的BaseActivity类:

import android.app.Activity;
import android.content.pm.ActivityInfo;
import android.os.Bundle;

public class BaseActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
    }
}

让其它的Activity都继承这个BaseActivity类就能实现全局禁用横竖屏切换了。实际开发中常用这种方法,不仅仅是用来设置横竖屏,还有其它的公共功能也可以写在BaseActivity中。继承确实是个好东西。


横竖屏切换的问题

屏幕自动切换时,默认状态的应用程序,会重新调用onCreate,相当于重新启动了一次应用程序。

同时,layout可能因为横屏带来不能合理适配的问题。为了解决旋屏和键盘切换引起的程序重启问题,还需要增加一个属性:android:configChanges。

这个属性可以理解为一个监听器,它将拦截旋屏和键盘切换事件,阻止程序重启而变为回调onConfigurationChanged方法。这里常用的属性取值为:keyboardHidden|orientation

android:configChanges="screenSize|keyboardHidden|orientation"
android:screenOrientation="sensor"    //sensor:旋屏,可切换横竖屏

AppTheme属性设置集合

现在新建一个项目基本都会在 style.xml 设置基础的 AppTheme,但是系统的给提供的设置属性又比较多。

所以在此收集记录,以便之后查找方便。


重拾Android之路之开发准备_第1张图片

Android Theme 主题总结

简介:主题决定了App的展示效果,我们可以为整个Application指定主题,也可以为Activity单独指定主题,甚至可以为各个控件如Button、TextView指定主题。下面对Android Theme的引用方式,版本分类进行列举,并对兼容包主题进行了归类、总结。期望达到对Theme有一个总体的清晰的认识。

一、Theme的来源分类

  1. 系统的主题
  2. 第三方库的主题
  3. 兼容包如support_v7.jar的主题
  4. 用户自定义的主题

二、引用方式

  • 系统主题: "@android:style/Theme.Holo.Light"
  • 兼容包: AndroidManifests.xml中"@style/Theme.Appcompat",其他地方使用“Theme.Appcompat”即可
  • 自定义主题:"@style/AppTheme"

三、Theme的版本分类

  1. android:Theme API 1 开始
  2. android:Theme.Holo API 11(android3.0) 开始
  3. android:Theme.DeviceDefault API 14(android4.0) 开始
  4. android:Theme.Material API 21(android5.0) 开始
  5. Theme.AppCompat 兼容包AppCompat_v7中的主题

主题的不同版本:

Theme:

  • Theme 深色主题
  • Theme.Light 浅色主题

位置:sdk/platforms/android-25/data/res/values/themes.xml
简介:许多主题的最终父类主题

Theme.Holo:

  • Theme.Holo 深色主题
  • Theme.Holo.Light 浅色主题

位置:sdk/platforms/android-25/data/res/values/themes_holo.xml
简介:android 11 - 13 的默认主题

Theme.DeviceDefault:

  • Theme.DeviceDefault 深色主题
  • Theme.DeviceDefault.Light 浅色主题

位置:sdk/platforms/android-25/data/res/values/themes_device_defaults.xml
简介:android 14以上的默认主题,在不同系统版本的设备上可以提供不同的样式

Theme.Material:

  • Theme.Material 深色主题
  • Theme.Material.Light 浅色主题

位置:sdk/platforms/android-25/data/res/values/themes_material.xml
简介:Material Design的样式

Theme.Leanback :

位置:sdk/platforms/android-25/data/res/values/themes_leanback.xml
简介:不知道是什么主题,暂且罗列在此

AppCompat_v7兼容包主题细分:
(以'com.android.support:appcompat-v7:25.1.0'为例:)

  • AlertDialog.AppCompat 对话框深色
  • AlertDialog.AppCompat.Light 对话框浅色
  • Animation.AppCompat.Dialog 带动画效果的对话框
  • Animation.AppCompat.DropDownUp
  • Theme.AppCompat 作用于Activity层面以上的主题
  • Base、Platform 作为父类被继承的,一般不直接使用
  • RtlOverlay.Widget.AppCompat
  • RtlUnderlay.Widget.AppCompat
  • TextAppearance.AppCompat 文字样式相关
  • ThemeOverlay.AppCompat
  • Widget.AppCompat 控件相关的主题

关于Theme.ApCompat兼容主题
主题间的继承关系:(以Theme.AppCompat为例)
Theme.AppCompat ——> Base.Theme.AppCompat
Base.Theme.AppCompat ——> Base.V.Theme.AppCompat (可能是7、21、23等)
Base.V*.Theme.AppCompat ——> Platform.AppCompat
Platform.AppCompat ——> android:Theme
其中第二步:版本25.1.0有四种选择:Base、Base.V21、Base.V22、Base.V23。(更早的版本还有V7、V11等)
兼容:App在运行时会根据系统的版本选择对应的父类主题。大于21选择V21,大于22选择V22

例如:使用DatePicker、CalendarView等在不同版本手机上安装会展示不同的样式,在4.2的手机上展示holo的样式,在5.1的手机上展示material样式。

App的UI一致性:不少App为了保证在不同手机上的UI一致性,会给控件显式指定样式,为了向下兼容,通常会使用holo样式,并做一下调整。

系统通常预定义的主题样式

  • Theme.AppCompat 深色主题
  • Theme.AppCompat.NoActionBar 没有ActionBar
  • Theme.AppCompat.Dialog 对话框适用
  • Theme.AppCompat.Dialog.Alert 警告框适用(根据屏幕决定宽度)
  • Theme.AppCompat.Dialog.MinWidth 对话框适用(根据内容决定宽度)
  • Theme.AppCompat.DialogWhenLarge 充满屏幕(继承自Theme.AppCompat,但没有扩展)
  • Theme.AppCompat.CompactMenu 看名字是用于Menu菜单。未验证
    其他主题系统默认都会有上述几种类型的子主题,以此类推就好。
    例如:浅色主题只需要将Theme.AppCompat 替换成 Theme.AppCompat.Light即可

常见的样式属性摘记

  • android:windowFullscreen 隐藏状态栏
  • windowActionBar 是否显示ActionBar
  • windowNoTitle 是否显示TitleBar,经常和windowActionBar一起使用

你可能感兴趣的:(重拾Android之路之开发准备)