Android之ListView,AsyncTask,GridView,CardView,本地數據存儲,SQLite數據庫

版權聲明:未經博主容許不得轉載android

標題圖

補充

補充上一節,使用ListView是用來顯示列表項的,使用ListView須要兩個xml文件,一個是列表佈局,一個是單個列表項的佈局。如咱們要在要顯示系統全部app列表項時,須要左邊appimage視圖和右邊文本視圖。sql

一個是列表佈局數據庫

all_app_list.xml安全

<ListView
 android:id="@android:id/app_list"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"/>
複製代碼

單個列表項的佈局bash

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:app

對於Android中的AsyncTask要比Handler更輕量級一些,適合用於簡單的異步處理。HandlerAsyncTask爲了是爲了避免阻塞主線程即UI線程,UI的更新只能在主線程中進行處理,因此異步處理在Android開發中不可免。異步

AsyncTask是Android封裝事後的後臺任務類,繼承於Object類,導入時注意是這個android.os.AsyncTask,在繼承AsyncTask中提供了三個泛型參數,和重載了幾個方法。ide

三種泛型參數類型爲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 知識點 個人目標是——天天不斷更

相關文章
相關標籤/搜索