android 编辑标签,在一个文本框输入标签回车添加退格删除

本文介绍如何在Android中创建一个编辑标签的功能,允许用户输入标签,通过回车或逗号生成新标签,同时支持删除和插入标签。每个标签还有特定的字符限制,英文计为1个字符,中文计为2个字符。示例代码包括activity和layout的设计,以及标签的背景图片。
摘要由CSDN通过智能技术生成

先上图:

       

最近产品需要一个编辑标签的页面如图所示。

需要实现可以输入标签,按回车键或逗号生成标签。并且可以移动光标删除标签,和插入标签。

并且单个标签有字符限制(英文算一个中文算两个字符)


直接上代码


activity的代码

package com.fan.tagtest;
import android.content.Context;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.v7.app.AppCompatActivity;
import android.text.Editable;
import android.text.InputFilter;
import android.text.Selection;
import android.text.Spannable;
import android.text.SpannableString;
import android.text.SpannableStringBuilder;
import android.text.Spanned;
import android.text.TextPaint;
import android.text.TextWatcher;
import android.text.style.ImageSpan;
import android.util.TypedValue;
import android.view.KeyEvent;
import android.view.View;
import android.view.inputmethod.InputMethodManager;
import android.widget.EditText;
import android.widget.FrameLayout;
import android.widget.TextView;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Comparator;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class MainActivity extends AppCompatActivity {


    List<String> source = new ArrayList<>();
    private static final int maxLength = 8;
    private static final boolean isChinese2English = true;

    public static void setEditTextInhibitInputSpeChat(EditText editText) {
        InputFilter filter = new InputFilter() {
            @Override
            public CharSequence filter(CharSequence source, int start, int end, Spanned dest, int dstart, int dend) {
                String chars = "\r\n\t ";
                String speChat = "[" + chars + "]";
                Pattern pattern = Pattern.compile(speChat);
                Matcher matcher = pattern.matcher(source.toString());
                if (matcher.find()) {
                    String str = source.toString();
                    char[] charArr = toCharArray(chars);
                    for (char c : charArr) {
                        str = str.replaceAll(new String(new char[]{c}), "");
                    }
                    return str;
                } else return null;
            }
        };
        InputFilter emojiFilter = new InputFilter() {

            @Override
            public CharSequence filter(CharSequence source, int start, int end, Spanned dest, int dstart, int dend) {
                for (int index = start; index < end; index++) {
                    int type = Character.getType(source.charAt(index));
                    if (type == Character.SURROGATE) {
                        return "";
                    }
                }
                return null;
            }
        };
        editText.setFilters(new InputFilter[]{filter, emojiFilter});
    }

    @NonNull
    private static MyImageSpanImage[] getSortedImageSpans(final Editable text) {
        MyImageSpanImage[] spans = text.getSpans(0, text.length(), MyImageSpanImage.class);

        Arrays.sort(spans, new Comparator<MyImageSpanImage>() {
            @Override
            public int compare(MyImageSpanImage o1, MyImageSpanImage o2) {
                int start1 = text.getSpanStart(o1);
                i
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在libgraphics中,可以使用 `inputbox()` 函数创建一个文本框,但是默认情况下只支持输入 ASCII 码字符。如果需要支持输入汉字,可以结合 `settextstyle()` 函数和 `outtextxy()` 函数来实现。具体实现方式如下: ``` #include <graphics.h> #include <conio.h> #include <string.h> #define MAX_INPUT 100 int main() { initwindow(640, 480); char input[MAX_INPUT + 1] = {0}; char temp[MAX_INPUT + 1] = {0}; int len = 0; int x = 50, y = 50; settextstyle(COMPLEX_FONT, HORIZ_DIR, 20); // 设置字体样式和大小 while (1) { if (kbhit()) { char ch = getch(); if (ch == '\r' || ch == '\n') { // 换行符作为输入结束标志 break; } else if (ch == '\b') { // 处理退格键 if (len > 0) { len--; input[len] = '\0'; x -= textwidth(temp); outtextxy(x, y, " "); // 删去光标前的字符 memset(temp, 0, sizeof(temp)); } } else { // 处理汉字输入 if (len < MAX_INPUT) { temp[0] = ch; temp[1] = '\0'; if (textwidth(temp) + x > 600) { // 超出文本框宽度时换行 x = 50; y += textheight(temp); } len += strlen(temp); strcat(input, temp); outtextxy(x, y, temp); x += textwidth(temp); memset(temp, 0, sizeof(temp)); } } } } outtextxy(50, y + textheight(temp), input); // 输出最终结果 getch(); closegraph(); return 0; } ``` 在上述代码中,首先使用 `settextstyle()` 函数设置字体样式和大小。然后,通过不断监听键盘输入的方式,处理用户的输入。对于汉字输入,可以先将输入的字符存储到一个临时缓冲区 `temp` 中,然后使用 `textwidth()` 函数计算出该字符的宽度,如果加上当前光标位置的横坐标超过了文本框的宽度,则将光标位置移动到下一行。最后,将输入的字符添加输入缓冲区 `input` 中,并使用 `outtextxy()` 函数在窗口中输出该字符。对于退格键的处理,可以删除光标前的字符,并将光标位置向前移动一个字符的宽度。在输入完成后,使用 `outtextxy()` 函数输出最终结果。需要注意的是,这里使用换行符作为输入结束标志。 上述代码虽然可以支持输入汉字,但是其输入效率较低,而且输入的汉字只能使用默认字体。如果需要更加高效的汉字输入,可以考虑使用第三方输入法库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值