当前位置: 编程技术>移动开发
本页文章导读:
▪基于Service与ContentProvider的音乐播发实例 基于Service与ContentProvider的音乐播放实例
Android的核心也就是Activity,Service,ContentProvider,BroadCastReceiver,以及串联它们的Intent五大模块,Activity我就不用多说了,而我将就这个例子来说一下Service,.........
▪ 近邻 测试快来体验 比邻 测试快来体验
一个高中生团队做的应用for iphone,你要不要来测试?我弟弟他们学校9个不爱读书的高中学生做的应用,我看了太震惊了,现在内测让我帮忙找人,所以发布到这个地方.........
▪ jQuery获取Select选中的Text跟Value(jquery学习备忘录) jQuery获取Select选中的Text和Value(jquery学习备忘录)
1. $("#select_id").change(function(){//code...}); //为Select添加事件,当选择其中一项时触发
2. var checkText=$("#select_id").find("option:selected").text(); //获.........
[1]基于Service与ContentProvider的音乐播发实例
来源: 互联网 发布时间: 2014-02-18
基于Service与ContentProvider的音乐播放实例
Android的核心也就是Activity,Service,ContentProvider,BroadCastReceiver,以及串联它们的Intent五大模块,Activity我就不用多说了,而我将就这个例子来说一下Service,以及ContentProvider.
Service:
Android中的服务,它与Activity不同,它是不能与用户交互的,运行在后台的程序,如果我们退出应用时,没有结束进程,它仍然在后台运行,那我们什么时候会用到Service呢?比如我们播放音乐的时候,有可能想边听音乐边干些其他事情,当我们退出播放音乐的应用,如果不用Service,我们就听不到歌了,所以这时候就得用到Service了,又比如当我们一个应用的数据是通过网络获取的,不同时间(一段时间)的数据是不同的这时候我们可以用Service在后台定时更新,而不用每打开应用的时候在去获取。
CotentProvider:
Android中的内容提供者,它让我们可以通过一个URL跨应用获取数据(通常是SQLite数据库),我觉得Android这个还是机制还是非常不错的,特别是我们想获取Sdcard里一些数据时,比如我们想获取所有Sdcard里的音频,视频,图片等,我们只要通过一个URL就可以轻松搞定,其实我们在开机或者插入Sdcard时,Android会做一些事情,就是它自动建库,将我们卡里所有音频,视频,图片等信息存在相应的表中,我们可以用DDMS打开看一下如下图(data/data目录下),红线是我手机当前卡建立的数据库(不同卡会建立不同的数据库)
然后我们可以将这个数据库导出,用可以打开.db的工具打开浏览数据库的相关信息如下图所示(我这里打开了音频的数据表,可以看到我手机里所有音频文件,当然还有数据表字段):
本来这个应用是我用来写播放音乐Widget的代码,但是布局有点多,我就简单化了,做了一个比较 简单的Demo,老规矩Step by Step.
第一步:新建一个Android工程命名为MusicDemo.
第二步:候改main.xml布局文件(我这里增加了四个按钮,上一首,播放,下一首,暂停)代码如下:
第三步:新建一个MusicService.java类,播放音乐都是在这个类里进行的哦,代码如下:
第四步:修改Musicdemo.java代码如下(代码比较简洁易懂):
第五步:修改AndroidManifest.xml,这里只是把我们的MusicService申明进去,不然会报错(第14行代码),代码如下:
Android的核心也就是Activity,Service,ContentProvider,BroadCastReceiver,以及串联它们的Intent五大模块,Activity我就不用多说了,而我将就这个例子来说一下Service,以及ContentProvider.
Service:
Android中的服务,它与Activity不同,它是不能与用户交互的,运行在后台的程序,如果我们退出应用时,没有结束进程,它仍然在后台运行,那我们什么时候会用到Service呢?比如我们播放音乐的时候,有可能想边听音乐边干些其他事情,当我们退出播放音乐的应用,如果不用Service,我们就听不到歌了,所以这时候就得用到Service了,又比如当我们一个应用的数据是通过网络获取的,不同时间(一段时间)的数据是不同的这时候我们可以用Service在后台定时更新,而不用每打开应用的时候在去获取。
CotentProvider:
Android中的内容提供者,它让我们可以通过一个URL跨应用获取数据(通常是SQLite数据库),我觉得Android这个还是机制还是非常不错的,特别是我们想获取Sdcard里一些数据时,比如我们想获取所有Sdcard里的音频,视频,图片等,我们只要通过一个URL就可以轻松搞定,其实我们在开机或者插入Sdcard时,Android会做一些事情,就是它自动建库,将我们卡里所有音频,视频,图片等信息存在相应的表中,我们可以用DDMS打开看一下如下图(data/data目录下),红线是我手机当前卡建立的数据库(不同卡会建立不同的数据库)
然后我们可以将这个数据库导出,用可以打开.db的工具打开浏览数据库的相关信息如下图所示(我这里打开了音频的数据表,可以看到我手机里所有音频文件,当然还有数据表字段):
本来这个应用是我用来写播放音乐Widget的代码,但是布局有点多,我就简单化了,做了一个比较 简单的Demo,老规矩Step by Step.
第一步:新建一个Android工程命名为MusicDemo.
第二步:候改main.xml布局文件(我这里增加了四个按钮,上一首,播放,下一首,暂停)代码如下:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="Welcome to Mr Wei's blog." /> <LinearLayout android:orientation="horizontal" android:layout_width="fill_parent" android:layout_height="wrap_content" > <Button android:id="@+id/previous" android:layout_height="fill_parent" android:layout_width="wrap_content" android:layout_weight="1" android:text="上一首" /> <Button android:id="@+id/play" android:layout_height="fill_parent" android:layout_width="wrap_content" android:layout_weight="1" android:text="播放" /> <Button android:id="@+id/next" android:layout_height="fill_parent" android:layout_width="wrap_content" android:layout_weight="1" android:text="下一首" /> <Button android:id="@+id/pause" android:layout_height="fill_parent" android:layout_width="wrap_content" android:layout_weight="1" android:text="暂停" /> </LinearLayout> </LinearLayout>
第三步:新建一个MusicService.java类,播放音乐都是在这个类里进行的哦,代码如下:
package com.tutor.music; import java.io.IOException; import android.app.Service; import android.content.Intent; import android.database.Cursor; import android.media.MediaPlayer; import android.net.Uri; import android.os.IBinder; import android.provider.MediaStore; import android.widget.Toast; public class MusicService extends Service { String[] mCursorCols = new String[] { "audio._id AS _id", // index must match IDCOLIDX below MediaStore.Audio.Media.ARTIST, MediaStore.Audio.Media.ALBUM, MediaStore.Audio.Media.TITLE, MediaStore.Audio.Media.DATA, MediaStore.Audio.Media.MIME_TYPE, MediaStore.Audio.Media.ALBUM_ID, MediaStore.Audio.Media.ARTIST_ID, MediaStore.Audio.Media.DURATION }; private MediaPlayer mMediaPlayer; private Cursor mCursor; private int mPlayPosition = 0; public static final String PLAY_ACTION = "com.tutor.music.PLAY_ACTION"; public static final String PAUSE_ACTION = "com.tutor.music.PAUSE_ACTION"; public static final String NEXT_ACTION = "com.tutor.music.NEXT_ACTION"; public static final String PREVIOUS_ACTION = "com.tutor.music.PREVIOUS_ACTION"; @Override public IBinder onBind(Intent arg0) { // TODO Auto-generated method stub return null; } @Override public void onCreate() { super.onCreate(); mMediaPlayer = new MediaPlayer(); //通过一个URI可以获取所有音频文件 Uri MUSIC_URL = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI; //这里我过滤了一下,因为我机里有些音频文件是游戏音频,很短 //播放不到一秒钟,我这里作了处理,默认大于10秒的可以看作是歌 mCursor = getContentResolver().query(MUSIC_URL, mCursorCols, "duration > 10000", null, null); } @Override public void onStart(Intent intent, int startId) { super.onStart(intent, startId); String action = intent.getAction(); if(action.equals(PLAY_ACTION)){ play(); }else if(action.equals(PAUSE_ACTION)){ pause(); }else if(action.equals(NEXT_ACTION)){ next(); }else if(action.equals(PREVIOUS_ACTION)){ previous(); } } //play the music public void play() { inite(); } //暂停时,结束服务 public void pause() { stopSelf(); } //上一首 public void previous() { if (mPlayPosition == 0) { mPlayPosition = mCursor.getCount() - 1; } else { mPlayPosition--; } inite(); } public void next() { if (mPlayPosition == mCursor.getCount() - 1) { mPlayPosition = 0; } else { mPlayPosition++; } inite(); } public void inite() { mMediaPlayer.reset(); String dataSource = getDateByPosition(mCursor, mPlayPosition); String info = getInfoByPosition(mCursor, mPlayPosition); //用Toast显示歌曲信息 Toast.makeText(getApplicationContext(), info, Toast.LENGTH_SHORT).show(); try { mMediaPlayer.setDataSource(dataSource); mMediaPlayer.prepare(); mMediaPlayer.start(); } catch (IllegalArgumentException e1) { e1.printStackTrace(); } catch (IllegalStateException e1) { e1.printStackTrace(); } catch (IOException e1) { e1.printStackTrace(); } } //根据位置来获取歌曲位置 public String getDateByPosition(Cursor c,int position){ c.moveToPosition(position); int dataColumn = c.getColumnIndex(MediaStore.Audio.Media.DATA); String data = c.getString(dataColumn); return data; } //获取当前播放歌曲演唱者及歌名 public String getInfoByPosition(Cursor c,int position){ c.moveToPosition(position); int titleColumn = c.getColumnIndex(MediaStore.Audio.Media.TITLE); int artistColumn = c.getColumnIndex(MediaStore.Audio.Media.ARTIST); String info = c.getString(artistColumn)+" " + c.getString(titleColumn); return info; } //服务结束时要释放MediaPlayer public void onDestroy() { super.onDestroy(); mMediaPlayer.release(); } }
第四步:修改Musicdemo.java代码如下(代码比较简洁易懂):
package com.tutor.music; import android.app.Activity; import android.content.ComponentName; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; public class MusicDemo extends Activity implements OnClickListener { private Button mPrevious,mPlay,mNext,mPause; private ComponentName component; public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); //oncreate里代码一如既往的少 setupViews(); } //初始化一些工作 public void setupViews(){ component = new ComponentName(this, MusicService.class); mPrevious = (Button)findViewById(R.id.previous); mPlay = (Button)findViewById(R.id.play); mNext = (Button)findViewById(R.id.next); mPause = (Button)findViewById(R.id.pause); mPrevious.setOnClickListener(this); mPlay.setOnClickListener(this); mNext.setOnClickListener(this); mPause.setOnClickListener(this); } //按钮点击事件响应 public void onClick(View v) { if(v == mPrevious){ Intent mIntent = new Intent(MusicService.PREVIOUS_ACTION); mIntent.setComponent(component); startService(mIntent); }else if(v == mPlay){ Intent mIntent = new Intent(MusicService.PLAY_ACTION); mIntent.setComponent(component); startService(mIntent); }else if(v == mNext){ Intent mIntent = new Intent(MusicService.NEXT_ACTION); mIntent.setComponent(component); startService(mIntent); }else{ Intent mIntent = new Intent(MusicService.PAUSE_ACTION); mIntent.setComponent(component); startService(mIntent); } } }
第五步:修改AndroidManifest.xml,这里只是把我们的MusicService申明进去,不然会报错(第14行代码),代码如下:
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.tutor.music" android:versionCode="1" android:versionName="1.0"> <application android:icon="@drawable/icon" android:label="@string/app_name"> <activity android:name=".MusicDemo" android:label="@string/app_name"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <service android:name=".MusicService" android:exported="true" /> </application> <uses-sdk android:minSdkVersion="7" /> </manifest>
[2] 近邻 测试快来体验
来源: 互联网 发布时间: 2014-02-18
比邻 测试快来体验
一个高中生团队做的应用for iphone,你要不要来测试?
我弟弟他们学校9个不爱读书的高中学生做的应用,我看了太震惊了,现在内测让我帮忙找人,所以发布到这个地方,希望大家支持他们。因为未上线所以很神秘的展开小范围公测,也没什么资料整理,欲想抢先体验的可以PM我。
唯一的截图:
一个高中生团队做的应用for iphone,你要不要来测试?
我弟弟他们学校9个不爱读书的高中学生做的应用,我看了太震惊了,现在内测让我帮忙找人,所以发布到这个地方,希望大家支持他们。因为未上线所以很神秘的展开小范围公测,也没什么资料整理,欲想抢先体验的可以PM我。
唯一的截图:
1 楼
Meier
2012-03-29
这个是做什么用的?
[3] jQuery获取Select选中的Text跟Value(jquery学习备忘录)
来源: 互联网 发布时间: 2014-02-18
jQuery获取Select选中的Text和Value(jquery学习备忘录)
1. $("#select_id").change(function(){//code...}); //为Select添加事件,当选择其中一项时触发 2. var checkText=$("#select_id").find("option:selected").text(); //获取Select选择的Text 3. var checkValue=$("#select_id").val(); //获取Select选择的Value 4. var checkIndex=$("#select_id ").get(0).selectedIndex; //获取Select选择的索引值 5. var maxIndex=$("#select_id option:last").attr("index"); //获取Select最大的索引值 jQuery设置Select选择的Text和Value: 语法解释: 1. $("#select_id ").get(0).selectedIndex=1; //设置Select索引值为1的项选中 2. $("#select_id ").val(4); //设置Select的Value值为4的项选中 3. $("#select_id option[text='jQuery']").attr("selected", true); //设置Select的Text值为jQuery的项选中 jQuery添加/删除Select的Option项: 语法解释: 1. $("#select_id").append("<option value='Value'>Text</option>"); //为Select追加一个Option(下拉项) 2. $("#select_id").prepend("<option value='0'>请选择</option>"); //为Select插入一个Option(第一个位置) 3. $("#select_id option:last").remove(); //删除Select中索引值最大Option(最后一个) 4. $("#select_id option[index='0']").remove(); //删除Select中索引值为0的Option(第一个) 5. $("#select_id option[value='3']").remove(); //删除Select中Value='3'的Option 5. $("#select_id option[text='4']").remove(); //删除Select中Text='4'的Option
最新技术文章: