Android应用开发之Android之ListView,AsyncTask,GridView,CardView,本地数据存储,SQLite数据库
白羽 2018-07-24 来源 :网络 阅读 1230 评论 0

摘要:本文将带你了解Android应用开发之Android之ListView,AsyncTask,GridView,CardView,本地数据存储,SQLite数据库,希望本文对大家学Android有所帮助





补充上一节,使用ListView是用来显示列表项的,使用ListView需要两个xml文件,一个是列表布局,一个是单个列表项的布局。如我们要在要显示系统所有app列表项时,需要左边appimage视图和右边文本视图。
一个是列表布局
all_app_list.xml
<ListView
 android:id="@android:id/app_list"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"/>
单个列表项的布局
list_item.xml
<ImageView
        android:id="@+id/icon_image_view"
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:src="@mipmap/ic_launcher"/>
<TextView
        android:id="@+id/title_text_view"
        android:layout_width="match_parent"
        android:layout_height="60dp"
        android:text="@string/app_name"
        android:textSize="24sp"/>
AsyncTask:
对于Android中的AsyncTask要比Handler更轻量级一些,适合用于简单的异步处理。Handler和AsyncTask为了是为了不阻塞主线程即UI线程,UI的更新只能在主线程中进行处理,所以异步处理在Android开发中不可免。
AsyncTask是Android封装过后的后台任务类,继承于Object类,导入时注意是这个android.os.AsyncTask,在继承AsyncTask中提供了三个泛型参数,和重载了几个方法。
三种泛型参数类型为Params,Progress和Result。如Params是启动任务执行时的输入参数,Progress为执行任务的百分比,Result是返回执行的结果。
接下来就是重写的以下方法

doInBackground(Params...):后台执行和耗时的操作都在这里。
onPostExecute(Result):此方法在主线程中执行。
onProgressUpdate(Progress):使用此方法显示任务执行的进度。
onPreExecute():调用Excute的接口。
onCancelled():调用取消时的任务,不常用。

GridView
使用GridView可以实现九宫格效果,是和ListView一样比较常用的多控件布局。
GridView布局,常用属性有:
android:columnWidth
android:numColumns
android:verticalSpacing
android:horizontalSpacing
android:stretchMode
android:cacheColorHint
android:listSelector

<GridView
 android:id="@+id/gridview"
 android:numColumns="auto_fit"
 android:verticalSpacing="10dp"
 android:horizontalSpacing="10dp"
 android:layout_width="match_parent"
 android:layout_height="match_parent"/>
CardView
CardView也是一种布局,像卡片一样,有点像公号推文一样,具有阴影效果和圆角,这种常用新闻视频之类控件,是Android5.0新增,使用时需要导入com.android.support:cardview-v7:~更加自己版本号统一。
属性:
<android.support.v7.widget.CardView
        app:cardBackgroundColor="#000000"
        app:cardCornerRadius="10dp"
        app:contentPadding="10dp"
        android:layout_width="wrap_content"
        android:layout_gravity="center"
        android:layout_height="wrap_content">
        <TextView
            android:gravity="center"
            android:layout_width="200dp"
            android:layout_height="50dp"
            android:text="Hello World!"/>
</android.support.v7.widget.CardView>
信息类:
public class Message {
    //声明信息
    private int id;
    private int imgResId;
    private String title;
    private String content;
    //创建构造方法
    public Message (){

    }

    public Message (int id, int imgResId, String title, String content) {
        this.id = id;
        this.imgResId = imgResId;
        this.title = title;
        this.content = content;
    }
    //以下自动导入
    public int getId() {
        return id;
    }

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

    public int getImgResId() {
        return imgResId;
    }

    public void setImgResId(int imgResId) {
        this.imgResId = imgResId;
    }

    public String getTitle() {
        return title;
    }

    public void setTitle(String title) {
        this.title = title;
    }

    public String getContent() {
        return content;
    }

    public void setContent(String content) {
        this.content = content;
    }
}
适配器:
//继承BaseAdapter 创建适配器类
public class MessageAdapter extends BaseAdapter{
    //Context 上下文
    private Context mContext;
    //渲染布局
    private LayoutInflater mInflater;
   //数据集合
    private List<Message> mDatas;
   //创建有参的构造函数,Context以及数据,通用
    public MessageAdapter (Context context, List<Message> datas){
        mContext = context;
        mInflater = LayoutInflater.from(context);//规定
        mDatas = datas;
    }

    @Override
    public int getCount() {
        //获取数据长度
        return mDatas.size();
    }

    @Override
    public Msg getItem(int position) {
        //获取数据位置
        return mDatas.get(position);
    }

    @Override
    public long getItemId(int position) {
        //获取数据Id,通常position即可
        return position;
    }
    //获取视图
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        //创建ViewHolder
        ViewHolder viewHolder = null;
        //如果为空
        if (convertView == null){
         //mInflater.inflate(渲染布局,parent , false)
         convertView = mInflater.inflate(R.layout.item_msg,parent,false);
         viewHolder = new ViewHolder();//创建类对象
         //视图
         viewHolder.mIvImg = convertView.findViewById(R.id.id_iv_img);
         viewHolder.mTvTitle = convertView.findViewById(R.id.id_tv_title);
         viewHolder.mTvContent = convertView.findViewById(R.id.id_tv_content);

         convertView.setTag(viewHolder);// convertView.getTag();

        }else {
            viewHolder = (ViewHolder) convertView.getTag();// convertView.getTag();
        }
        //获取数据位置
        Message msg = mDatas.get(position);//数据集合 private List<Message> mDatas;
        viewHolder.mIvImg.setImageResource(msg.getImgResId());//获取图片位置
        viewHolder.mTvTitle.setText(msg.getTitle());//获取标题
        viewHolder.mTvContent.setText(msg.getContent());//获取内容

