启动Activity并传递参数
Extra
正常情况下启动Activity并且传递参数的代码:
Intent intent = new Intent(context,LoginActivity.class); intent.putExtra("phone","123456); intent.putExtra("pwd","123456); startActivity(intent);
使用Blade启动Activity的方式
public class LoginActivity extends AppcompatActivity{ @Extra String mText; @Extra MyData mData; }
通过上面的代码就会自动生成一个如下两个方法
Intent forX(Context c, T1 extra1[, T2 extra2, ...]) void startX(Context c, T1 extra1[, T2 extra2, ...])
然后我们就可以直接通过 I.startLoginActivity 来启动Activity。
创建Fragment实例
@Arg
用来为Fragment生成newInstance方法
通常我们创建Fragment对象都是些如下的样板代码
public class MyFragment extends Fragment{ public MyFragment newInstance(String data){ MyFragment fragment = new MyFragment(); Bundle bundle = new Bundle(); bundle.putExtra("data",data); fragment.setArguments(bundle); return fragment; } ... }
使用Blade的方式
public class MyFragment extends Fragment { @Arg String mText; @Arg MyData mData; }
自定义序列化
public class MyFragment extends Fragment { @Arg(MyTypeBundler.class) MyType mMyType; } public class MyTypeBundler implements Bundler<MyType> { void save(@Nullable final MyType value, @NonNull final Bundle state) { // save given value to the state } @Nullable MyType restore(@NonNull final Bundle state) { // restore and return value from state } }
@Parcel
当我们创建一个实体类需要实现Parcelable的时候,可以按如下的方法写
@blade.Parcel public class MyClass implements Parcelable { String text; int number; boolean flag; double[] doubleArray; protected MyClass(Parcel in) { } @Override public int describeContents() { return 0; } @Override public void writeToParcel(Parcel dest, int flags) { } }
如果某个字段想忽略,不需要被序列化的话,使用 @blade.ParcelIgnore
Mvp
Mvp是和Dager配合使用的。
第一步:在你的build.gradle中添加dager依赖
compile 'com.google.dagger:dagger:2.x' apt 'com.google.dagger:dagger-compiler:2.x'
第二步:创建一个继承自IView的接口
public interface IMyView extends blade.mvp.IView { void show(String something); }
第三步:创建Prensenter和View接口相互影响
public class MyPresenter extends blade.mvp.BasePresenter<IMyView> { public void onUserDidSomething() { String s = // do something ... if (getView() != null) { getView().show(s); } } //... }
第四步:创建View的实现,使用@Inject注入Presenter,现在支持Fragmnt,Activit,View
public class MyView extends android.support.v4.app.Fragment implements IMyView { @Inject MyPresenter mPresenter; @Override public void onViewCreated(View view, @Nullable Bundle savedInstanceState) { super.onViewCreated(view, savedInstanceState); yourDaggerComponent.inject(this); } @Override void show(String something) { /* ... */ } // ... }
第五步:Activity中包含存在Presenter的Fragment,View,那么该Activity需要使用@Blade注解一遍让Blade知道。
State
简化状态管理, @State 注解会生成一个帮助类,里面包含两个静态的方法:
public class StateArgFragment extends Fragment { @Arg @State int num; } @Weave( into = "0_onSaveInstanceState", args = {"android.os.Bundle"}, statement = "eu.f3rog.blade.sample.state.StateArgFragment_Helper.saveState(this, $1);" ) public static void saveState(StateArgFragment target, Bundle state) { if (state == null) { throw new IllegalArgumentException("State cannot be null!"); } BundleWrapper bundleWrapper = BundleWrapper.from(state); bundleWrapper.put("<Stateful-num>", target.num); } @Weave( into = "1^onCreate", args = {"android.os.Bundle"}, statement = "eu.f3rog.blade.sample.state.StateArgFragment_Helper.restoreState(this, $1);" ) public static void restoreState(StateArgFragment target, Bundle state) { if (state == null) { return; } BundleWrapper bundleWrapper = BundleWrapper.from(state); target.num = bundleWrapper.get("<Stateful-num>", target.num); }
继承自Fragment、Activity或View的类都会自动管理状态。自定义序列化的功能如上所示。
Blade可以让我们少写很多的样板代码,具体的我还没有应用到项目中,之后会在项目中进行使用,用来使项目看起来更加清晰。
Blade地址: https://github.com/FrantisekGazo/Blade
总结
以上所述是小编给大家介绍的Android中Blade的使用方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
本文向大家介绍Android中html.fromhtml的使用方法,包括了Android中html.fromhtml的使用方法的使用技巧和注意事项,需要的朋友参考一下 Android中html.fromhtml 在android中,有一个容易遗忘的Html.fromhtml方法,意思是可以将比如文本 框中的字符串进行HTML格式化,支持的还是很多的, 但要注意的是要在string.xml中用<
// 区块占位 @yield('name') // 扩展布局模板 @extends('layout.name') // 实现命名为 name 的区块(yield 占位的地方) @section('name') @stop // 可继承内容区块 @section('sidebar') @show // 继承父模板内容(@show 的区块内容) @parent // 包含子视图 @include('v
Blade 是一款追求简约、高效的 Web 框架,让 JavaWeb 开发如虎添翼,在性能与灵活性上同时兼顾。 功能特性 [x] 新一代MVC框架,不依赖更多的库 [x] 摆脱SSH的臃肿,模块化设计 [x] 源码不到 500kb ,学习也简单 [x] Restful风格路由设计 [x] 模板引擎支持,视图开发更灵活 [x] 高性能,100并发下qps 14w/s [x] 运行 JAR
Blade 是一款追求简约、高效的 Web 框架,让 JavaWeb 开发如虎添翼,在性能与灵活性上同时兼顾。 功能特性 [x] 新一代MVC框架,不依赖更多的库 [x] 摆脱SSH的臃肿,模块化设计 [x] 源码不到 500kb ,学习也简单 [x] Restful风格路由设计 [x] 模板引擎支持,视图开发更灵活 [x] 高性能,100并发下qps 14w/s [x] 运行 JAR
本书共有四个部分,九个章节,全面介绍如何基于 Blade 框架快速搭建一个 web 应用。 第一部分是快速上手和入门 Blade以及Web开发的基础知识,这部分在第一章; 第二部分讲解一个 Blade 应用的项目结构和核心概念,包含核心对象,数据库操作,模板引擎等。这部分内容在第二章至第六章; 第三部分手把手带大家实现一个在线图片社交的web应用,将前面讲解的 Blade 知识融会贯通,真正做一个
本文向大家介绍Android 中Context的使用方法详解,包括了Android 中Context的使用方法详解的使用技巧和注意事项,需要的朋友参考一下 Android 中Context的使用方法详解 概要: Context字面意思是上下文,位于framework package的android.content.Context中,其实该类为LONG型,类似Win32中的Handle句柄。很多方法