# KJFrameForAndroid
**Repository Path**: coolbole/KJFrameForAndroid
## Basic Information
- **Project Name**: KJFrameForAndroid
- **Description**: KJFrameForAndroid的设计思想是通过封装Android原生SDK中复杂的复杂操作而达到简化Android应用级开发,最终实现快速而又安全高效的开发APP。我们的目标是用最少的代码,完成最多的操作,用最高的效率,完成最复杂的功能。
- **Primary Language**: Unknown
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: http://www.kymjs.com
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 181
- **Created**: 2015-04-03
- **Last Updated**: 2020-12-19
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
## KJFrameForAndroid简介
=================
[](http://android-arsenal.com/details/1/836)
[](https://www.openhub.net/p/KJFrameForAndroid)
[](http://www.oschina.net/p/kjframeforandroid)
**KJFrameForAndroid** 又叫KJLibrary,是一个Android的快速开发工具包。同时封装了android中的Bitmap、Http、插件模块加载操作的框架,使开发者更容易轻松实现这些功能;
KJFrameForAndroid的设计思想是通过封装Android原生SDK中复杂的复杂操作而达到简化Android应用级开发,最终实现快速而又安全高效的开发APP。我们的目标是用最少的代码,完成最多的操作,用最高的效率,完成最复杂的功能。
## KJFrameForAndroid 相关链接
* blog:http://blog.kymjs.com
* QQ群:[257053751](http://jq.qq.com/?_wv=1027&k=WoM2Aa)(开发者群1),[201055521](http://jq.qq.com/?_wv=1027&k=MBVdpK)(开发者群2)
* 项目API文档:[在线API文档](https://KJFrame.github.io)
* github项目地址:[https://github.com/kymjs/KJFrameForAndroid](https://github.com/kymjs/KJFrameForAndroid)
* 版本日志 [http://git.oschina.net/kymjs/KJFrameForAndroid/blob/master/debug_log.txt](http://git.oschina.net/kymjs/KJFrameForAndroid/blob/master/debug_log.txt)
---
# 框架使用
实际项目中的使用方法演示:[KJMusic音乐播放器](https://github.com/KJFrame/KJMusic) 以及 [爱看博客客户端](https://github.com/KJFrame/KJBlog)
**Demo工程运行** 
①[下载](http://git.oschina.net/kymjs/KJFrameForAndroid/repository/archive?ref=master)框架最新源码。
②选择KJLibraryExample工程导入Eclipse。
③将/binrary目录KJFrameForAndroid_Vxxx.jar包复制至demo的libs目录。
④删除[project.properties](http://git.oschina.net/kymjs/KJFrameForAndroid/blob/master/KJLibraryExample/project.properties)文件的最后一行
**在项目中使用** :将/binrary目录最新jar包[KJFrameForAndroid_xxx.jar](http://git.oschina.net/kymjs/KJFrameForAndroid/tree/master/binrary)添加到你工程/libs目录中并引用。
* 由于使用了SDK最新的API函数,以及3.0版Fragment。KJFrameForAndroid框架最低支持API 11。
*注:使用 KJFrameForAndroid 应用开发框架需要在你项目的AndroidManifest.xml文件中加入以下基本权限:*
```xml
```
----
## =======各模块使用介绍=======
## Plugin模块
使用Plugin模块可以让你的插件apk不用安装便直接被运行,极大的方便了APP动态更新,且可以轻松实现插件与APP项目之间的解耦。
你可以在[这里](http://git.oschina.net/kymjs/KJFrameForAndroid/attach_files)获取项目示例中插件的Demo apk与源码。更多介绍请看[Plugin模块详细介绍](http://git.oschina.net/kymjs/KJFrameForAndroid/tree/master/doc/PluginLibrary.md)
## UILibrary模块
UILibrary包含两个部分Widget(控件)、Topology(Android框架结构继承链) [详细介绍...](http://my.oschina.net/kymjs/blog/284897)
**UILibrary -> Widget控件部分**
主要封装了常用的UI控件,为了不让项目jar包过大,我们只引入了开发中一定会用到的控件,例如:可上下拉的KJScrollView、圆形显示的ImageView,可以双指缩放双击缩放双指旋转的ScaleImageView、等等......更多内容请自行查看项目文件中org.kymjs.kjframe.widget包下的内容
**UILibrary -> Topology拓扑部分**
规范了Activity中数据及控件的初始化,并包含一个使用IOC设计思想的控件初始化方式:可通过注解的方式进行UI绑定,与设置监听,在Activity和Fragment中均可以通过一行代码绑定控件并实现点击监听;同时UILibrary为开发者定义了完善的KJActivity和KJFragment等基类,开发者只需手动继承就可以获得Topology部分的全部功能。
```java
public class TabExample extends KJActivity {
    @BindView(id = R.id.bottombar_content1, click = true)
    public RadioButton mRbtn1;
    @BindView(id = R.id.bottombar_content2, click = true)
    private RadioButton mRbtn2;
    @Override
    public void setRootView() {
        setContentView(R.layout.aty_tab_example);
    }
    
    @Override
    protected void initWidget() {
        super.initWidget();
        mRbtn1.setText("控件已经初始化绑定并设置了监听");
    }
    @Override
    public void widgetClick(View v) {
        super.widgetClick(v);
        switch (v.getId()) {
        case R.id.bottombar_content1:
        ViewInject.toast("点击了mRbtn1");
            break;
        case R.id.bottombar_content2:
        ViewInject.toast("点击了mRbtn2");
            break;
        }
    }
}
```
###Topology中各函数调用顺序:
setRootView();
@BindView
initDataFromThread();(异步调用,可做耗时操作)
threadDataInited();(initDataFromThread执行完成后才会回调)
initData();
initWidget();
registerBroadcast();
## BitmapLibrary模块
任何View(ImageView设置src,普通View设置bg)加载图片的时候都无需考虑图片加载过程中出现的oom和android容器快速滑动时候出现的图片错位等现象,同时无需考虑图片加载过程中出现的OOM。默认使用内存lru算法+磁盘lru算法缓存图片 [详细介绍](http://blog.kymjs.com/kjframeforandroid/2014/07/25/01/)
**注:**在Android2.3之前,我们常常使用软引用或弱引用的形式去做缓存图片,然而根据Google的描述:垃圾回收器会更倾向于回收持有软引用或弱引用的对象,这让软引用和弱引用变得不再可靠。另外,Android 3.0 (API Level 11)中,图片的数据会存储在本地的内存当中,因而无法用一种可预见的方式将其释放,这就有潜在的风险造成应用程序的内存溢出并崩溃。BitmapLibrary使用lru算法去管理缓存,同时内存缓存配合磁盘缓存能更有效的管理缓存调用。
```java
KJBitmap kjb = KJBitmap.create();
/**
 * url不仅支持网络图片显示,同时支持本地SD卡上的图片显示;
 * view不仅可以是imageview,同时普通view也可以传入,框架会自动识别对imageview设置src对普通view设置bg
 */
// 载入本地图片
kjb.display(imageView, "/storage/sdcard0/1.jpg"); 
// 载入网络图片
kjb.display(textView, http://www.xxx.com/xxx.jpg); 
//自定义图片显示大小
kjb.display(view, http://www.xxx.com/xxx.jpg, 80, 80); //如不指定图片大小,默认采用控件大小显示图片
```
## HttpLibrary模块
KJLibrary默认对所有Http通信的数据做了缓存处理,缓存时间为5分钟。这么做的目的不仅是为了节省用户手机流量,同时是为了减少服务器压力
HttpLibrary模块使用HttpUrlConnection实现方式实现网络通信、数据上传,使用HttpClient实现文件的断点下载。根据Google建议:在2.3系统之前由于HttpUrlConnection不稳定且有一定的BUG,应该尽量使用HttpClient;在2.3以后的系统,若只是简单的数据交互,应该使用更加轻量级、易扩展的HttpUrlConnection。
###普通get、post方法示例:
```java
    	kjh.get("http://www.oschina.net/", new HttpCallBack();//与post相似,就只写一种了
		
		KJHttp kjh = new KJHttp();
		HttpParams params = new HttpParams();
        params.put("id", "1");
        params.put("name", "kymjs");
		kjh.post("http://192.168.1.149/post.php", params, new HttpCallBack() {
            @Override
            public void onPreStart() {
                super.onPreStart();
                KJLoger.debug("即将开始http请求");
            }
            @Override
            public void onSuccess(String t) {
                super.onSuccess(t);
                ViewInject.longToast("请求成功");
                KJLoger.debug("请求成功:" + t.toString());
            }
            @Override
            public void onFailure(Throwable t, int errorNo, String strMsg) {
                super.onFailure(t, errorNo, strMsg);
                KJLoger.debug("出现异常:" + strMsg);
            }
            @Override
            public void onFinish() {
                super.onFinish();
                KJLoger.debug("请求完成,不管成功还是失败");
            }
        });
```
###post上传文件方法示例:
```php
// 文件上传的PHP后台实现示例
 0)
    {
        echo "Return Code: " . $_FILES["file"]["error"] . "
";
    }
    else
    {
        echo "Upload: " . $_FILES["file"]["name"] . "
";
        echo "Type: " . $_FILES["file"]["type"] . "
";
        echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb
";
        echo "Temp file: " . $_FILES["file"]["tmp_name"] . "
";
    
		if (file_exists("upload/" . $_FILES["file"]["name"]))
        {
            echo $_FILES["file"]["name"] . " already exists. ";
        }
        else
        {
            move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["name"]);
            echo "Stored in: " . "upload/" . $_FILES["file"]["name"];
        }
    }
?>
```
```java
	private void upload() {
       HttpParams params = new HttpParams();
		//支持一次传递多个文件,这里使用UtilsLibrary中的工具类获取一个文件
        params.put("file", FileUtils.getSaveFile("KJLibrary", "logo.jpg"));
        kjh.post("http://192.168.1.149/kymjs/hello.php", params,
                new HttpCallBack() {
                    @Override
                    public void onSuccess(String t) {
                        super.onSuccess(t);
                        ViewInject.toast("文件上传完成");
                    }
                    @Override
                    public void onFailure(Throwable t, int errorNo,
                            String strMsg) {
                        super.onFailure(t, errorNo, strMsg);
                        ViewInject.toast("文件上传失败" + strMsg);
                    }
                });
    }
```
###断点下载方法示例:
```java
	kjh.download(mEtDownloadPath.getText().toString(), FileUtils.getSaveFile("KJLibrary", "l.pdf"),
            new HttpCallBack() {
                @Override
                public void onSuccess(File f) {
                    super.onSuccess(f);
                    KJLoger.debug("success");
                    ViewInject.toast("下载成功");
                    mProgress.setProgress(mProgress.getMax());
                }
				
                @Override
                public void onFailure(Throwable t, int errorNo,
                        String strMsg) {
                    super.onFailure(t, errorNo, strMsg);
                    KJLoger.debug("onFailure");
                }
					
				/* onLoading方法只在下载方法中有效,且每秒回调一次 */
                @Override
                public void onLoading(long count, long current) {
                    super.onLoading(count, current);
                    mProgress.setMax((int) count);
                    mProgress.setProgress((int) current);
                    KJLoger.debug(count + "------" + current);
                }
            });
```
## DBLibrary模块
包含了android中的orm框架,一行代码就可以进行增删改查。支持一对多,多对一等查询。
DB模块,很大程度上参考了[finalDB](https://github.com/kymjs/afinal)的设计,并在此基础上完善了几乎全部的API注释,与更多可定制的DB操作
```java
	//普通数据存储
	KJDB db = KJDB.create(this);
	User ugc = new User(); //这里需要注意的是User对象必须有id属性,或者有通过@ID注解的属性
	ugc.setEmail("kymjs123@gmail.com");
	ugc.setName("kymjs");
	db.save(ugc);
```
```java
	//一对多数据存储
	public class Parent{  //JavaBean
		private int id;
		@OneToMany(manyColumn = "parentId")
		private OneToManyLazyLoader children;
		/*....*/
	}
	public class Child{ //JavaBean
		private int id;
		private String text;
		@ManyToOne(column = "parentId")
		private  Parent  parent;
		/*....*/
	}
	List all = db.findAll(Parent.class);
		for( Parent  item : all){
			if(item.getChildren ().getList().size()>0)
				ViewInject.toast(item.getText() + item.getChildren().getList().get(0).getText());
		}
```
## 帮助我
我是张涛,中国深圳,Android高级工程师
如果我的项目帮到了你,可否在你有能力的基础捐助我买书学习,以让我更有信心和能力回馈网友。
[点这里参与我的众筹](https://shenghuo.alipay.com/send/payment/fill.htm) 我的支付宝账号[kymjs@foxmail.com](https://shenghuo.alipay.com/send/payment/fill.htm)
书本计划清单:
《[项目经理应该知道的97件事](http://item.jd.com/10794354.html)》   ¥39(已读)
《[简约至上:交互式设计四策略](http://item.jd.com/1412828696.html)》  ¥21 (感谢王小壮的捐赠)
《[参与感:小米口碑营销内部手册](http://item.jd.com/11512713.html)》	¥42 (感谢韩杰的捐赠)
《[格拉德威尔经典系列](http://www.amazon.cn/%E6%A0%BC%E6%8B%89%E5%BE%B7%E5%A8%81%E5%B0%94%E7%BB%8F%E5%85%B8%E7%B3%BB%E5%88%97-%E5%BC%82%E7%B1%BB-%E7%9C%A8%E7%9C%BC%E4%B9%8B%E9%97%B4-%E5%BC%95%E7%88%86%E7%82%B9-%E9%80%86%E8%BD%AC-%E5%A4%A7%E5%BC%80%E7%9C%BC%E7%95%8C-%E9%A9%AC%E5%B0%94%E7%A7%91%E5%A7%86%E2%80%A2%E6%A0%BC%E6%8B%89%E5%BE%B7%E5%A8%81%E5%B0%94/dp/B00JXFD0XM/ref=sr_1_1?s=books&ie=UTF8&qid=1418830300&sr=1-1&keywords=%E6%A0%BC%E6%8B%89%E5%BE%B7%E7%BB%B4%E5%B0%94)》	¥132
##感谢 沙加(¥99) 江斌(¥88) 夏志强(¥168) 马俊谟(¥88) 黄文燕(¥88) 王婷婷(¥20) 的捐赠