Skip to content

themores/AntCaves

Repository files navigation

AntCaves

Android Router 框架,取名为AntCaves,中文名”蚁穴“。

关于名字的一个故事

说起名字的由来,得从大四那年在武汉学车的时候。记得是学科目二的时候一个下午,在学车地方看到了一个蚂蚁窝。虽然小时候经常看到蚂蚁窝, 但是经过4年计算机技术体系的学习,对软件架构有了一定的认知。于是对蚂蚁窝的建筑架构有了一定的兴趣,当时把一个蚂蚁洞口堵住,完全不影响其他洞口的工作。 不得不佩服,蚂蚁间的工作车间的解藕,分工明确。道路四通八达,互不影响,他们的架构思维远远超过大多数软件研发。于是当时就跟同学说蚁穴的架构思想。 工作契机,于是正好有机会实现这一想法。 题外话,佩服的动物莫过于蚂蚁,最佩服的人莫过于唐朝郭子仪。

如何导入?

step1:在project build.gradle 文件中添加如下仓库

allprojects {
    repositories {
        jcenter()
        maven { url 'https://jitpack.io' }
    }
}

step2:在项目module中build.gradle 添加如下引用(如果是多module 的情况下,在不同的module下同样添加以下引入)

  compile 'com.github.themores.AntCaves:antcaves:lastVersion'
  compile 'com.github.themores.AntCaves:annotation:lastVersion'

其中最新版本lastVersion = 1.2.2

如何使用?

1.初始化

1.注册module

在module中,常见为app_module,在Application类或者新建一个类,添加注解。

@Modules(module = "app")
public class App extends Application {
    @Override
    public void onCreate() {
        super.onCreate();
    }
}

同时在主module 上的任意一个类 上添加该注解module 的名字

@Module(module = "app")

然后在对应的activity添加path 即可。

@Router(path = "activity/about") 

//如果在Router 注解中添加了module = "xxx", 以这个成为module名字。 2.build项目 3.重写Application类,在其onCreate()方法中初始化,添加

AntCavesSDK.init();

2.说明

关于path,必须遵循http url形式。如:module://activity/about

关于参数param,必须遵循key->type(基本数据类型+String)的形式进行规范。如:id->int,name->String,isClose->boolean

3.多种方式添加path

step1:注解的方式添加

@Router(path = "activity/about", param = {"id->int", "name->String"})
public class AboutActivity extends Activity {
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        Toast.makeText(this, getIntent().getStringExtra("name") + "", Toast.LENGTH_LONG).show();
        Toast.makeText(this, getIntent().geIntExtra("id", 0) + "", Toast.LENGTH_LONG).show();
    }
}
        注解             参数           请求       
@Router(path="activity/about") 无参数 module://activity/about
@Router(path="activity/about",param="id->int") 1个参数 module://activity/about?id=123
@Router(path="activity/about",param={"id->int","name->String"}) 多个参数 module://activity/about?id=123&name=ant

step2:代码的方式添加 (无参数)

AntCavesRouter.addRouter("module://activity/about",Activity.class)

(有参数)

List<String> paramList = Arrays.asList("id->int","name->String");
AntCavesRouter.addRouter("module://activity/about",paramList,Activity.class);

4.最常见的跳转方式

AntCavesRouter.getInstance().prepare(Activity.this, path).go();

5.支持传递Object序列化

User:

public class User implements Serializable {
    private int id;
    private String name;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

A->B

A:
User user = new User();
user.setId(10086);
user.setName("this is a object");
AntCavesRouter.getInstance().prepare(Activity.this, path).equipExtra("user", user).go();

B:
User user = (User) getIntent().getSerializableExtra("user");

6.支持跳转事件回调

通过跳转事件回调,得知是否跳转成功/失败/被拦截

 AntCavesRouter.getInstance().prepare(Activity.this, path).go(new IAntCallBack() {
            @Override
            public void onLost(Context context, String message) {
            }

            @Override
            public void onArrival(Context context, String message) {

            }

            @Override
            public void onInterceptor(Context context, String message) {

            }
        });

7.支持startActivityForResult和setResult跳转方式

A->B->A
A->B: int requestCode = 1;
      AntCavesRouter.getInstance().prepare(this, "activity://aba").go(requestCode);
      
B->A: setResult(RESULT_OK,intent);

A: 
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    //from B 
}

8.支持添加拦截处理

自定义添加拦截器 CustomInterceptor extends Interceptor

public class CustomInterceptor extends Interceptor {
    @Override
    public void process(Context context, String path, IInterceptorCallBack iInterceptorCallBack) {
     //do something: show Dialog,intent to another Activity etc.
   }
}

添加拦截器

AntCavesRouter.getInstance().prepare(Activity.this, path).addInterceptor(new CustomInterceptor()).go();

9.支持多module方式

1.注册多module 在主module中,常见为app_module,在Application类或者新建一个类,添加注解。

@Modules(module = {"app", "demo"})
public class App extends Application {
    @Override
    public void onCreate() {
        super.onCreate();
    }
}

同时在主module 上的任意一个类添加改注解module 的名字

@Module(module = "app")

同样在其他module 上任意一个类上添加改注解module 的名字

@Module(module = "demo")

然后对应的activity 添加路径即可。

@Router(path = "activity/demo")

10.API使用说明(具体使用请看demo)

        API       说明           例子       
prepare(Context context, String path) 组装/呼叫一个Ant 小蚂蚁 AntCavesRouter.getInstance().prepare(context,path)
go() module内部跳转 AntCavesRouter.getInstance().prepare(context,path).go()
go(int requestCode) module内部跳转A->B->A形式 AntCavesRouter.getInstance().prepare(context,path).go(requestCode)|
cross() module之间进行跳转 AntCavesRouter.getInstance().prepare(context,path).cross()
cross(int requestCode) module之间进行跳转A->B->A形式 AntCavesRouter.getInstance().prepare(context,path).cross(requestCode)
addInterceptor(Interceptor customInterceptor) 添加拦截器,让小蚂蚁改变路线或者停止跑路 AntCavesRouter.getInstance().prepare(context,path).addInterceptor(new CustomInterceptor()).cross()
interceptor() 停止小蚂蚁跳转拦截方法 IInterceptorCallBack.interceptor()
interceptor(String path) 改变小蚂蚁跳转的路线 IInterceptorCallBack.interceptor(path)

混淆配置

-dontwarn com.google.**
-dontwarn com.squareup.**
-dontwarn com.antcaves.**

迭代优化

1.暂时不支持跨进程 2.日志打印优化 3.代码规范优化

感谢

感谢ActivityRouter作者曹神,ARouter作者Alex,Sixgod六神,Tom神,Camel神的技术和精神支持。

联系:

个人邮箱:[email protected] 加群沟通:284430347