Android Afinal使用与总结

原创
2014/03/23 14:28
阅读数 2.1W

Afinal简介

  • Afinal 是一个android的sqlite orm 和 ioc 框架。同时封装了android中的http框架,使其更加简单易用;

  • 使用finalBitmap,无需考虑bitmap在android中加载的时候oom的问题和快速滑动的时候图片加载位置错位等问题。

  • Afinal的宗旨是简洁,快速。约定大于配置的方式。尽量一行代码完成所有事情。


目前Afinal主要有四大模块:

FinalDB模块:android中的orm框架,一行代码就可以进行增删改查。支持一对多,多对一等查询。
FinalActivity模块:android中的ioc框架,完全注解方式就可以进行UI绑定和事件绑定。无需findViewById和setClickListener等。
FinalHttp模块:通过httpclient进行封装http数据请求,支持ajax方式加载。

FinalBitmap模块:通过FinalBitmap,imageview加载bitmap的时候无需考虑bitmap加载过程中出现的oom和android容器快速滑动时候出现的图片错位等现象。FinalBitmap可以配置线程加载线程数量,缓存大小,缓存路径,加载显示动画等。FinalBitmap的内存管理使用lru算法,没有使用弱引用(android2.3以后google已经不建议使用弱引用,android2.3后强行回收软引用和弱引用,详情查看android官方文档),更好的管理bitmap内存。FinalBitmap可以自定义下载器,用来扩展其他协议显示网络图片,比如ftp等。同时可以自定义bitmap显示器,在imageview显示图片的时候播放动画等(默认是渐变动画显示)。


Afinal 更多信息可以参考:https://github.com/yangfuhai/afinal


这里我要使用的是它的FinalDB模块,下面通过一个简单Demo来展示一下。

Book实体定义如下:

[java] view plaincopy在CODE上查看代码片派生到我的代码片

  1. package com.example.afinaltest.entity;  

  2.   

  3. import net.tsz.afinal.annotation.sqlite.Table;  

  4.   

  5. @Table (name="book")  

  6. public class Book {  

  7.     private int id;  

  8.     private String name;  

  9.     private String isbn;  

  10.     private float price;  

  11.       

  12.     public int getId() {  

  13.         return id;  

  14.     }  

  15.     public void setId(int id) {  

  16.         this.id = id;  

  17.     }  

  18.     public String getName() {  

  19.         return name;  

  20.     }  

  21.     public void setName(String name) {  

  22.         this.name = name;  

  23.     }  

  24.     public String getIsbn() {  

  25.         return isbn;  

  26.     }  

  27.     public void setIsbn(String isbn) {  

  28.         this.isbn = isbn;  

  29.     }  

  30.     public float getPrice() {  

  31.         return price;  

  32.     }  

  33.     public void setPrice(float price) {  

  34.         this.price = price;  

  35.     }  

  36.       

  37.     @Override  

  38.     public String toString() {  

  39.         return "Book [id=" + id + ", name=" + name + ", isbn=" + isbn  

  40.                 + ", price=" + price + "]";  

  41.     }  

  42.       

  43. }  


这个实体类要注意一点就是getter和setter是不能省略的,因为afinal的finalDb最终会调用setter去给实体类的属性赋值。注解 @Table(name="book")表示我们希望将Book实体映射到book表中,Book类的属性会映射成对应表中的字段。


以下类中展示FinalDb的CRUD功能

