你的位置:首页 > Java教程

[Java教程]零门槛!ZBLibrary仿微信朋友圈自定义View,就是这么简单!


传统方法是继承现有View再重写方法,这种方式缺点很多:

1.往往不能在

2.比较难实现预期效果,比如设置宽度为wrap_content,实际显示为match_parent等;

3.需要在

4.一旦自定义View修改了全路径(移动至其它package、删除等),

5.需要学习draw,measure等平时比较少用的方法;

6.需要维护大量代码,constructor就得重写3个。

使用ZBLibrary自定义View,以上通通不是问题!!!

最终效果图和源码如下

下载试用 TestSelfDefineView.apk

下载源码 TestSelfDefineView.zip

 

 

如何使用ZBLibrary自定义View

一、准备

1.依赖ZBLibrary

 

2.分别复制DemoView,demo_view,KeyValueBean到你自己项目的对应目录下 

二、使用

这里以MainActivity和MainActivity的界面布局activity_main做示范

1.在activity_main中的根布局(最外层布局)内添加以下代码

 <LinearLayout

        android:id="@+id/llMainContainer"

        android:layout_width="match_parent"

        android:layout_height="match_parent"

        android:orientation="vertical" >

 </LinearLayout>

 

  

2.添加以下代码到MainActivity的onCreate方法或者它里面调用的方法中。

 

ImageLoaderUtil.init(this);

 

LinearLayout llMainContainer = (LinearLayout) findViewById(R.id.llMainContainer);

llMainContainer.removeAllViews();

 

DemoView demoView = new DemoView(this, null);

llMainContainer.addView(demoView.getView());

 

KeyValueBean data = new KeyValueBean("KEY", "123");

demoView.setView(data);

 

 

3.修改复制过来的DemoView中的KeyValueBean路径为你项目中的路径,这里为 com.example.testselfdefinview.KeyValueBean,然后运行看效果

 

  

三、修改

1.分别改名称为你需要的,这里分别改为MyView,MyBean,my_view以作示范。

 

 

2.将MyView中import zuo.biao.library.R;中的zuo.biao.library路径替换为你项目的路径。

 

3.将MyView中的demo_view改为my_view;将MainActivity,MyView,my_view中的"DemoView"全部改为"MyView"。

 

4.运行测试。如果出现问题,检查以上步骤。

 

5.到这一步,将MyView看成一个Activity,将my_view看成这个Activity的界面布局,然后修改MyView,MyBean,my_view代码为你想要的,就这么简单!

 

附源码(含使用方法)

GitHub源码      https://github.com/TommyLemon/Android-ZBLibrary 
开源中国源码    http://git.oschina.net/Lemon19950301/Android-ZBLibrary 

 

注:ZBLibrary自定义View方式不是万能的,实现一些特殊功能还是要用继承现有View的方式,不过在大多数情况下ZBLibrary都能用并且比继承现有View好很多。