3

EditText でユーザーから入力を取得する 1 つのアプリケーションを作成しています。

ボタンをクリックすると、入力された文字列が TextView に表示されます。今私の質問は、ユーザーが任意の単語をクリックすると、その単語が TextView で強調表示されるようにすることです。

例: ユーザー入力: こんにちは、お元気ですか。

ユーザーが「Hello」をクリックすると、TextView で強調表示されます。または、ユーザーが「方法」をクリックすると、強調表示されます。

私を助けてください。

4

1 に答える 1

7
public class MainActivity extends Activity {
TextView _tv;


@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
_tv = (TextView) findViewById( R.id.tv );

SpannableString ss = new SpannableString("Hello friend how are you.");

ss.setSpan(new MyClickableSpan(), 0,5, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
ss.setSpan(new MyClickableSpan(), 6, 12, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
ss.setSpan(new MyClickableSpan(), 13, 16, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
ss.setSpan(new MyClickableSpan(), 17, 20, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
ss.setSpan(new MyClickableSpan(), 21, 24, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

_tv.setText(ss);
_tv.setMovementMethod(LinkMovementMethod.getInstance());
}
class MyClickableSpan extends ClickableSpan{ //clickable span
public void onClick(View textView) {
//do something

   Toast.makeText(MainActivity.this, "Clicked",
        Toast.LENGTH_SHORT).show();
}
@Override
public void updateDrawState(TextPaint ds) {
   ds.setColor(Color.BLACK);//set text color 
   ds.setUnderlineText(false); // set to false to remove underline
} 
}
}

編集:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity" >

<TextView
    android:id="@+id/tv"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center"
    android:layout_marginTop="50dp"
    android:text="@string/hello_world" />

<EditText
    android:id="@+id/ed"
    android:layout_width="fill_parent"
    android:layout_height="40dp"
    android:layout_marginTop="40dp" />

<Button
    android:id="@+id/button1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center"
    android:layout_marginTop="20dp"
    android:text="Click" />

 </LinearLayout>

文字列をスペースで分割し、各単語をスパン可能な文字列として設定できます。次に、スパン可能な文字列をクリック可能にします。このようにして、文字列の長さをハードコーディングする必要はありません。ユーザーは、テキストビュー内の任意の単語をクリックして、強調表示することができます。

 public class MainActivity extends Activity {
TextView _tv;
String[] each;
SpannableString ss1;
Button b;
EditText et;
    String s;


@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
b= (Button) findViewById(R.id.button1);
et = (EditText) findViewById(R.id.ed);
_tv = (TextView) findViewById( R.id.tv );

b.setOnClickListener(new OnClickListener()
{

    @Override
    public void onClick(View v) {
        // TODO Auto-generated method stub
        s=et.getText().toString();
        _tv.setText("");
        for(int i=0;i<s.length();i++)
        {
            each = s.split("\\s+");
        }
        for(int i=0;i<each.length;i++)
        {
            System.out.println("................"+each[i]);
            ss1=  new SpannableString(each[i]);
            ss1.setSpan(new MyClickableSpan(), 0, ss1.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
            _tv.append(ss1); 
            _tv.append(" "); 

        }
        _tv.setMovementMethod(LinkMovementMethod.getInstance());
    }

   });
}
class MyClickableSpan extends ClickableSpan{ //clickable span
public void onClick(View textView) {
//do something

   Toast.makeText(MainActivity.this, "Clicked",
        Toast.LENGTH_SHORT).show();
 }
 @Override
 public void updateDrawState(TextPaint ds) {
   ds.setColor(Color.BLACK);//set text color 
   ds.setUnderlineText(false); // set to false to remove underline
 }
 }
 }

http://www.chrisumbel.com/article/android_textview_rich_text_spannablestring。スパナブルストリングのスタイリングに。

結果のスナップショット。

ここに画像の説明を入力してください

于 2013-03-20T17:06:05.893 に答える