android – 一旦活动结束,就会调用onStartCommand服务

当我点击播放按钮播放歌曲并将歌曲mp3与它捆绑在一起并在onStartCommand中接收时,我开始服务.问题是当我启动服务的活动结束时,我的服务再次调用onStartCommand.当它接收该捆绑时它不存在,因为这次活动没有启动它.因此,我在准备媒体播放器时遇到了非法的例外情况.我没有约束我的服务.

为什么在我的活动结束时会调用onStartCommand?

启动服务:

Intent i = new Intent(SongList.this,MyService.class);
i.putExtra("songURL",user.songurlz);
i.putExtra("songNAME",songplay_name);
startService(i);

服务类:

public class MyService extends Service {

    static MediaPlayer mediaPlayer;
    static int pauseplay;
    static notificationmanager notificationmanagerPlay;
    static CharSequence tickerText;
    static Notification notification4;//Notification variable(for song playing)
    TelephonyManager telephonyManager;
    PhonestateListener listener;
    static Notification notification;
    static notificationmanager mnotificationmanager;
    String songurl;
    String songname;

    @Override
    public IBinder onBind(Intent intent) {
        // Todo Auto-generated method stub
        return null;
    }

    @Override
    public void onCreate() {
        super.onCreate();
        mediaPlayer = new MediaPlayer();
        pauseplay = 1;
        MainMenu.serviceRunning = 1;
        telephonyManager = (TelephonyManager) getSystemService(
                Context.TELEPHONY_SERVICE);
        // Create a new PhonestateListener
        listener = new PhonestateListener() {

            @Override
            public void onCallStateChanged(int state,String incomingNumber) {
                switch (state) {
                case TelephonyManager.CALL_STATE_IDLE:
                    break;
                case TelephonyManager.CALL_STATE_OFFHOOK:
                    break;
                case TelephonyManager.CALL_STATE_RINGING:
                    if (mediaPlayer.isPlaying() == true && mediaPlayer != null){
                        pauseSong();
                    }
                    break;
                }
            }
        };
        // Register the listener wit the telephony manager
        telephonyManager.listen(listener,PhonestateListener.LISTEN_CALL_STATE);
    }

    public int onStartCommand(Intent intent,int flags,int startId) {
        super.onStartCommand(intent,flags,startId);
        if (intent != null) {
            Bundle bundle = intent.getExtras();
            //Retrieve your data using the name
            songurl = bundle.getString("songURL");
            Bundle bundle2 = intent.getExtras();
            //Retrieve your data using the name
            songname = bundle2.getString("songNAME");
        }
        Toast toast = Toast.makeText(getApplicationContext(),"Now Playing: "
                + songname,Toast.LENGTH_LONG);
        toast.show();
        // configure the intent
        Intent playIntent = new Intent(MyService.this,SongList.class);
        final PendingIntent pendingIntent = PendingIntent.getActivity(
                MyService.this,playIntent,0);
        notification = new Notification(R.drawable.playicon,"Buffering...",System.currentTimeMillis());
        notification.contentView = new RemoteViews(getPackageName(),R.layout.custom_notification2);
        notification.contentIntent = pendingIntent;
        if (SongList.bitmap != null) {
            notification.contentView.setimageViewBitmap(R.id.notifimage,SongList.bitmap);
        } else {
            notification.contentView.setimageViewResource(R.id.notifimage,R.drawable.icon);
        }
        notification.contentView
                .setTextViewText(R.id.notiftitle,"Now Playing");
        notification.contentView.setTextViewText(R.id.notiftext,songname);
        notification.flags = notification.flags
                | Notification.FLAG_ONGOING_EVENT;
        mnotificationmanager = (notificationmanager) getApplicationContext()
                .getSystemService(Context.NOTIFICATION_SERVICE);
        mnotificationmanager.notify(4,notification);
        mediaPlayer.reset();
        mediaPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
        try {
            mediaPlayer.setDataSource(songurl);
        } catch (IllegalArgumentException e) {
            e.printstacktrace();
        } catch (IllegalStateException e) {
            e.printstacktrace();
        } catch (IOException e) {
            e.printstacktrace();
        }
        // register an error listener via MediaPlayer's setonErrorListener
        mediaPlayer.setonErrorListener(new OnErrorListener() {

            @Override
            public boolean onError(MediaPlayer mp,int what,int extra) {
                Log.e("MEDIAPLAYER ERRORS","what: " + what + "  extra: "
                        + extra);
                mediaPlayer.reset();
                mnotificationmanager.cancel(4);
                return false;
            }
        });
        mediaPlayer.prepareAsync();
        mediaPlayer.setonPreparedListener(new MediaPlayer.OnPreparedListener() {

            @Override
            public void onPrepared(MediaPlayer mp) {
                mediaPlayer.start();
            }
        });
        mediaPlayer
                .setonCompletionListener(new MediaPlayer.OnCompletionListener(){

                    public void onCompletion(MediaPlayer mp) {
                        stopSelf();
                    }
                });
        return START_STICKY;
    }