        return convertView;
    }

    public static class ViewHolder{
        //静态内部类,类调用
        ImageView mIvImg;
        TextView mTvTitle;
        TextView mTvContent;
    }
}
其他就可以ok的了。
数据存储方式
四种:

SharedPreferences
SQLite
Content Provider
File

本地数据存储
这里介绍常用之Shared Preferences,主要以key-value形式存储。(支持boolean,int,float,long,string);Internal Storage数据安全性高,空间大小有限;External Storage与之Internal Storage相反。
SharedPreferences是一种比较轻型的数据存储,基于xml的键值对存储,存储一些简单的信息。
SharedPreferences只能获取数据不能存储和修改,但能通过Editor实现存储修改。

步骤:
获取SharedPreferences对象
SharedPreferences.Editor
Editor的putXXX的方法
Editor.commit()

SharedPreferences sharedPreferences = getSharedPreferences("sharedPreferences", MODE_PRIVATE);
Editor editor = sharedPreferences.edit();
editor.putXXX();
editor.commit();
创建一个类
SharedPreferences sharedPreferences = getSharedPreferences("text",Context.MODE_PRIVATE);
sharedPreferences.edit().putInt("test",1).commit();
//获取
int value = sharedPreferences.getInt("test",0);
SQLite数据库
SQLite是一种轻量级系型数据库,实质为二进制文件,所谓关系型,就是一种关系模式,这里表示二维表结构模式。在关系型数据库中,二维表中的列为属性,称为字段;行为记录,如一对象;属性中(字段)取值范围称为域。
这里我们要学会数据库,如DDL,DML等,数据定义语言和数据操作语言,创建表格和增删改查。
在SQLite中我们要了解认识SQLiteOpenHelper和SQLiteDatabase,并学会用。和两种方法rawQuery():用于查询和execSQL():用于增删改查。在Android提供了SQLiteDatabase创建对象,运用不用写数据库语法封装好的API类。分别用query(),insert(),delete(),update()表示。

SQLite的形式,以单个文件的存储,存储2T内存,以B-Tree形式。

SQLiteDatabase db = openOrCreateDatabase("table.db", MODE_PRIVATE, null);
SQL
insert into student values("077555","dashu","1444.2.2","男");
select...from...where...
update student set...where...
关系数据完整性是对关系的某种约束条件

实体完整性:对主码进行限制
参照完整性:对外码进行限制
用户定义完整性 :对具体数据进行限制

关系数据库的特点
(1)数据结构简单。
(2)功能强。
(3)使用方便。
(4)数据独立性高。
SQL的主要功能
(1)数据定义功能。
(2)数据操纵功能。
(3)数据控制功能。
内容
什么是Sqlite:
效率高,开源,小型,程序驱动,支持事务操作,无数据类型,可嵌入的关系型数据库,独立的,跨平台的,代码量少,简单易用。
创建表语句
//注意这里 _id 在Android中写这种形式,如果写 id为报错的
create table student(_id Integer primary key autoincrement, name varchar(10), age Integer not null);
删除表
drop table student;
插入数据
insert into 表名(字段) values (值);
insert into student(_id,age) values(1,17);
insert into student values(1,"vic",17);
修改数据
update student set name="dashu",age=17 where _id=1;
更新数据
update 表名 set 字段=值 更新的条件
删除数据
delete from 表名 [删除条件];
delete from student where _id=1;
查询语句
select 列名称 from 表名称 where 条件;
group by 分组的字段 having 筛选条件 order by 排序字段 desc 降序

select * from student;
select _id from student;

select * from student where _id=1 and age>17;
select * from student where age like "%1%";
select * from student where age>17 order by _id=1;
SQLite
//SD卡路径,那么数据库位置则在指定的路径下
String path = Environment.getExternalStorageDirectory() + "/student.db";
//三个参数,this,上下文,path为路径,null没有,最后一个为int类型,版本号
SQLiteOpenHelper helper = new SQLiteOpenHelper(this,path,null,1) {
    @Override
     public void onCreate(SQLiteDatabase sqLiteDatabase) {
      //创建
      Toast.makeText(MainActivity.this,"数据库创建成功",Toast.LENGTH_SHORT).show();
     //如果数据库不存在,则会调用onCreate方法

    String sql = "create table info_tb_student (_id integer primary key autoincrement," +
                      "name varhcar(20)," +
                       "age integer, "+
                       "gender varhcar(4) )";
                       sqLiteDatabase.execSQL(sql);
            }

   @Override
   public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {
       //升级提示
       Toast.makeText(MainActivity.this,"数据库升级",Toast.LENGTH_SHORT).show();
       }
};
//以上如果发现找不到数据库,因为没调用下方代码
helper.getReadableDatabase();



本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标移动开发之Android频道!

本文由 @白羽 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程