版权声明:未经博主允许不得转载
补充上一节,使用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可以实现九宫格效果,是和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也是一种布局,像卡片一样,有点像公号推文一样,具有阴影效果和圆角,这种常用新闻视频之类控件,是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的了。
四种: 1. SharedPreferences 2. SQLite 3. Content Provider 4. 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是一种轻量级系型数据库,实质为二进制文件,所谓关系型,就是一种关系模式,这里表示二维表结构模式。在关系型数据库中,二维表中的列为属性,称为字段;行为记录,如一对象;属性中(字段)取值范围称为域。
这里我们要学会数据库,如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 知识点
程序员哆啦A梦 认证博客专家 博客专家 简书万粉优秀创作 掘金优秀作者 我是程序员哆啦A梦,蓝胖子,简书万粉优秀创作者,掘金优秀作者、博客专家,云+社区社区活跃作者,致力于打造一系列能够帮助程序员提高的优质文章。网站@http://www.dadaqianduan.cn