1. 程式人生 > 程式設計 >Android小程式實現音樂播放列表

Android小程式實現音樂播放列表

本文例項為大家分享了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>

執行程式,新增音樂資訊:

Android小程式實現音樂播放列表

在音樂列表中單擊一條記錄,彈出警告對話方塊刪除一條記錄:

Android小程式實現音樂播放列表

更多關於播放器的內容請點選《java播放器功能》進行學習。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。