• 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更轻量级一些,适合用于简单的异步处理。HandlerAsyncTask为了是为了不阻塞主线程即UI线程,UI的更新只能在主线程中进行处理,所以异步处理在Android开发中不可免。

    AsyncTask是Android封装过后的后台任务类,继承于Object类,导入时注意是这个android.os.AsyncTask,在继承AsyncTask中提供了三个泛型参数,和重载了几个方法。

    三种泛型参数类型为ParamsProgressResult。如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的了。

    数据存储方式

    四种:
    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数据库

    SQLite是一种轻量级系型数据库,实质为二进制文件,所谓关系型,就是一种关系模式,这里表示二维表结构模式。在关系型数据库中,二维表中的列为属性,称为字段;行为记录,如一对象;属性中(字段)取值范围称为域。

    这里我们要学会数据库,如DDLDML等,数据定义语言和数据操作语言,创建表格和增删改查。

    在SQLite中我们要了解认识SQLiteOpenHelperSQLiteDatabase,并学会用。和两种方法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 知识点

  • 相关阅读:
    团队冲刺第五天
    团队冲刺第一天
    IOS开发(四):开关控件UISwitch
    IOS开发(七):UIActionSheet和UIAlertView
    IOS开发(五):分段控件UISegmentedControl
    [转]IOS开发(一):第一个有交互的APP
    [转]IOS开发(三):UIImageView、UISlider、UIStepper、UIButton
    IOS开发(八):系统声音服务
    [转]Tab Bars和Pickers
    [转]IOS开发(二):ImageView、TextField、键盘
  • 原文地址:https://www.cnblogs.com/dashucoding/p/11932609.html
Copyright © 2020-2023  润新知