(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);}@Overridepublic 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, null, values);db.close();}//查询public Cursor query(){SQLiteDatabase db = getWritableDatabase();Cursor c = db.query(TBL_NAME, null, null, null, null, null, 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();}}@Overridepublic 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;@Overridepublic 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);//创建数据库工具类DBHelperDBHelper 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;@Overridepublic 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"};//列表项IDint[] 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() {@Overridepublic 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", "name", "singer"};int[] to = {R.id.text0, R.id.text1, R.id.text2};SimpleCursorAdapter adapter = new SimpleCursorAdapter(getApplicationContext(), R.layout.activity_query, c, from, 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小程序之音乐播放列表相关推荐

  1. 微信小程序之音乐播放

    微信小程序之音乐播放 这次用的是API中的wx.createInnerAudioContext()接口 (创建内部 audio 上下文 InnerAudioContext 对象.) InnerAudi ...

  2. 微信小程序实现音乐播放器(3)(使用全局数据实现数据共享)

    文章目录 前情提要 搭建静态资源服务器 小程序项目 app.json app.js app.wxss pages/index/index.json pages/index/index.wxml pag ...

  3. 微信小程序实现音乐播放器(5)

    文章目录 前情提要 pubsubjs实现页面通信 moment.js实现时间格式化 BackgroundAudioManager 小程序项目 app.json app.wxss app.js page ...

  4. html5音乐播放器设计论文,基于微信小程序的音乐播放器设计和毕业论文

    摘  要 随着通信技术的发展和智能设备的普及,移动互联网在近两年发展迅猛,新兴的移动社交软件"微信"逐渐走进了手机用户的生活,深受全国数亿用户的欢迎.随着微信版本的不断更新,微信也 ...

  5. 用eclipse开发android小程序,【转】Eclipse 开发Android小程序遇到的问题总结

    用Eclipse 开发Android小程序遇到些小问题,在一边学习的过程中,将遇到的问题就记录一下,方面挺杂的,有关于程序出错的,关于linux应用的,有eclipse设置等- 1.ERROR: Ap ...

  6. android小程序:计算圆面积

    网络111 葛鹏 此程序主要实现的功能是输入圆的半径,点击计算按钮,程序便会自动计算出圆的面积. 知识点: 1.为什么要选择android. 2.了解各控件的用处. 3.避免在代码中死记硬背,注意灵活 ...

  7. 纯css svg 改变图片颜色 ios android 小程序

    本文出自: http://blog.csdn.net/wyk304443164 使用的是 filter drop-shadow 如果你只想兼容 Chrome 那么请看: http://www.zhan ...

  8. 微信小程序云音乐项目

    微信小程序云音乐项目 微信小程序云音乐项目 1. 项目介绍 技术栈 项目使用库 项目目标 2. 页面效果和功能展示 3. 项目源码与 API 接口 4. 项目说明 5. 致谢 微信小程序云音乐项目 1 ...

  9. 微信小程序实现音乐播放器(2)

    文章目录 前情提要 BackgroundAudioManager API:wx.setNavigationBarTitle() 搭建静态资源服务器 小程序项目 app.json app.wxss pa ...

最新文章

  1. OVS openflow(二十四)
  2. 一套简约漂亮的响应式博客园主题皮肤分享给你们(一)
  3. 基于stm32f405控制三相无刷电机例程_ST SSC 频道 | 基于ST STM32F302R8T6 电机空气压缩机方案...
  4. 函数、装饰器、迭代器、内置方法总练习题
  5. Leaflet中绘制同心圆、多个中心对称多边形、平行四边形网格、矩形网格
  6. linux 添加用户_linux ---添加普通用户账号
  7. SRE(Simple Rule Engine) Document
  8. MS CRM 2011 如何创建基于SQL的自定义报表,并使用数据预筛选(Pre-Filtering)
  9. 如何在一年内从零基础到前端就业?
  10. Javascript框架库漏洞验证
  11. Hibernate ——二级缓存
  12. SVN源码服务器搭建-详细教程(我的收藏)
  13. [20160325]bbed是否有4G的限制.txt
  14. C#获取字符串中某个字符出现的次数
  15. Origin下载速度慢怎么办
  16. android平板电脑 刷机工具,小白必看,安卓平板电脑刷机教程之一键刷机,普耐尔 MOMO 安卓平板论坛...
  17. 内存核心频率、工作频率,等效频率、总线频率
  18. 《HelloGitHub》第 40 期
  19. 何为水仙花?点开让我们直接了解
  20. SpringBoot+MDC实现链路调用日志

热门文章

  1. java取共轭_1.运用java 编写一个复数类,有实部和虚部,并实现复数的加减乘除运算?...
  2. 建立了一个微信公众平台交流群,欢迎加入!
  3. C语言标准库—— 参考手册
  4. OpenCV C++案例实战八《基于Hu矩轮廓匹配》
  5. 大神节,大神为什么这么拼?
  6. 多云时代的这三个陷阱一定要重视
  7. 成为一个好员工的七个忠告
  8. IO口未初始化差点烧板子
  9. 如何识别哭泣csdn_AI实战 | 最适合初学者的人脸识别入门教程
  10. 怎样的团队,值得我们加入