android 的TextView有居中,左对齐,右对齐,但没有扩散对齐
总体效果:如图
红线款里面的逗号为界限,左边的当标题,对齐,如果只有一个这样的布局直接在xml里面手动对齐也挺容易的,如果一个应用程序里面有很多这种对齐方式,在xml里面每个就要这样配置就比较费事了。请参考代码
package com.javase.test;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Set;
/**
* 扩散对齐
* <p>
*
* @author 作者不详
* @version 2016年7月14日
*/
public class TextAlign {
public static void main(String[] args) {
MapTwo mapTwo = new MapTwo();
mapTwo.put("今天天气不错:", " || 内容");
mapTwo.put("今天天不错:", " || 内容");
mapTwo.put("天气不错:", " || 内容");
mapTwo.put("天天错:", " || 内容");
mapTwo.put("不错:", " || 内容");
mapTwo.put("错:", " || 内容");
mapTwo.put(":", " || 内容");
textHeadAlign(mapTwo);
print(mapTwo, "---7个字符对齐----");
mapTwo = new MapTwo();
mapTwo.put("今天天不错:", " || 内容");
mapTwo.put("天气不错:", " || 内容");
mapTwo.put("天天错:", " || 内容");
mapTwo.put("不错:", " || 内容");
mapTwo.put("错:", " || 内容");
mapTwo.put(":", " || 内容");
textHeadAlign(mapTwo);
print(mapTwo, "---6个字符对齐----");
mapTwo = new MapTwo();
mapTwo.put("天气不错:", " || 内容");
mapTwo.put("天天错:", " || 内容");
mapTwo.put("不错:", " || 内容");
mapTwo.put("错:", " || 内容");
mapTwo.put(":", " || 内容");
textHeadAlign(mapTwo);
print(mapTwo, "---5个字符对齐----");
mapTwo = new MapTwo();
mapTwo.put("天天错:", " || 内容");
mapTwo.put("不错:", " || 内容");
mapTwo.put("错:", " || 内容");
mapTwo.put(":", " || 内容");
textHeadAlign(mapTwo);
print(mapTwo, "---4个字符对齐----");
mapTwo = new MapTwo();
mapTwo.put("不错:", " || 内容");
mapTwo.put("错:", " || 内容");
mapTwo.put(":", " || 内容");
textHeadAlign(mapTwo);
print(mapTwo, "---3个字符对齐----");
mapTwo = new MapTwo();
mapTwo.put("错:", " || 内容");
mapTwo.put(":", " || 内容");
textHeadAlign(mapTwo);
print(mapTwo, "---2个字符对齐----");
}
public static void print(MapTwo item, String title) {
System.out.println(title);
Set<Integer> keySet = item.keySet();
for (Integer key : keySet) {
String get1 = item.get(key);
String get2 = item.get1(key);
System.out.println(get1 + get2);
}
System.out.println("");
}
//集合排版
public static void textHeadAlign(HashMap<Integer, String> map) {
Set<Integer> keySet = map.keySet();
int max = 0;
for (Integer integer : keySet) {
String value = map.get(integer);
if (value == null)
continue;
int len = value.length();
if (len > max)
max = len;
}
if (max > 7) {
// Log.i("textAlign", "大于7个字还没提供解决方案...");
return;
}
keySet = map.keySet();
for (Integer integer : keySet) {
String value = map.get(integer);
if (value == null)
continue;
map.put(integer, typeSetting(value, max));
}
}
/**
* 设置文字排版
*
* @param tv
* @param max 最长的标题,按照几个字排版
*/
public static void setTypeSettingText(TextView tv, int max) {
tv.setText(typeSetting(tv.getText().toString(), max));
}
// 返回文字排版后的内容,max 最长的标题个数
public static String typeSetting(String value, int max) {
int len = value.length();
int cha = 0;
if (len < max)
cha = max - len;
else
return value;
String fullWidthSpace = " ";// 全角空格
String halfWidthSpace = " ";// 两个半角空格
String temp = "";
if (max == 7 || max == 6) {
if (len <= 2) {
for (int i = 0; i < cha; i++)
temp += fullWidthSpace;
return temp + value;
} else if (len == 3) {
for (int i = 0; i < cha; i++)
temp += fullWidthSpace;
String start = value.substring(0, 1);
String end = value.substring(1);
return start + temp + end;
} else if (len == 4) {// 四个字符
boolean isBaseNumber = cha % 2 == 1;
temp += fullWidthSpace;// 全角空格
if (isBaseNumber) // 基数
temp += halfWidthSpace;// 两个半角空格,一个不行,两个稍微有丁点多
String start = value.substring(0, 1);
String middlen = value.substring(1, 2);
String end = value.substring(2);
return start + temp + middlen + temp + end;
} else if (len == 5) {// 5个字符
for (int i = 0; i < cha; i++)
temp += fullWidthSpace;// 全角空格
String start = value.substring(0, 2);
String end = value.substring(2);
return start + temp + end;
} else if (len == 6) {// 6个字符
temp = halfWidthSpace;
String start = value.substring(0, 2);
String middlen = value.substring(2, 4);
String end = value.substring(4);
return start + temp + middlen + temp + end;
}
return value;
}
// 五个字以内的对齐
if (len <= 2) {
for (int i = 0; i < cha; i++)
temp += fullWidthSpace;
return temp + value;
} else if (cha % 2 == 0) {
for (int i = 0; i < cha; i++)
temp = fullWidthSpace + temp;// 这个空格不是普通空格,是全角空格也可以用xml中四个 表示全角空格
String start = value.substring(0, 1);
String end = value.substring(1);
return start + temp + end;
} else if (max % len == 1 && len == 4) {
String srart = value.substring(0, 1);
String middlen = value.substring(1, 2);
String end = value.substring(2);
return srart + halfWidthSpace + middlen + halfWidthSpace + end;
} else if (max % len == 1 && len == 3) {// 3个字的
String srart = value.substring(0, 1);
String end = value.substring(1);
return srart + fullWidthSpace + end;// 一个字的空格
}
return value;
}
}
/**
* 一个key存储两个字段
* <p>
*
* @author 作者不详
* @version 2016年7月14日
*/
class MapTwo extends LinkedHashMap<Integer, String> {
private static final long serialVersionUID = 1L;
private String flag = "amAbac";
private int key = 0;
public String put(Integer key, String value, String value2) {
value = value + flag + value2;
return super.put(key, value);
}
public Integer removeKey(String value) {
int key = -1;
Set<Integer> keySet = keySet();
for (Integer integer : keySet) {
String string = get(integer);
if (string != null) {
boolean equals = string.equals(value);
if (equals) {
return integer;
}
}
}
return key;
}
@Override
public String remove(Object value) {
if (!(value instanceof Integer) || value.toString() == "-1") {
return null;
}
return super.remove(value);
}
// 标题和值
public String put(String value, String value2) {
value = value + flag + value2;
String put = super.put(key, value);
key++;
return put;
}
@Override
public String put(Integer key, String value) {
return put(key, value, get1(key));
}
public String get1(Integer key) {
String t1 = super.get(key);
if (t1 == null) {
return null;
}
String[] split = t1.split(flag);
if (split == null)
return null;
String result = null;
try {
result = split[1];
} catch (Exception e) {
}
return result;
}
@Override
public String get(Object key) {
String t1 = super.get(key);
if (t1 == null) {
return null;
}
String[] split = t1.split(flag);
if (split == null)
return null;
String result = null;
try {
result = split[0];
} catch (Exception e) {
}
return result;
}
}
运行后如下图: