AyoActivityNoManifest - Activity 代理框架
软件简介
1 这是什么?
-
这个库提供了:
-
一个轻量级的Activity代理框架(ActivityAttacher,使用方式基本和Activity一样),目的在于不必在Manifest反复声明Activity
-
同时提供了一个轻量级的Bundle机制(SimpleBundle,使用方式基本和Bundle一样),目的在于在Activity之间传递参数时考虑序列化问题,适用于进程内通信
-
提供了一个轻量级的OnActivityResult机制(OnResultCallback,使用方式基本和OnActivity不一样)
-
状态栏一体化的简单封装
-
Activity和Fragment状态保存的问题
-
其他Activity和Fragment问题的解决方案,后期一个一个加
-
2 ActivityAttacher的使用
(1) manifest
-
manifest里只需要声明:
-
主Activity
-
有特殊需求的Activity,如支持旋转
-
模板Activity,暂时只支持一个启动模式对应一个模板Activity
-
模板Activity有几个默认配置项,如果需要更改,也需要声明自己的Activity
-
Manifest中的声明:
<activity
android:name="com.cowthan.sample.MainActivity"
android:configChanges="orientation|screenSize|keyboardHidden|navigation"
android:screenOrientation="portrait"
android:theme="@style/AppTheme"
>
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name="org.ayo.app.base.TmplActivityStandard"
android:configChanges="orientation|screenSize|keyboardHidden|navigation"
android:screenOrientation="portrait"
android:launchMode="standard"
android:theme="@style/AyoTransparentTheme" />
<activity
android:name="org.ayo.app.base.TmplActivitySingleTask"
android:configChanges="orientation|screenSize|keyboardHidden|navigation"
android:screenOrientation="portrait"
android:launchMode="singleTask"
android:theme="@style/AyoTransparentTheme" />
<activity
android:name="org.ayo.app.base.TmplActivitySingleTop"
android:configChanges="orientation|screenSize|keyboardHidden|navigation"
android:screenOrientation="portrait"
android:launchMode="singleTop"
android:theme="@style/AyoTransparentTheme" />
<activity
android:name="org.ayo.app.base.TmplActivitySingleInstance"
android:configChanges="orientation|screenSize|keyboardHidden|navigation"
android:screenOrientation="portrait"
android:launchMode="singleInstance"
android:theme="@style/AyoTransparentTheme" />
(2) ActivityAttacher
-
ActivityAttacher的意义:
-
ActivityAttacher就是附着在上面4个模板Activity里的Activity代理
-
ActivityAttacher中持有一个Activity实例对象,是在onCreate时赋值的
-
ActivityAttacher可以处理Activity中的所有配置和生命周期
-
ActivityAttacher提供的接口,原则上应该完全仿Activity,这一点类似v7源码中的和AppCompactActivity相关的一个delegate类,但不知道这个类是干什么用的
-
看代码,这两个只有基类不一样,内部代码应该是一样的,其中继承AyoActivity的是一个普通Activity,需要去manifest声明,
而继承AyoActivityAttacher,就不需要再去manifest声明了
public class SampleActivity extends AyoActivityAttacher{
public static void start(Context c, boolean takeSystemBar, int lanuchMode, OnResultCallBack callBack){
SimpleBundle sb = new SimpleBundle();
sb.putExtra("takeSystemBar", takeSystemBar);
ActivityAttacher.startActivity(c, SampleActivity.class, sb, false, lanuchMode, callBack);
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.ac_tmpl);
}
}
public class SampleActivity extends AyoActivity{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.ac_tmpl);
}
}
(4) 启动ActivityAttacher
启动方式变成这样:
public static void start(Context c, boolean takeSystemBar, int lanuchMode, OnResultCallBack callBack){
SimpleBundle sb = new SimpleBundle();
sb.putExtra("takeSystemBar", takeSystemBar);
ActivityAttacher.startActivity(c, SampleActivity.class, sb, false, lanuchMode, callBack);
}
-
SimpleBundle:功能类似于intent或者bundle,存的是传到下一个Activity的参数
-
取出参数:
boolean takeSystemBar = getIntent().getBooleanExtra("takeSystemBar");
-
这里,在Activity之间传的都是引用,不再需要考虑序列化问题,当然只适用于app单进程内
-
-
OnResultCallBack是接收Activity的回传结果
- 如何回传:
getResultCallback().onResult("代替OnActivityReslt和setResult"); finish();
- 如何回传:
-
lanuchMode是选择Activity的启动模式,也就是选择模板:
-
ActivityAttacher.LAUNCH_MODE_STANDARD
-
ActivityAttacher.LAUNCH_MODE_SINGLE_TASK
-
ActivityAttacher.LAUNCH_MODE_SINGLE_TOP
-
ActivityAttacher.LAUNCH_MODE_SINGLE_INSTANCE
-
(5) Activity主题
这里提供了两个主题:AyoTransparentTheme和AyoTheme,没啥特殊的