AyoActivityNoManifest 介绍
-
这个库提供了:
-
一个轻量级的Activity代理框架(ActivityAttacher,使用方式基本和Activity一样),目的在于不必在Manifest反复声明Activity
-
同时提供了一个轻量级的Bundle机制(SimpleBundle,使用方式基本和Bundle一样),目的在于在Activity之间传递参数时考虑序列化问题,适用于进程内通信
-
提供了一个轻量级的OnActivityResult机制(OnResultCallback,使用方式基本和OnActivity不一样)
-
状态栏一体化的简单封装
-
Activity和Fragment状态保存的问题
-
其他Activity和Fragment问题的解决方案,后期一个一个加
-
-
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" />
-
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); } }
启动方式变成这样:
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
-
这里提供了两个主题:AyoTransparentTheme和AyoTheme,没啥特殊的