亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

Android仿微信標簽功能

2019-10-21 21:34:18
字體:
來源:轉載
供稿:網友

微信中有對聯系人添加標簽的功能,如下圖所示。

Android,微信,標簽

這里有三種狀態的標簽,分別的未選擇,選中,編輯中,由于前兩種標簽不需要提供輸入,所以用TextView實現即可,編輯中的標簽用EditText來實現。而標簽的形狀就用Shape來實現。

在drawable下新建xml文件,這里先上Shape的xml文件。

tag_normal.xml

<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android"  android:shape="rectangle" >   <corners    android:bottomLeftRadius="10dp"    android:bottomRightRadius="10dp"    android:topLeftRadius="10dp"    android:topRightRadius="10dp" />  <stroke android:width="1dp" android:color="#66CDAA" />   <padding    android:bottom="4dp"    android:left="8dp"    android:right="8dp"    android:top="4dp" /> </shape>

tag_selected.xml

<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android"  android:shape="rectangle" >   <corners    android:bottomLeftRadius="10dp"    android:bottomRightRadius="10dp"    android:topLeftRadius="10dp"    android:topRightRadius="10dp" />  <stroke android:width="1dp" android:color="#66CDAA" />   <padding    android:bottom="4dp"    android:left="8dp"    android:right="8dp"    android:top="4dp" /> </shape>

tag_edit.xml

<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android"  android:shape="rectangle" >   <corners    android:bottomLeftRadius="10dp"    android:bottomRightRadius="10dp"    android:topLeftRadius="10dp"    android:topRightRadius="10dp" />  <!-- 這里實現虛線邊框--> <stroke android:dashWidth="5dp" android:dashGap="2dp" android:width="1dp" android:color="#e0e0e0" />   <padding    android:bottom="4dp"    android:left="8dp"    android:right="8dp"    android:top="4dp" /></shape>

接著在在布局文件中新建一個LinearLayout用以存放標簽(如果要實現多行標簽自適應添加,用自定義的FlowLayout,代碼網上很多。)

activity_main.xml

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  xmlns:tools="http://schemas.android.com/tools"  android:id="@+id/tag_container"  android:layout_width="match_parent"  android:layout_height="match_parent"  android:orientation="horizontal"  tools:context="com.qtree.tagdemo.MainActivity"> </LinearLayout>

      根據對微信標簽的分析,這里可以這樣實現,創建一個EditText,對其軟鍵盤的Enter和Delete按鍵進行監聽,當輸入完成后按下Enter則生成一個標簽,添加到LinearLayout中。然后如果當標簽內文字為空時,按下刪除鍵,就將它前一個標簽的狀態修改為選中狀態。同樣地,當點擊未選擇的標簽也可以選中該標簽進行刪除。

詳細實現如下

