[Android入门]从零构建Android app之天气——4.App初始化、设计主要结构、封装工具类

通过前面几篇你已经准备好,可以开始输入代码,创建你的应用了。

App初始化

我们要自定义Application

默认情况下,系统会让你的应用使用默认的Application,可以,这很方便。但是实际开发中,我们往往需要在应用程序一进去就开始一些初始化(初始化配置、加载后面要使用的资源)的操作,所以我们需要使用自己的Application。
1. 首先extends Application,目前暂时只在其中初始化异常捕捉

public class ChiceApplication extends Application {

  private static Context context;
  @Override
  public void onCreate() {
    super.onCreate();
    context = this;
//    初始化异常处理类
    CrashHandler.getInstance().init(context);
  }

  //获取系统级Context
  public static Context getAppContext(){
    return context;
  }
}
  1. 在AndroidManifest.xml中把<application>标签的name属性改成我们定义的这个Application。接下来,我们每次启动应用时,系统将初始化我们的ChiceApplication
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
          package="com.chenbing.oneweather">

  <application
    android:name=".ChiceApplication" //就是在这里修改为我们的Application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">
    <activity android:name=".View.activitys.MainActivity">
      <intent-filter>
        <action android:name="android.intent.action.MAIN"/>

        <category android:name="android.intent.category.LAUNCHER"/>
      </intent-filter>
    </activity>
  </application>

</manifest>

编写基类

Activity基类

我们的Activity继承自v7兼容包下的AppComponentActivity。由于v7包提供了更多的特性,并且当今时代,我们并不需要考虑android 2.1之前的兼容性,试问你听说过有谁在用2.1之前的Android机吗?有的用户可能喜欢刷机,但是网上的ROM也基本都是基于android 2.1以上,所以我就直接使用v7兼容包了。

//我们后续创建的Activity都需要继承这个BaseActivity,这样便于以后植入统一的操作。
//不然以后需要统一给Activity进行相同操作时,你就要一个个去改。真蛋疼啊!

//之所以写成抽象,是为了规范约束,提醒你下面几个方法是必要的
public abstract class BaseActivity extends AppCompatActivity {

  //初始化数据请求(不是必须的,习惯了)
  abstract protected void initData();

  //初始化View
  abstract protected void initView();

  //给View添加监听器
  abstract protected void addListener();

}

Fragment基类

Fragment我选择继承v4包的,因为app包下只支持4.4以上,对于现在的Android市场来说太高了。

public abstract class BaseFragment extends Fragment {

  abstract protected void initData();

  abstract protected void initView();

  abstract protected void addListener();
  @Override
  public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
    super.onViewCreated(view, savedInstanceState);
    view.setClickable(true); //让Fragment最底层的View拦截事件,防止扯到蛋的点透
  }
}

BaseRelativeLayout

因为我比较喜欢使用RelativeLayout,所以选择它做View的基类。这个基类可选,主要是为了方便创建自定义View。

public abstract class BaseRelativeLayout extends RelativeLayout {
  public BaseRelativeLayout(Context context) {
    this(context, null);
  }

  public BaseRelativeLayout(Context context, AttributeSet attrs) {
    this(context, attrs, 0);
  }

  public BaseRelativeLayout(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
    bindView();
  }

  private void bindView() {
    LayoutInflater inflater = LayoutInflater.from(getContext());
    inflater.inflate(getLayout(), this, true);
    ButterKnife.bind(this);
  };

  //重写这个方法就能加载布局了。
  abstract protected int getLayout();
}

BaseItemViewHolder

这个是专门为RecyclerView设计的ViewHolder,目的是为了简化ViewHolder的使用。

public class BaseItemViewHolder extends RecyclerView.ViewHolder {
  public BaseItemViewHolder(View itemView) {
    super(itemView);
  }
}

//看看RecyclerView的Adapter现在的变化
@Override
  public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    return new BaseItemViewHolder(new NavigatorItemView(context)); //一句话创建
  }

设计主要架构

本项目我们采用时下流行的MVP框架,现在针对MainActtivity先来进行结构设计。设计结构时需要注意以下几点:
- 遵循依赖倒置原则,即模块应该依赖抽象,而不要依赖具体。这样做的的好处是,单需求发生变化,比如Model需要切换逻辑时,我们只需要换一个实现了同一个接口的实现类就可以,而不用对Presenter修改。同样,当我们现有的一套Presenter和Model需要在另一个View模块上展示时,只要View模块不要求View接口发生变化,我们可以很容易的就把这套东西用到新的View模块上。当然,理论上可行,但实际的Android开发中往往是View模块占据主导地位,至少大多数时候是这样。
- 使用MVP框架其实就已经注定了代码量会增大,所以不能为了省事把Model模块的逻辑、算法代码写到Presenter中。
- 要注意我们的依赖关系。

MVP依赖关系

下面看看View、Model、Presenter的结构。

View模块

//抽象
//我们的Presenter需要依赖的就是这个抽象
public interface MainActivityView extends MvpView {

}

//具体实现
public class MainActivity extends BaseActivity implements MainActivityView {
  private MainActivityPresenterApi presenter;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    presenter = new MainActivityPresenter(this); //初始化Presenter
    //下面调用方法我没有固定,就是为了根据需求变化。当然大多数情况下是这样的。
    initData();
    initView();
    addListener();
  }

  @Override
  protected void initData() {

  }

  @Override
  protected void initView() {

  }

  @Override
  protected void addListener() {

  }
}

Model模块

//抽象
public interface MainActivityModelApi {
}

//实现
public class MainActivityModel implements MainActivityModelApi {
}

Presenter模块

//抽象
public interface MainActivityPresenterApi {
}

//实现
public class MainActivityPresenter implements MainActivityPresenterApi {

  private MainActivityView view; //依赖的是抽象
  private MainActivityModelApi model;

  public MainActivityPresenter(MainActivityView view) {
    this.view = view;
    model = new MainActivityModel(); //创建Model真实对象
  }
}

封装工具类

工具类基本上都是提供一些静态方法供外界调用的。

工具类

根据自己的需要来就行,我暂时封装这么多,有需要再加,具体的到我的GitHub中看。下面我简单介绍下他们的作用。

工具类根据实际开发,可继续不断的扩展添加。

项目地址GitHub

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值