用代码实现文字扩散对齐

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;
	}

}





运行后如下图:


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值