TextView+Emoji

背景

21世紀(jì)最受歡迎的交流方式------------表情痛垛!

思路

  1. 解析表情
  2. 匹配表情
  3. 顯示表情

解析表情,使用正則表達(dá)式解析表情規(guī)則奏瞬。
匹配表情侄刽,將表情匹配我們本地的資源 。
顯示表情鹊汛,有兩種方式可以為TextView增加表情顯示蒲赂,一種是使用SpannableString配置ImageSpan,另一種是使用Html的方式刁憋。

開始

規(guī)則:#(文字或符號)

粘貼代碼有bug滥嘴,只能粘貼圖了.png

就這上面的圖,結(jié)果把


Paste_Image.png

轉(zhuǎn)換成了

Paste_Image.png

如下:

Pattern p = Pattern.compile("(#\\(([^#\\(\\) ]*?)\\))");
Matcher m = p.matcher(originString);

注意:
1至耻、對于()要使用\\轉(zhuǎn)義若皱,因?yàn)?)在Pattern里是關(guān)鍵符號,表示分組尘颓,如上最外層的括號就是一個(gè)分組走触,對于正則表達(dá)式,每次使用的時(shí)候都得查下api疤苹,相關(guān)定義查閱互广。
2、請已第一張圖為準(zhǔn)(還是agroup好用哇~)卧土。

值得提一下的是惫皱,Matcher的方法有個(gè)groupCount,用來獲取表達(dá)式有多少個(gè)分組夸溶,這個(gè)分組不是匹配正則的數(shù)量分組逸吵,而是前面說的以()括起來的分組,千萬別進(jìn)入誤區(qū)缝裁。

匹配:我們將表情匹配對應(yīng)本地的資源扫皱,比如#(高興)對應(yīng)成該表情的本地路徑或資源名稱

我將表情存放到assets文件夾中,表情對應(yīng)路徑按照有序規(guī)則存放捷绑,這樣方便遍歷賦值韩脑。

private String[] emojiTextArray = {"呵呵", "哈哈", "吐舌", "啊粹污?", "酷"};
<string-array name="emoji_text_array">
    <item>呵呵</item>
    <item>哈哈</item>
    <item>吐舌</item>
    <item>岸味唷?</item>
    <item>酷</item>
</string-array>

我這里簡便的硬編碼了壮吩,最好抽成資源到string.xml中进苍。

private final String PREFIX = "emoji/face/image_editoricon";
private final String SUFFIX = "@2x.png";

由于我的資源規(guī)則一定的加缘,所以我定義規(guī)則,方便遍歷觉啊。

public List<EmojiData> getEmojiList() {
    List<EmojiData> emojiDatas = new ArrayList<>();
    EmojiData emojiData;
    int index = 1;
    for (String text : emojiTextArray) {
        emojiData = new EmojiData();
        emojiData.text = text;
        emojiData.path = PREFIX + index + SUFFIX;
        emojiDatas.add(emojiData);
        index++;
    }
    return emojiDatas;
}

一定要保證你的字符串資源與存放到本地的資源數(shù)量相同拣宏,否則會(huì)出現(xiàn)找不到資源的問題,這里最好也增加對應(yīng)本地資源數(shù)量的判斷杠人。

顯示

ImageSpan

主要是采用下標(biāo)及drawable替換下標(biāo)范圍內(nèi)的文字為drawable勋乾。

