zoukankan      html  css  js  c++  java
  • android WebView音频关闭的问题

    关于WebView加载的的网页中加载一些音频文件,退出的时候无法关闭的问题,网上一堆的解决方案,但是都没有解决我的问题。我们的界面是一个很特殊的情况,在onDestory的时候,不能立刻关闭WebView( myWebView.destroy();myWebView = null;)

    后期各种尝试,都没法关闭,最后想到了用系统的音频管理来处理这个问题,没想到还真的可以,下面直接放代码:

    if (audioManager == null) {
                    audioManager = (AudioManager) getSystemService(Context.AUDIO_SERVICE);
                }
                /**系统音频控制权限,AUDIOFOCUS_GAIN_TRANSIENT 短暂获取**/
                int result = audioManager.requestAudioFocus(
                        adfocusChangeListener, AudioManager.STREAM_MUSIC, AudioManager.AUDIOFOCUS_GAIN_TRANSIENT);
                /**AUDIOFOCUS_REQUEST_GRANTED 标识拿到控制,然后再将监听释放**/
                if (result == AudioManager.AUDIOFOCUS_REQUEST_GRANTED) {
                    if (audioManager != null) {
                        audioManager.abandonAudioFocus(adfocusChangeListener);
                    }
                }
    

      

        /**
         * 获取音频焦点
         **/
        private AudioManager.OnAudioFocusChangeListener adfocusChangeListener = new AudioManager.OnAudioFocusChangeListener() {
            public void onAudioFocusChange(int focusChange) {
            }
        };
    

      

    onAudioFocusChange()方法的focusChange参数指示了该AudioFocus的竞争者对AudioFocus的拥有情况,取值如下:

    •  AUDIOFOCUS_GAIN:获得了Audio Focus;
    •  AUDIOFOCUS_LOSS:失去了Audio Focus,并将会持续很长的时间。这里因为可能会停掉很长时间,所以不仅仅要停止Audio的播放,最好直接释放掉Media资源。而因为停止播放Audio的时间会很长,如果程序因为这个原因而失去AudioFocus,最好不要让它再次自动获得AudioFocus而继续播放,不然突然冒出来的声音会让用户感觉莫名其妙,感受很不好。这里直接放弃AudioFocus,当然也不用再侦听远程播放控制【如下面代码的处理】。要再次播放,除非用户再在界面上点击开始播放,才重新初始化Media,进行播放。
    •  AUDIOFOCUS_LOSS_TRANSIENT:暂时失去Audio Focus,并会很快再次获得。必须停止Audio的播放,但是因为可能会很快再次获得AudioFocus,这里可以不释放Media资源;
    •  AUDIOFOCUS_LOSS_TRANSIENT_CAN_DUCK:暂时失去AudioFocus,但是可以继续播放,不过要在降低音量。
  • 相关阅读:
    tidb的数据校验工具sync-diff-inspector
    tidb的binlog同步工具TiDB Binlog
    tidb的数据同步ticdc
    tidb的数据备份与恢复工具br
    tiup的数据同步工具dm
    反人类设计是如何炼成的?
    tidb的tidb组件的配置文件详解
    tidb的tikv配置详解
    tidb的pd配置详解
    tidb的tiup工具
  • 原文地址:https://www.cnblogs.com/xueqiang911226/p/8046292.html
Copyright © 2011-2022 走看看