美好的一天,从解决一个诡异的小 bug 开始!

一个困扰了我两天的 bug,今天终于算是解决了,其实就删了一个方法的调用,这里简单记录一下。

App 所做的功能是视频播放,之前的大半年是运行在 Android 4.4.2 系统上的,上周换了新设备,搭载的 Android 5.1.1 系统,这个 bug 就出现了。有人纳闷,为什么之前没做系统适配,到现在才发现问题,这里我只能告诉你,公司的产品做的是某种设备的定制开发,专门用在一个行业用的。想必这么说就明白了。

表现的问题是新设备上无法播放视频了,Log 信息是:

libijkffmpeg.so: unused DT entry: type 0x6ffffffe arg 0x4cac4
...
libijkffsdl.so: unused DT entry: type 0x6ffffffe arg 0xe42c
...
libijkplayer.so: unused DT entry: type 0x6ffffffe arg 0x9410
...
J4ALoader: Ignore: 'android.media.PlaybackParams' need API 22
...

这里贴张图:

ijkplayer Log

这些 Log 指向了 libijkplayer 相关的 so 文件的问题,
首先再次引入了 ijk 相关的 so 文件,gradle 文件里相关配置都做了,仍不行,网上浏览了多篇加载 so 文件的文章,反复确认加载过程无误。
其次在 Google、GitHub issues、Stack Overflow 等等找寻解决方法,git 上虽有类似问题的字眼,但也无具体的解决办法,有的也是清理工程,重新编译,自然又好了。。。WTF...

这一天就过去了......

第二天再折腾,还是各种无解。中午老大问那个问题好了吗,不行的话就重新找个播放器框架。纳尼,再找个新的合适的框架谈何容易,这个在去年试了多少框架,踩了多少坑才做好的,再重新做,又得重构代码结构了。当然我只是淡淡的回了个“哦”。

说什么也不甘心,必须把它整好了。还有即将在这家公司离职了,不能留着这个遗憾离开啊,说我能力不行搞不定离开的。O(∩_∩)O哈哈~

一步一步分析,多种情况下查看现象和 Log,还是一样的结果。喝杯茶,换换脑子 ~,起身到外面溜达了一圈,有了一个 idea,好吧,重新建个工程,仍用此框架做视频播放,要是还不行,那就是设备真不支持这个框架,只能放弃了。哎呀 ~ 竟然可以播放了。有希望了~~

比较两个工程不同的地方,gradle 配置文件,播放流程等等,最后发现了是个过渡动画的地方不一致。直接去了,不用动画了,要啥自行车!!果然好了,能播放了。

到此时也就知道了为什么不能播放视频了,其实跟 ijk 的 so 库有没有加载没有关系,Log 的信息引导错了问题调查的方向,不过也不能怪 Log 有问题,还是我们自己的失误丢失了某些东西。我的问题是只在播放界面做了要实现怎样的动画,而没在前一个界面做跳转时为其指定。下面贴出要实现的正确代码。

  • step 1. 跳转前
Intent intent = new Intent(context, GSYPlayerActivity.class);
intent.putExtra(GSYPlayerActivity.TRANSITION, true);
if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.LOLLIPOP) {
    Pair pair = new Pair<>(mBtnOpenVideo, GSYPlayerActivity.IMG_TRANSITION);
    activityOptions = ActivityOptionsCompat.makeSceneTransitionAnimation(
            context, pair);
    ActivityCompat.startActivity(context, intent, activityOptions.toBundle());
} else {
    context.startActivity(intent);
    context.overridePendingTransition(R.anim.abc_fade_in, R.anim.abc_fade_out);
}
  • step 2. 跳转后,在过渡动画里开始播放(videoPlayer.startPlayLogic())
...
isTransition = getIntent().getBooleanExtra(TRANSITION, false);
...
private void initTransition() {
    if (isTransition && Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
        postponeEnterTransition();
        ViewCompat.setTransitionName(videoPlayer, IMG_TRANSITION);
        addTransitionListener();
        startPostponedEnterTransition();
    } else {
        videoPlayer.startPlayLogic();
    }
}

@TargetApi(Build.VERSION_CODES.LOLLIPOP)
private boolean addTransitionListener() {
    transition = getWindow().getSharedElementEnterTransition();
    if (transition != null) {
        transition.addListener(new OnTransitionListener() {
            @Override
            public void onTransitionEnd(Transition transition) {
                super.onTransitionEnd(transition);
                videoPlayer.startPlayLogic();
                transition.removeListener(this);
            }
        });
        return true;
    }
    return false;
}

看到这里,应该懂动画的该吐槽我了。望轻吐,我承认我对此了解不深~~

好了写完这篇文章,我要去补一补动画这块的知识了~

最后总结一下吧。

  • 还是解决 bug 的技巧:首先定位问题表现,看看规律,排除其他外部干扰,之后断点跟踪···
  • 对待 bug 有点耐心,抱怨的心态永远解决不了问题。
  • 使用第三方框架认真理解作者的源码,出问题了对比原作的 simple,看自己丢了什么,大不了再新建工程重新来过。为什么别人都没问题就你的出问题了,先找自己的原因。

解决 bug,任重而道远。。。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 225,151评论 6 523
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 96,465评论 3 405
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 172,429评论 0 368
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 61,147评论 1 301
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 70,149评论 6 400
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 53,614评论 1 315
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 41,965评论 3 429
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 40,950评论 0 279
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 47,486评论 1 324
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 39,524评论 3 347
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 41,640评论 1 355
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 37,228评论 5 351
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 42,976评论 3 340
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 33,407评论 0 25
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 34,552评论 1 277
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 50,215评论 3 381
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 46,714评论 2 366

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,460评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,136评论 4 61
  • 宽恕的四大原则: 一、宽恕是要先从自己的内心开始。惟有宽恕了自己,我们才能宽恕别人,或接受别人的宽恕。 二、宽恕...
    海清我爱你阅读 730评论 0 2
  • 聽先生的課程,思維真的很開闊,明明是組織運營的課程,企業文化也在其中,商業模式也在其中……這就是先生常常說的,在贏...
    粟莎阅读 264评论 0 0
  • 凌晨4点半起床,打卡,不说话,赶稿写文章,希望能顺利验收。
    杨艺瀚阅读 228评论 0 0