Android TagCloudView云标签的灵活运用

这两天做了一个项目,发现标签不能更改任意一个标签的字体的颜色,需求如同置前标签,然后就对tagcloudeview稍做修改做了这么一个demo。不为别的,只为以后自己用的时候方便拷贝。
先看效果图:

示意图

这两天做了一个项目,需求如同置前标签,然后就对tagcloudeview稍做修改做了这么一个demo。不为别的,只为以后自己用的时候方便拷贝。
云标签开源地址https://github.com/kingideayou/TagCloudView
本项目开源地址:https://github.com/a12a15a05/TagCloudViewDemo
在源码里面加了两个方法

/**修改某些位置定点颜色**/

public void setTagsByPosition(HashMap<Integer, Boolean> positions, List<String> tagList){

this.tags = tagList;

this.removeAllViews();

if (tags != null && tags.size() > 0) {

for (int i = 0; i < tags.size(); i++) {

TextView tagView = (TextView) mInflater.inflate(mTagResId, null);

if (mTagResId == DEFAULT_TAG_RESID) {

tagView.setBackgroundResource(mBackground);

tagView.setTextSize(TypedValue.COMPLEX_UNIT_SP, mTagSize);

if (positions.get(i)){

tagView.setTextColor(mSeclectTagColor);

}else{

tagView.setTextColor(mTagColor);

}

}

LayoutParams layoutParams = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);

tagView.setLayoutParams(layoutParams);

tagView.setText(tags.get(i));

tagView.setTag(TYPE_TEXT_NORMAL);

final int finalI = i;

tagView.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

if (onTagClickListener != null) {

onTagClickListener.onTagClick(finalI);

}

}

});

addView(tagView);

}

}

postInvalidate();

}

/**最前面的修改颜色**/

public void setTagsByLength(int length,List<String> tagList){

this.tags = tagList;

this.removeAllViews();

if (tags != null && tags.size() > 0) {

for (int i = 0; i < tags.size(); i++) {

TextView tagView = (TextView) mInflater.inflate(mTagResId, null);

if (mTagResId == DEFAULT_TAG_RESID) {

tagView.setBackgroundResource(mBackground);

tagView.setTextSize(TypedValue.COMPLEX_UNIT_SP, mTagSize);

if (i >= length){

tagView.setTextColor(mTagColor);

}else{

tagView.setTextColor(mSeclectTagColor);

}

}

LayoutParams layoutParams = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);

tagView.setLayoutParams(layoutParams);

tagView.setText(tags.get(i));

tagView.setTag(TYPE_TEXT_NORMAL);

final int finalI = i;

tagView.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

if (onTagClickListener != null) {

onTagClickListener.onTagClick(finalI);

}

}

});

addView(tagView);

}

}

postInvalidate();

}

一目了然的方法,所以不多做解释 另外加了一个选中字体颜色的全局常量,和一个int变量

private static final int SELCECT_TEXT_COLOR = R.color.yellow_bg;//选中后的标签颜色 
private int mSeclectTagColor;

在styles.xml中给TagCloudView增加了一个选中字体颜色的attr

<attr name="tcvSeclecTextColor" format="reference" />

剩下就是运用的地方不多说,直接上代码

public class MainActivity extends AppCompatActivity {

private TagCloudView normalTagView;//标准

private TagCloudView selectTagUseView;//置前

private TagCloudView positionsView;//定点

private List<String> AllTagsNormal = new ArrayList<>(0);//整个标签存放集合

private List<String> AllTagsSelect = new ArrayList<>(0);//整个标签存放集合

private List<String> AllTagsPosition = new ArrayList<>(0);//整个标签存放集合

private List<String> selectTags = new ArrayList<>(0);//选中的标签

private List<String> notSelectTags = new ArrayList<>(0);//未选中的标签

private HashMap<Integer, Boolean> map = new HashMap<>(0);//记录选择的位置

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);

normalTagView = (TagCloudView) findViewById(R.id.normalTag);

selectTagUseView = (TagCloudView) findViewById(R.id.selcetTagUse);

positionsView = (TagCloudView) findViewById(R.id.positionsTag);

setSupportActionBar(toolbar);

for (int i = 0; i < 15; i++) {

AllTagsNormal.add("普通标签" + i);

AllTagsSelect.add("置前标签" + i);

AllTagsPosition.add("定点标签" + i);

map.put(i, false);

}

