当前位置:  编程技术>移动开发
本页文章导读:
    ▪基于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布局文件(我这里增加了四个按钮,上一首,播放,下一首,暂停)代码如下:

<?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我。

唯一的截图:

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

    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android中通过view方式获取当前Activity的屏幕截... iis7站长之家
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android按钮单击事件的四种常用写法总结
▪Android消息处理机制Looper和Handler详解
▪Android实现Back功能代码片段总结
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
▪Android提高之自定义Menu(TabMenu)实现方法
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
▪Android提高之手游转电视游戏的模拟操控
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3