android listview asynctask,Android之ListView,AsyncTask,GridView,CardView,本地数据存储,SQLite数据库...

版权声明:未经博主允许不得转载

9d2f9271152f

标题图

补充

补充上一节,使用ListView是用来显示列表项的,使用ListView需要两个xml文件,一个是列表布局,一个是单个列表项的布局。如我们要在要显示系统所有app列表项时,需要左边appimage视图和右边文本视图。

一个是列表布局

all_app_list.xml

android:id="@android:id/app_list"

android:layout_width="match_parent"

android:layout_height="wrap_content"/>

单个列表项的布局

list_item.xml

android:id="@+id/icon_image_view"

android:layout_width="60dp"

android:layout_height="60dp"

android:src="@mipmap/ic_launcher"/>

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

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:~更加自己版本号统一。

属性:

app:cardBackgroundColor="#000000"

app:cardCornerRadius="10dp"

app:contentPadding="10dp"

android:layout_width="wrap_content"

android:layout_gravity="center"

android:layout_height="wrap_content">

android:gravity="center"

android:layout_width="200dp"

android:layout_height="50dp"

android:text="Hello World!"/>

信息类:

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 mDatas;

//创建有参的构造函数,Context以及数据,通用

public MessageAdapter (Context context, List 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 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();

如果觉得不错,那就点个赞吧!❤️

编辑 :达叔

信箱:2397923107@qq.com

定位:分享 Android&Java 知识点

我的目标是——每天不断更

我是简书的达叔小生。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值