normalTagView.setOnTagClickListener(new TagCloudView.OnTagClickListener() {

@Override

public void onTagClick(int position) {

Snackbar.make(normalTagView, AllTagsNormal.get(position), Snackbar.LENGTH_LONG)

.setAction("Action", null).show();

}

});

selectTagUseView.setOnTagClickListener(new TagCloudView.OnTagClickListener() {

@Override

public void onTagClick(int position) {

if (selectTags.contains(AllTagsSelect.get(position))) {//如果选中的里面有 就删掉 扔到未选中的里面去

selectTags.remove(position);

notSelectTags.add(AllTagsSelect.get(position));

} else {

selectTags.add(AllTagsSelect.get(position));//

notSelectTags.remove(position - selectTags.size() + 1);

}

Snackbar.make(selectTagUseView, AllTagsSelect.get(position), Snackbar.LENGTH_LONG)

.setAction("Action", null).show();

AllTagsSelect.clear();//清空,重新装数据

AllTagsSelect.addAll(selectTags);

AllTagsSelect.addAll(notSelectTags);

bindSelectUseView(selectTags.size());

}

});

positionsView.setOnTagClickListener(new TagCloudView.OnTagClickListener() {

@Override

public void onTagClick(int position) {

bindPositionView(position);

Snackbar.make(positionsView, AllTagsPosition.get(position), Snackbar.LENGTH_LONG)

.setAction("Action", null).show();

}

});

normalTagView.setTags(AllTagsNormal);

int selectLength = 4;

bindSelectUseView(selectLength);

//用一个hashmap存放当前位置是否需要变色

bindPositionView(3);

bindPositionView(6);

bindPositionView(9);

}

/**

 * 定点标签记录和view变化

 **/

private void bindPositionView(int position) {

for (int i = 0; i < AllTagsPosition.size(); i++) {

if (i == position) {

if (map.get(i)) {

map.put(i, false);

} else {

map.put(i, true);

}

} else {

if (map.get(i)) {

map.put(i, true);

} else {

map.put(i, false);

}

}

}

positionsView.setTagsByPosition(map, AllTagsPosition);

for (int i = 0; i < AllTagsPosition.size(); i++) {

if (map.get(i)) {

positionsView.getChildAt(i).setBackgroundResource(R.drawable.edit_style_yellow);

}

}

}

/**

 * 选中标签的运用

 **/

private void bindSelectUseView(int selectLength) {

selectTagUseView.setTagsByLength(selectLength, AllTagsSelect);

selectTags.clear();

notSelectTags.clear();

for (int i = 0; i < AllTagsSelect.size(); i++) {

if (i < selectLength) {

selectTags.add(AllTagsSelect.get(i));//选中的存放入集合

selectTagUseView.getChildAt(i).setBackgroundResource(R.drawable.edit_style_yellow);

} else {

notSelectTags.add(AllTagsSelect.get(i));//未选中的存放入集合

}

}

}

@Override

public boolean onCreateOptionsMenu(Menu menu) {

// Inflate the menu; this adds items to the action bar if it is present.

getMenuInflater().inflate(R.menu.menu_main, menu);

return true;

}

@Override

public boolean onOptionsItemSelected(MenuItem item) {

// Handle action bar item clicks here. The action bar will

// automatically handle clicks on the Home/Up button, so long

// as you specify a parent activity in AndroidManifest.xml.

int id = item.getItemId();

//noinspection SimplifiableIfStatement

if (id == R.id.action_settings) {

return true;

}

return super.onOptionsItemSelected(item);

}

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,907评论 25 707
  • HTML标签解释大全 一、HTML标记 标签:!DOCTYPE 说明:指定了 HTML 文档遵循的文档类型定义(D...
    米塔塔阅读 3,232评论 1 41
  • 财商教育 在今天看来财商教育已经是需要在各年龄层推广的事情了:小至幼儿园,中至成年人,大至老人……但不管在哪个年龄...
    日鑫悦益阅读 210评论 0 0
  • 《欢乐颂》的热播,又一次掀起了一股共鸣与吐槽的热潮。共鸣是因为大家在五位女主的身上都或多或多少的找到自己影子或...
    TAOLI阅读 909评论 5 2