版權聲明:未經博主允許不得轉載 補充 補充上一節,使用 是用來顯示列表項的,使用 需要兩個xml文件,一個是列表佈局,一個是單個列表項的佈局。如我們要在要顯示系統所有app列表項時,需要左邊app 視圖和右邊文本視圖。 一個是列表佈局 all_app_list.xml 單個列表項的佈局 list_i ...
版權聲明:未經博主允許不得轉載
補充
補充上一節,使用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 知識點