List<EmojiData> emojiDatas = getEmojiList();
    String key;

    SpannableString destString = new SpannableString(originString);
    while (m.find()) {
        key = originString.substring(m.start(), m.end());
        String innerKey = key.substring(2, key.length() -1);
        ImageSpan imageSpan = null;
        for (EmojiData emojiData : emojiDatas) {
            if (innerKey.equals(emojiData.text)) {
                Drawable drawable =          getImageFromAssetsFile(emojiData.path);
                if (drawable != null) {
                    drawable.setBounds(0, 0, BaseApplication.getInst().getResources().getDimensionPixelSize(R.dimen.ds40),
                            BaseApplication.getInst().getResources().getDimensionPixelSize(R.dimen.ds40));
                    imageSpan = new ImageSpan(drawable);
                }
                break;
            }
        }
        if (imageSpan != null) {
            destString.setSpan(imageSpan, m.start(), m.end(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
        }
    }

Html

主要是使用html的<img>標(biāo)簽

List<EmojiData> emojiDatas = getEmojiList();
    String key;
    Map<String, String> map = new HashMap<>();
    String value = "";
    while (m.find()) {
        key = originString.substring(m.start(), m.end());
        String innerKey = key.substring(2, key.length() -1);
        for (EmojiData emojiData : emojiDatas) {
            if (innerKey.equals(emojiData.text)) {
                value = key.replace(key, "![](" + emojiData.path + ")");
                break;
            }
        }
        map.put(key, value);
    }

    for (String tempKey : map.keySet()) {
        originString = originString.replace(tempKey, map.get(tempKey));
    }

    CharSequence destString = Html.fromHtml(originString, new Html.ImageGetter() {
        @Override
        public Drawable getDrawable(String source) {
            Drawable drawable = getImageFromAssetsFile(source);
            drawable.setBounds(0, 0, BaseApplication.getInst().getResources().getDimensionPixelSize(R.dimen.ds40),
                    BaseApplication.getInst().getResources().getDimensionPixelSize(R.dimen.ds40));
            return drawable;
        }
    }, null);

兩者的差別在于Html多了一步解析的過程。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末嗡善,一起剝皮案震驚了整個(gè)濱河市辑莫,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌罩引,老刑警劉巖各吨,帶你破解...
    沈念sama閱讀 221,273評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異袁铐,居然都是意外死亡绅你,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評論 3 398
  • 文/潘曉璐 我一進(jìn)店門昭躺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來忌锯,“玉大人,你說我怎么就攤上這事领炫∨伎澹” “怎么了?”我有些...
    開封第一講書人閱讀 167,709評論 0 360
  • 文/不壞的土叔 我叫張陵帝洪,是天一觀的道長似舵。 經(jīng)常有香客問我,道長葱峡,這世上最難降的妖魔是什么砚哗? 我笑而不...
    開封第一講書人閱讀 59,520評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮砰奕,結(jié)果婚禮上蛛芥,老公的妹妹穿的比我還像新娘。我一直安慰自己军援,他們只是感情好仅淑,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著胸哥,像睡著了一般涯竟。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,158評論 1 308
  • 那天庐船,我揣著相機(jī)與錄音银酬,去河邊找鬼。 笑死筐钟,一個(gè)胖子當(dāng)著我的面吹牛捡硅,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播盗棵,決...
    沈念sama閱讀 40,755評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼北发!你這毒婦竟也來了纹因?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,660評論 0 276
  • 序言:老撾萬榮一對情侶失蹤琳拨,失蹤者是張志新(化名)和其女友劉穎瞭恰,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體狱庇,經(jīng)...
    沈念sama閱讀 46,203評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡惊畏,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了密任。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片颜启。...
    茶點(diǎn)故事閱讀 40,427評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖浪讳,靈堂內(nèi)的尸體忽然破棺而出缰盏,到底是詐尸還是另有隱情,我是刑警寧澤淹遵,帶...
    沈念sama閱讀 36,122評論 5 349
  • 正文 年R本政府宣布口猜,位于F島的核電站,受9級特大地震影響透揣,放射性物質(zhì)發(fā)生泄漏济炎。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評論 3 333
  • 文/蒙蒙 一辐真、第九天 我趴在偏房一處隱蔽的房頂上張望须尚。 院中可真熱鬧,春花似錦侍咱、人聲如沸恨闪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽咙咽。三九已至,卻和暖如春淤年,著一層夾襖步出監(jiān)牢的瞬間钧敞,已是汗流浹背蜡豹。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留溉苛,地道東北人镜廉。 一個(gè)月前我還...
    沈念sama閱讀 48,808評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像愚战,于是被迫代替她去往敵國和親娇唯。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評論 2 359

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理寂玲,服務(wù)發(fā)現(xiàn)塔插,斷路器,智...
    卡卡羅2017閱讀 134,693評論 18 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,264評論 25 707
  • 1. 前兩天終于在簡書注冊,開始了在簡書上的寫作之旅断序。于是流纹,我與大家分享了《堅(jiān)持3個(gè)月,寫作給我?guī)淼?個(gè)變化》违诗,...
    旅人記閱讀 328評論 17 8
  • 文|文小輝 與別人交談時(shí)答非所問诸迟? 匯報(bào)工作時(shí)抓不住重點(diǎn)碉哑? 自我介紹時(shí)不能快速突出亮點(diǎn)? ………… 《如何在30秒...
    文小輝cool閱讀 245評論 0 2
  • 上周,我才剛剛結(jié)束從內(nèi)蒙古之旅回到家慎玖。 用照片來記錄一下美食和美景贮尖。 呼和浩特 一下飛機(jī)就感受到了北方干燥的空氣。...
    歲月如歌閱讀 2,251評論 10 5