    @Override
    public void onDestroy() {
        MainMenu.serviceRunning = 0;
        mnotificationmanager.cancel(4);
    }

    public static void pauseSong() {
        if (mediaPlayer.isPlaying() == true) {
            mediaPlayer.pause();
            mnotificationmanager.cancel(4);
            pauseplay = 0;
        }
    }

    public static void playSong() {
        if (pauseplay == 0) {
            mnotificationmanager.notify(4,notification);
            mediaPlayer.start();
            pauseplay = 1;
        }
    }
}

解决方法

Why does the onStartCommand get called when my activity ends?

要么在“活动结束”时调用startService()(无论这意味着什么),要么Android因为您使用START_STICKY而因某种原因重新启动服务.

就个人而言,对于音乐播放器,我认为START_NOT_STICKY是正确的答案.如果您的服务因任何原因而停止,用户应该负责再次启动它.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


这篇“android轻量级无侵入式管理数据库自动升级组件怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定...
今天小编给大家分享一下Android实现自定义圆形进度条的常用方法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文...
这篇文章主要讲解了“Android如何解决字符对齐问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Android...
这篇文章主要介绍“Android岛屿数量算法怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Android岛屿数量算...
本篇内容主要讲解“Android如何开发MQTT协议的模型及通信”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Andro...
本文小编为大家详细介绍“Android数据压缩的方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“Android数据压缩的方法是什么”文章能帮助大家解决疑惑...
这篇“Android怎么使用Intent传大数据”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅...
本文小编为大家详细介绍“Android事件冲突怎么解决悬浮窗拖拽问题”,内容详细,步骤清晰,细节处理妥当,希望这篇“Android事件冲突怎么解决悬浮窗拖拽问题”文...
这篇文章主要介绍了Android拼接如何实现动态对象的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Android拼接如何实现动态对象文...
今天小编给大家分享一下Android全面屏适配怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下...
本篇内容介绍了“Android怎么开发Input系统触摸事件分发”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何...
今天小编给大家分享一下AndroidRoom怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下...
本文小编为大家详细介绍“AndroidRoom使用方法有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“AndroidRoom使用方法有哪些”文章能帮助大家...
这篇文章主要介绍“Android中的OpenGL怎么配置使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Android中的Open...
这篇文章主要介绍了Android如何自定义自动识别涂鸦工具类的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Android如何自定义自动...
今天小编给大家分享一下Android如何自定义有限制区域的图例角度自识别涂鸦工具类的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以...
今天小编给大家分享一下ReactNative错误采集原理在Android中如何实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章...
这篇文章主要讲解了“Android崩溃日志收集和保存代码分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“A...
这篇“Android面向单Activity开发实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大...
本篇内容介绍了“Android应用启动白屏处理的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何...