Android之ListView,AsyncTask,GridView,CardView,本地数据存储,SQLite数据库
版权声明:未经博主允许不得转载
补充
补充上一节,使用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&Java 知识点
Android之ListView,AsyncTask,GridView,CardView,本地数据存储,SQLite数据库的更多相关文章
- Unity本地数据存储---Sqlite和JSON
2014-05-04更新 SqliteDatabase.cs这个文件的初始方法有问题,具体是如果指定URL已经存在了DB文件,就不会重新覆盖DB文件. 这导致我们修改之后的DB文件无法产生效果. 本人 ...
- Android数据存储——SQLite数据库(模板)
本篇整合Android使用数据库,要保存一个实体类的样本. 首先看一下数据库语句: ORM:关系对象映射 添加数据: ContentValues values = new ContentValues( ...
- iOS开发中关于本地数据中SQLite数据库常用的SQL语句
创建表 CREATE TABLE IF NOT EXISTS "student" ("number" INTEGER PRIMARY KEY AUTOINCRE ...
- Android本地数据存储复习
Android本地数据存储复习 Android无论是应用层还是系统层都需要在本地保存一些数据,尤其在应用层中使用的就更为普遍,大体有这么几种:SharedPreference,file,sqlite数 ...
- Android本地数据存储: ASimpleCache
一:前言 在上一篇博客Android本地数据存储: Reservoir 博客中,我提到,除了Reservoir库,还可以采用ASimpleCache开源库,来实现本地数据存储.昨天并没有仔细的对比Re ...
- Android本地数据存储: Reservoir
一:前言 今天做项目,准备使用本地存储,把一些数据存在本地磁盘上,比如用户名.密码这样的.其实大家都知道,这种情况最常用的就是SharedPreferences了,我也不例外,脑子里第一个想到的就是用 ...
- [安卓安全] 01.安卓本地数据存储:Shared Preferences安全风险浅析
*:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...
- iOS开发——数据持久化&使用NSUserDefaults来进行本地数据存储
使用NSUserDefaults来进行本地数据存储 NSUserDefaults适合存储轻量级的本地客户端数据,比如记住密码功能,要保存一个系统的用户名.密码.使用NSUserDefaults是首 ...
- iOS APP之本地数据存储(译)
最近工作中完成了项目的用户信息本地存储,查阅了一些本地存储加密方法等相关资料.期间发现了一个来自印度理工学院(IIT)的信息安全工程师的个人博客,写了大量有关iOS Application secur ...
随机推荐
- STL里的内存池实现
这个貌似有点复杂,解决的主要问题 就是 减少 内存分配次数,减少用户态核心态切换中断次数,提高运行速度,预分配 和线程池一个道理,预分配 ////////////////////自由链表 union ...
- sublime3支持es6语法和vue彩色显示
支持ES6语法设置: 首先安装nodejs 当然你可以使用其它诸如jsc之类的环境来运行js, 本文使用的是nodejs. 首先确保你的电脑已经安装好nodejs, 并已将其添加到环境变量中 (一般安 ...
- jquery中的callbacks之我见
callbacks是jquery的核心之一. 语法如下: jQuery.Callbacks( flags ) flags 类型: String 一个用空格标记分隔的标志可选列表,用来改变回调列表中 ...
- 2018-2019-2 20175213实验三《敏捷开发与XP实践》实验报告
一.实验报告封面 课程:Java程序设计 班级:1752班 姓名:吕正宏 学号:20175213 指导教师:娄嘉鹏 实验日期:2019年4月29日 实验时间:13:45 - 21:00 实验序号:实验 ...
- cdnbest 节点和主控连接不上原因主要查看几点
1. 注意安装过程中有没有报错,如果没有报错,检查下节点程序是否有运行,本例以linux系统为例,windows系统可以查看进程管理器 有以下进程说明程序是运行成功的 ps -aux |grep ka ...
- DJango 基础 (3)
模板路径 在配置文件setting.py中找到TEMPLATES设置来配置. 这是一个设置选项的列表,模板大都包含两项通用设置:两种方式配置模板: 第一种: DIRS 定义一个目录列表,模板引擎按列表 ...
- spark 算子之RDD
map map(func) Return a new distributed dataset formed by passing each element of the source through ...
- RESTful API格式 图片验证码接口
之前公司写图片验证码时用的是session 后来写接口时也想用session存验证码 不过领导说RESTful API 写接口 没有session这一说 于是就用了redis 存验证码 还有就是接口 ...
- FortiGate路由模式--静态地址线路上网配置
1.需求:外网接口使用专线,由运营商分配指定的静态地址,内网为192.168.1.0/24网段,实现基本上网功能. 运营商分配ip地址:202.1.1.10,网关地址:202.1.1.9, DNS:2 ...
- [leetcode]341. Flatten Nested List Iterator展开嵌套列表的迭代器
Given a nested list of integers, implement an iterator to flatten it. Each element is either an inte ...