[java] view plaincopy在CODE上查看代码片派生到我的代码片

  1. package com.example.afinaltest;  

  2.   

  3. import java.util.List;  

  4. import com.example.afinaltest.entity.Book;  

  5. import net.tsz.afinal.FinalDb;  

  6. import android.app.Activity;  

  7. import android.os.Bundle;  

  8. import android.view.View;  

  9. import android.view.View.OnClickListener;  

  10. import android.widget.Button;  

  11.   

  12. public class MainActivity extends Activity implements OnClickListener {  

  13.   

  14.     @Override  

  15.     protected void onCreate(Bundle savedInstanceState) {  

  16.         super.onCreate(savedInstanceState);  

  17.         setContentView(R.layout.activity_main);  

  18.           

  19.         findView();  

  20.     }  

  21.   

  22.     private void findView() {  

  23.           

  24.         Button bt_database = (Button) findViewById(R.id.bt_database);  

  25.         Button bt_insert = (Button) findViewById(R.id.bt_insert);  

  26.         Button bt_query = (Button) findViewById(R.id.bt_query);  

  27.         Button bt_update = (Button) findViewById(R.id.bt_update);  

  28.         Button bt_delete = (Button) findViewById(R.id.bt_delete);  

  29.           

  30.         bt_database.setOnClickListener(this);  

  31.         bt_insert.setOnClickListener(this);  

  32.         bt_query.setOnClickListener(this);  

  33.         bt_update.setOnClickListener(this);  

  34.         bt_delete.setOnClickListener(this);  

  35.     }  

  36.   

  37.     @Override  

  38.     public void onClick(View v) {  

  39.           

  40.         FinalDb finalDb = null;  

  41.         switch (v.getId()) {  

  42.         case R.id.bt_database:  

  43.               

  44.             finalDb = FinalDb.create(this"cart"); //创建数据库  

  45.               

  46.             break;  

  47.         case R.id.bt_insert:  

  48.               

  49.             finalDb = FinalDb.create(this"cart");  

  50.               

  51.             Book book = new Book();//这里需要注意的是User对象必须有id属性,或者有通过@ID注解的属性  

  52.             book.setName("设计模式");  

  53.             book.setIsbn("ISBN1000");  

  54.             book.setPrice(48.9f);  

  55.               

  56.             finalDb.save(book);  

  57.               

  58.             book = new Book();  

  59.             book.setName("大话设计模式");  

  60.             book.setIsbn("ISBN2000");  

  61.             book.setPrice(88.9f);  

  62.               

  63.             finalDb.save(book);  

  64.               

  65.             book = new Book();  

  66.             book.setName("研磨设计模式");  

  67.             book.setIsbn("ISBN3000");  

  68.             book.setPrice(58.9f);  

  69.               

  70.             finalDb.save(book);  

  71.               

  72.             book = new Book();  

  73.             book.setName("深入Java虚拟机");  

  74.             book.setIsbn("ISBN4000");  

  75.             book.setPrice(78.5f);  

  76.               

  77.             finalDb.save(book);  

  78.               

  79.             break;  

  80.         case R.id.bt_query:  

  81.               

  82.             finalDb = FinalDb.create(this"cart");  

  83.             List<Book> list = finalDb.findAllByWhere(Book.class"name like '%设计模式'");  

  84.               

  85.             for(int i=0;list!=null && i<list.size();i++){  

  86.                 System.out.println(list.get(i));  

  87.             }  

  88.               

  89.             break;  

  90.               

  91.         case R.id.bt_update:  

  92.               

  93.             finalDb = FinalDb.create(this"cart");  

  94.               

  95.             Book entity = new Book();  

  96.             entity.setName("设计模式");  

  97.             entity.setIsbn("ISBN1000");  

  98.             entity.setPrice(108.9f);  

  99.               

  100. //          finalDb.update(entity);  

  101.             finalDb.update(entity, "name like '%设计模式'");  

  102.             break;  

  103.               

  104.         case R.id.bt_delete:  

  105.               

  106.             finalDb = FinalDb.create(this"cart");  

  107.               

  108. //          finalDb.delete(entity);  

  109.             finalDb.deleteById(Book.class1);  

  110. //          finalDb.deleteByWhere(Book.class, "name like '%设计模式'");  

  111.               

  112.             break;  

  113.         default:  

  114.             break;  

  115.         }  

  116.     }  

  117.   

  118. }  



FinalDB优点
android中的orm框架,一行代码就可以进行增删改查。支持一对多,多对一等查询。


FinalDb的缺点

目前暂时不支持复合主键,并且对SQL语句的支持也非常有限,一些比较复杂的业务逻辑实现非常麻烦!



推荐github上一个开源项目 xUtils,它基于Afinal框架,进行了大量重构,使得xUtils支持大文件上传,更全面的http请求协议支持(10种谓词),拥有更加灵活的ORM,更多的事件注解支持且不受混淆影响

xUtilshttps://github.com/wyouflf/xUtils


展开阅读全文
打赏
1
1 收藏
分享
加载中
更多评论
打赏
0 评论
1 收藏
1
分享
返回顶部
顶部