package com.qtree.tagdemo; import android.graphics.Color;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.text.Editable;import android.text.TextWatcher;import android.util.Log;import android.view.KeyEvent;import android.view.View;import android.view.ViewGroup;import android.widget.EditText;import android.widget.LinearLayout;import android.widget.TextView;import java.util.ArrayList;import java.util.List; public class MainActivity extends AppCompatActivity {   private LinearLayout layout;  private LinearLayout.LayoutParams params;   @Override  protected void onCreate(Bundle savedInstanceState) {    super.onCreate(savedInstanceState);    setContentView(R.layout.activity_main);     layout=(LinearLayout)findViewById(R.id.tag_container);     params=new LinearLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);    params.setMargins(30,30,0,0);     //存放標簽和標簽選擇狀態    final List<TextView> tagView=new ArrayList<>();    final List<Boolean> tagViewState=new ArrayList<>();     //創建編輯中的標簽    final EditText editText=new EditText(getApplicationContext());    editText.setHint("添加標簽");    //設置固定寬度    editText.setMinEms(4);    editText.setTextSize(12);    //設置shape    editText.setBackgroundResource(R.drawable.tag_edit);    editText.setHintTextColor(Color.parseColor("#b4b4b4"));    editText.setTextColor(Color.parseColor("#000000"));    editText.setLayoutParams(params);        //添加到layout中    layout.addView(editText);     //對軟鍵盤的Enter和Del鍵監聽    editText.setOnKeyListener(new View.OnKeyListener() {      @Override      public boolean onKey(View v, int keyCode, KeyEvent event) {         if (KeyEvent.ACTION_DOWN == event.getAction()) {          switch (keyCode) {            case KeyEvent.KEYCODE_ENTER:              String editTextContent = editText.getText().toString();              //判斷輸入是否為空              if (editTextContent.equals(""))                return true;              //判斷標簽是否重復添加              for(TextView tag:tagView){                String tempStr=tag.getText().toString();                if(tempStr.equals(editTextContent)) {                  Log.e("tag","重復添加");                  editText.setText("");                  editText.requestFocus();                  return true;                }              }              //添加標簽              final TextView temp = getTag(editText.getText().toString());              tagView.add(temp);              tagViewState.add(false);              //添加點擊事件,點擊變成選中狀態,選中狀態下被點擊則刪除              temp.setOnClickListener(new View.OnClickListener() {                @Override                public void onClick(View v) {                  int curIndex = tagView.indexOf(temp);                  if (!tagViewState.get(curIndex)) {                    //顯示 ×號刪除                    temp.setText(temp.getText() + " ×");                    temp.setBackgroundResource(R.drawable.tag_selected);                    temp.setTextColor(Color.parseColor("#ffffff"));                    //修改選中狀態                    tagViewState.set(curIndex, true);                  } else {                    layout.removeView(temp);                    tagView.remove(curIndex);                    tagViewState.remove(curIndex);                  }                }              });              layout.addView(temp);              //讓編輯框在最后一個位置上              editText.bringToFront();              //清空編輯框              editText.setText("");              editText.requestFocus();              return true;            case KeyEvent.KEYCODE_DEL:              int lastIndex = tagView.size() - 1;              //沒有添加標簽則不繼續執行              if (lastIndex < 0)                return false;              //獲取前一個標簽              TextView prevTag = tagView.get(lastIndex);              //第一次按下Del鍵則變成選中狀態,選中狀態下按Del鍵則刪除              if (tagViewState.get(lastIndex)) {                tagView.remove(prevTag);                tagViewState.remove(lastIndex);                layout.removeView(prevTag);              } else {                String te = editText.getText().toString();                if (te.equals("")) {                  prevTag.setText(prevTag.getText() + " ×");                  prevTag.setBackgroundResource(R.drawable.tag_selected);                  prevTag.setTextColor(Color.parseColor("#ffffff"));                  tagViewState.set(lastIndex, true);                }              }              break;          }         }        return false;      }     });     //監聽編輯標簽的輸入事件    editText.addTextChangedListener(new TextWatcher() {      @Override      public void beforeTextChanged(CharSequence s, int start, int count, int after) {       }       @Override      public void onTextChanged(CharSequence s, int start, int before, int count) {        //輸入文字時取消已經選中的標簽        for (int i = 0; i < tagViewState.size(); i++) {          if (tagViewState.get(i)) {            TextView tmp = tagView.get(i);            tmp.setText(tmp.getText().toString().replace(" ×", ""));            tagViewState.set(i, false);            tmp.setBackgroundResource(R.drawable.tag_normal);            tmp.setTextColor(Color.parseColor("#66CDAA"));          }        }      }       @Override      public void afterTextChanged(Editable s) {       }    });   }   /**   * 創建一個正常狀態的標簽   * @param tag   * @return   */  private TextView getTag(String tag){    TextView textView=new TextView(getApplicationContext());    textView.setTextSize(12);    textView.setBackgroundResource(R.drawable.tag_normal);    textView.setTextColor(Color.parseColor("#66CDAA"));    textView.setText(tag);    textView.setLayoutParams(params);    return textView;  } }

Android,微信,標簽

效果挺好。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人免费网站在线观看| xxx欧美精品| 亚洲午夜av电影| 国产激情综合五月久久| 国产一区二区久久精品| 亚洲精品一区二区网址| 成人免费观看49www在线观看| 欧美激情在线一区| 亚洲一区av在线播放| 亚洲一区二区在线| 欧美亚洲国产另类| 久久亚洲精品视频| 国产精品国产福利国产秒拍| 日韩av在线免费观看| 久久人人97超碰精品888| 国产美女91呻吟求| 久久久久久香蕉网| 国产脚交av在线一区二区| 中文字幕九色91在线| 欧美激情高清视频| 国产精品主播视频| 国产丝袜一区二区三区免费视频| 国产欧美精品日韩精品| 国产97人人超碰caoprom| 久久99视频精品| 亚洲国产精品视频在线观看| 一区二区三区视频观看| 国产亚洲精品美女| 国产专区欧美专区| 亚洲国产成人av在线| 亚洲自拍偷拍福利| 欧美日韩不卡合集视频| 日本一区二区在线免费播放| 欧美日韩国产中文精品字幕自在自线| 久久免费精品日本久久中文字幕| 清纯唯美日韩制服另类| 国产一区二区三区在线观看视频| 欧美最猛性xxxxx亚洲精品| 久久久国产在线视频| 国产精品免费久久久久久| 欧美在线国产精品| 欧美国产第二页| 97色在线观看| 国产成人亚洲综合91精品| 欧美性做爰毛片| 亚洲视频在线观看网站| 成人精品福利视频| 日韩欧美一区二区三区久久| 国产成人精品一区| 成人a级免费视频| 日本三级久久久| 日韩在线观看免费高清| 国产视频精品xxxx| 欧美日韩成人黄色| 日韩精品一二三四区| 国产欧美韩国高清| 一区二区欧美亚洲| 欧美夫妻性生活xx| 欧美精品第一页在线播放| 欧美日韩视频免费播放| 亚洲成人久久一区| 欧美日韩国产在线看| 国精产品一区一区三区有限在线| 91麻豆国产语对白在线观看| 久久人人爽亚洲精品天堂| 狠狠躁夜夜躁人人爽超碰91| 国产亚洲视频在线观看| 欧美激情国产高清| 日本久久久久亚洲中字幕| 欧美国产日韩一区二区| 精品国产精品三级精品av网址| 91成人在线观看国产| 亚洲免费av电影| 欧美精品一本久久男人的天堂| 日韩欧美在线第一页| 国产精品免费久久久| 色妞一区二区三区| 日韩福利视频在线观看| 亚洲人精品午夜在线观看| 色综合久久88色综合天天看泰| 欧美激情中文字幕乱码免费| 国产成人高潮免费观看精品| 日本高清+成人网在线观看| 日韩一区在线视频| 日韩成人av网| zzijzzij亚洲日本成熟少妇| 中文欧美日本在线资源| 91av国产在线| 热re99久久精品国产66热| 日韩精品福利网站| 91亚洲精品在线| 欧美激情区在线播放| 日韩在线观看电影| 国产亚洲欧洲黄色| 久久久久亚洲精品| 国产va免费精品高清在线观看| 久久91精品国产91久久久| 国产亚洲人成网站在线观看| 另类专区欧美制服同性| 亚洲国产成人精品久久| 午夜免费在线观看精品视频| 情事1991在线| 亚洲的天堂在线中文字幕| 国产不卡在线观看| 91精品国产电影| 欧美日韩激情小视频| 亚洲天堂第一页| 亚洲无av在线中文字幕| 国产午夜精品免费一区二区三区| 亚洲欧美国产精品va在线观看| 欧美一级免费视频| 中文字幕欧美精品日韩中文字幕| 久久成人一区二区| 色一情一乱一区二区| 日韩欧美一区二区三区久久| 国产在线播放不卡| 欧美大奶子在线| 日本久久久久久| 亚洲国产精品va在看黑人| 亚洲va欧美va国产综合久久| 色综合久久久久久中文网| 高清一区二区三区四区五区| 国产精品日韩欧美综合| 欧美精品在线播放| 久久大大胆人体| 欧洲精品在线视频| 日韩亚洲欧美成人| 欧美日韩性生活视频| 日韩精品一区二区视频| 久久精品视频99| 97婷婷涩涩精品一区| 97在线观看免费| 日本精品一区二区三区在线播放视频| 高清欧美性猛交xxxx| 国产精品久久久久福利| 亚洲精品视频免费| 国产精品影院在线观看| 亚洲sss综合天堂久久| 久久韩国免费视频| 欧美日韩美女在线观看| 日韩在线视频二区| 国产精品久久久久久久久久东京| 国产精品美女久久久免费| 国产精品主播视频| 国产成人精品av| 大桥未久av一区二区三区| 在线看片第一页欧美| 日韩综合视频在线观看| 一本色道久久综合狠狠躁篇的优点| 国产精品96久久久久久又黄又硬| 国产精品久久久久久久久久三级| 亚洲激情在线观看视频免费| 欧美激情小视频| 亚洲精品xxx| 97精品一区二区三区| 久久久国产视频91| 亚洲级视频在线观看免费1级| 国产成人一区二区三区电影| 亚洲男人的天堂在线| 欧美高清在线观看| 欧美国产日本高清在线| 国产免费一区二区三区在线能观看| 亚洲欧美综合精品久久成人| 欧美成人中文字幕在线|