需求是实现字体的横向和竖向切换,并且切换成竖排的了字体方向不能变吧, 咱还得横着读,于是开始分析需求, 那普通的TextView也没发现竖着但是字体方向不变的啊, 如果把Textview旋转90度字体方向也变了,于是上网各种查阅,发现资料甚少, 但是最终发现了一个思路就是每一个字是一个TextView,我仔细的想了想貌似可行,那就开始搞吧, 虽然发现了思路但是并没有源代码让我直接用, 所以本人自己自定义了一个LinearLayout, 下面看下效果图:
做到这的时候我真的很欣慰,因为我和公司同事说这个想法的时候遭到了嘲笑哈哈,这更加坚定了我要完成它的目标,期间也遇到了一些难点,接下来说一下核心的思路:
-
遇到了第一个难点, 怎么换行啊
解决方案 :一个TextView挨着一个, 换行怎么办, 当从一个EditText输入 一段文字时, 换行是有换行符的啊, 于是开始实践, 将输入的文字转成char[], 然后遍历它,当遇到换行的地方记录此时到了第几个字符。 -
第二个难点, 即使是记录了到第几个字符换行,那都是Textview还是一行啊
解决方案:此时我只能大胆想象了,那我用多个LinearLayout存储Textview, 外层控制方向, 里面也可以控制方向,二话不说,直接尝试,答案是可行的, 贴下核心代码:
private void addText() {
//在添加字之前移除所有已经添加的View
removeAllViews();
//存储换行字符的位置
ns = new ArrayList<Integer>();
if (text != null) {
//转成char[] 可遍历
char[] chars = text.toCharArray();
//后面要截取从0到换行符的字符添加到LinearLayout中 所以要加0
ns.add(0);
for (int i = 0; i < chars.length; i++) {
//当碰到换行符 add it
if(String.valueOf(text.charAt(i)).equals("\n")){
ns.add(i);
}
}
//最后加到字符末尾 注意是length()
ns.add(text.length());
//我们不能确定有多少换行符, 那也不能确定有多少个Linearlayout 所以这里根据换行符个数来写
customLinearlayouts = new CustomLinearlayout[ns.size()-1];
for(int i=0; i<ns.size()-1; i++){
customLinearlayouts[i] = new CustomLinearlayout(context);
customLinearlayouts[i].setTextColor(color);
customLinearlayouts[i].setTextSize(size);
//将每个字符设置到一个Textview上并且添加到customLinearlayouts中
customLinearlayouts[i].setText((text.substring(ns.get(i), ns.get(i+1)).trim()));
//最后将所有的customLinearlayouts 加入到最大的 Linearlayout中
addView(customLinearlayouts[i]);
}
setChildViewOrientation(customLinearlayouts, orientation);
}
}
肺腑之言: 自定义View最好自己一步步写
注释详细, 不多解释了, 这是我第一次自己写自定义View,让我真正感觉到是我在创造代码的感觉,都说自定义View很难, 我想就难在创造代码创造作品的过程中吧, 不过在实现的那一刻感觉不言而喻, 想了半个小时写了一行代码的感觉,真的是大部分时间都在思考, 想想写代码的时候很多自定义view都是从别人的github上下载的,都不如自己写的,好亲切啊哈哈, 刚实现的时候我就想快点把它分享出来, 虽然还有一些细节需要处理,但是大的框已经实现, 我会把它优化好,也会上传到github上, 如果你用到了给我点个star,点个不亏。