Android小程式實現音樂播放列表
阿新 • • 發佈:2020-05-25
本文例項為大家分享了Android實現音樂播放列表的具體程式碼,供大家參考,具體內容如下
(1)建立一個數據類工具類DBHelper,該類繼承SQLiteOpenHelper,重寫onCreate()和onUpgrade()方法,並新增insert()、delete()、query()方法,分別實現資料的新增、刪除和查詢。DBHelper類的程式碼如下:
package com.example.musiclist; import android.content.ContentValues; import android.content.Context; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import android.os.Bundle; import android.view.Menu; import android.view.MenuItem; public class DBHelper extends SQLiteOpenHelper{ private static final String DB_NAME = "music.db"; //資料庫名稱 private static final String TBL_NAME = "MusicTbl"; //表名 private SQLiteDatabase db; //宣告SQLiteDatabase物件 //建構函式 DBHelper(Context c){ super(c,DB_NAME,null,2); } @Override public void onCreate(SQLiteDatabase db){ //獲取SQLiteDatabase物件 this.db = db; //建立表 String CREATE_TBL = "create table MusicTbl(_id integer primary key autoincrement,name text,singer text)"; db.execSQL(CREATE_TBL); } //插入 public void insert(ContentValues values){ SQLiteDatabase db = getWritableDatabase(); db.insert(TBL_NAME,values); db.close(); } //查詢 public Cursor query(){ SQLiteDatabase db = getWritableDatabase(); Cursor c = db.query(TBL_NAME,null); return c; } //刪除 public void del(int id){ if(db == null){ db = getWritableDatabase(); } db.delete(TBL_NAME,"_id=?",new String[]{String.valueOf(id)}); } //關閉資料庫 public void close(){ if(db != null){ db.close(); } } @Override public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion) { } }
(2)建立新增音樂的AddActivity,新增介面提供兩個文字框和一個按鈕,用於輸入音樂名和歌手名,當單擊“新增”按鈕時,將資料插入到表中,具體程式碼如下:
package com.example.musiclist; import android.app.Activity; import android.content.ContentValues; import android.content.Intent; import android.os.Bundle; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; public class AddActivity extends Activity { private EditText et1,et2; private Button b1; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_add); this.setTitle("新增收藏資訊"); et1 = (EditText)findViewById(R.id.EditTextName); et2 = (EditText)findViewById(R.id.EditTextSinger); b1 = (Button)findViewById(R.id.ButtonAdd); b1.setOnClickListener(new OnClickListener() { public void onClick(View v) { // 獲取使用者輸入的文字資訊 String name = et1.getText().toString(); String singer = et2.getText().toString(); //建立ContentValues物件。封裝記錄資訊 key 和 values 值成對出現 ContentValues values = new ContentValues(); values.put("name",name); values.put("singer",singer); //建立資料庫工具類DBHelper DBHelper helper = new DBHelper(getApplicationContext()); //呼叫insert()方法插入資料 helper.insert(values); //跳轉到QueryActivity,顯示音樂列表 Intent intent = new Intent(AddActivity.this,QueryActivity.class); startActivity(intent); } }); } }
當單擊“新增”按鈕時,先將使用者輸入的音樂名和歌手資訊封裝到ContentValues物件中,再呼叫DBHelper的insert()方法將記錄插入到資料庫中,然後跳轉到QueryActivity來顯示音樂列表。
AddActivity的佈局檔案內容如下:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:padding="10dp"> <TableLayout android:id="@+id/TableLayout" android:layout_width="wrap_content" android:layout_height="wrap_content" android:stretchColumns="1"> " <TableRow android:id="@+id/TableRow01" android:layout_width="wrap_content" android:layout_height="wrap_content"> <TextView android:id="@+id/TextView01" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="歌名"/> <EditText android:id="@+id/EditTextName" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text=""/> </TableRow> <TableRow android:id="@+id/TableRow02" android:layout_width="wrap_content" android:layout_height="wrap_content"> <TextView android:id="@+id/TextView02" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="歌手"/> <EditText android:id="@+id/EditTextSinger" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text=""/> </TableRow> <Button android:id="@+id/ButtonAdd" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="新增"/> </TableLayout> </LinearLayout>
(3)建立顯示音樂列表的QueryActivity,具體程式碼如下:
package com.example.musiclist; import android.app.AlertDialog; import android.app.ListActivity; import android.content.DialogInterface; import android.database.Cursor; import android.os.Bundle; import android.support.v4.widget.CursorAdapter; import android.text.AlteredCharSequence; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.widget.AdapterView; import android.widget.AdapterView.OnItemClickListener; import android.widget.ListView; import android.widget.SimpleCursorAdapter; public class QueryActivity extends ListActivity { //列表檢視 private ListView listView = null; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); this.setTitle("瀏覽音樂列表資訊"); final DBHelper helpter = new DBHelper(this); //獲取listview物件,引用變數和例項化物件 listView = getListView(); //查詢資料,獲取遊標 Cursor c = helpter.query(); //列表項陣列 String[] from = {"_id","name","singer"}; //列表項ID int[] to = {R.id.text0,R.id.text1,R.id.text2}; //介面卡 SimpleCursorAdapter adapter = new SimpleCursorAdapter(this,R.layout.activity_query,c,from,to); //為列表檢視新增介面卡 listView.setAdapter(adapter); //提示對話方塊 final AlertDialog.Builder builder = new AlertDialog.Builder(this); //設定ListView單擊監聽器 listView.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?>arg0,View arg1,int arg2,long arg3){ final long temp = arg3; builder.setMessage("真的要刪除該記錄嗎?").setPositiveButton("是",new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog,int which) { //刪除資料 helpter.del((int)temp); //重新查詢資料 Cursor c = helpter.query(); String[] from = {"_id","singer"}; int[] to = {R.id.text0,R.id.text2}; SimpleCursorAdapter adapter = new SimpleCursorAdapter(getApplicationContext(),to); //為列表檢視新增介面卡 listView.setAdapter(adapter); } }).setNegativeButton("否",null); AlertDialog ad = builder.create(); ad.show(); } }); helpter.close(); } }
上述程式碼中呼叫DBHelper的query()方法查詢資料庫並返回一個Cursor遊標,然後使用SimpleCursorAdapter介面卡將資料繫結到ListView控制元件上,並在ListView控制元件上註冊單擊監聽器,當單擊一條記錄時,顯示一個警告對話方塊提示是否刪除,單擊“是”,則呼叫DBHelper的del()方法刪除指定記錄。
QueryActivity佈局檔案內容如下:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:id="@+id/text0" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="25px"/> <TextView android:id="@+id/text1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="25px"/> <TextView android:id="@+id/text2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="25px"/> </LinearLayout>
執行程式,新增音樂資訊:
在音樂列表中單擊一條記錄,彈出警告對話方塊刪除一條記錄:
更多關於播放器的內容請點選《java播放器功能》進行學習。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。