Android组件化导致的代码不生效

先说问题,最近有一个小需求是对一个对话框的标题超过两行打点显示,如下图所示。在没有修改之前这个对话框是超过一行打点。


Paste_Image.png

这本来是一个非常简单的需求,原来是一行打点,实现是这样。

 android:ellipsize="end"
 android:maxLines="1"

我只需要将maxLines="1"中的1改成2即可。

 android:ellipsize="end"
 android:maxLines="2"

如果问题就这样解决了,也就没必要写这篇文章了。

诡异的现象

程序运行后发现,代码并没有生效,对话框还是一行打点。最开始以为是Android studio的问题,于是重启重新编译运行,发现还是没有生效。然后我试了另外两种方式居然生效了。
一种方式是在代码中设置最大行数。

 TextView mTvTitle = (TextView) layout.findViewById(R.id.tv_title);
 mTvTitle.setMaxLines(2);

另一种方式是重新建一个工程,将相关的代码原封不动的拷贝过去。
这个现象非常奇怪,有两个问题需要思考:
1、为什么相同的代码在不同的工程里却有不同的结果。
2、为什么在布局文件里,代码没有生效,而在代码中设置就生效了。

于是我带着这两个问题思考下去。
先看第一个问题:

为什么相同的代码在不同的工程里却有不同的结果。

第一个工程是一个很庞大的工程,另一个是新建的工程。虽然他们的对话框的代码是一样的,但是他们的环境是不一样的。我最开始想到是不是他们的SDK的版本,主题,项目依赖的库不同造成的。做了一些对比试验后这些猜测都被否决了,TextView 是android.widget包下的类,也不太可能受其他库的影响。因为两个工程不相同的东西太多,也没办法一一做对比试验,只好放弃。

第一个问题无果,再看第二个问题:

为什么在布局文件里,代码没有生效,而在代码中设置就生效了。

最开始我以为是不是ellipsize和maxLines一起使用冲突的问题,因为之前发现过在TextView 中同时使用 ellipsize=start/middle/marquee/none (ellipsize=end不会报错)和 maxLines属性可能导致运行时崩溃。根据Google Issue 上的报告,这个 bug 从 Android 4.1 到 7.0 都有人报告。
对应的issue: https://issuetracker.google.com/issues/36950033
不过很快这个想法也被否决了,因为在我修改之前ellipsize=end与maxLines=1是结合使用的,并且也出现了一行打点的效果。

柳暗花明

思考了一圈没有找到问题的原因,不过可以肯定的是ellipsize=end与maxLines结合使用是没有问题的,问题的关键是我修改了布局文件却没有生效。那么就只剩下一种可能,这个布局文件没有被使用,还有另一个相同的布局文件存在,想到这的时候,细思极恐,仿佛找到了真正的杀人凶手一般,而这个杀手一直隐藏在你的身后。
按照这个思路我去全局搜索了一下这个布局文件,结果和预期的一样,真的有两个相同命名的文件。

Paste_Image.png

一个在主工程一个在中间层的module中。

结果已经很清晰了,原来是其他同事在做组件化的过程中,将一些公共组件移到另外的module时是通过复制粘贴的方式,而这样的方式很容易导致主工程的一些文件忘记删除。而程序在找布局文件时会优先从主工程开始找,所以便出现了我们在中间层的module中修改代码却没有生效的情况。上文中出现的两个诡异现象也就很好解释了。

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,398评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,016评论 4 62
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,725评论 1 92
  • 北京时间6月13日,2018俄罗斯世界杯亚洲区预选赛十二强阶段比赛第八轮迎来一场万众瞩目的交锋,中国男足国家队奔赴...
    枫桥落夜阅读 395评论 4 2
  • 今天下雨了,下了很大的雨,带走了闷热,带来了清爽,也涤荡了心灵,谢谢大自然这无穷的变化,才能给我们带来舒适的环境,...
    安奇_306e阅读 151评论 0 0