26

私は次のように ClickableSpan を持つ SpannableString を持っています

for (int i = 0; i < items.size(); i++) {
            final SpannableString span = new SpannableString(items.get(i));
            final int index=i;

            span.setSpan(new ClickableSpan() {

                @Override
                public void onClick(View widget) {

                }

                @Override
                public void updateDrawState(TextPaint ds) {
                    ds.setColor(Color.LTGRAY);
                    ds.setUnderlineText(false);

                }
            }, 0, span.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

            builder.append(span);
        }

//my text view
txt.setText(builder);
txt.setMovementMethod(LinkMovementMethod.getInstance());

私がやりたいのは、クリックしたときにスパンの前景色を変更することです。

これどうやってするの ?

4

3 に答える 3

37

選択時に緑色のハイライトをなくしたい場合は、次のことを知っておいてください。

どうやら、カスタム クラスでオーバーライドpublic void updateDrawState(TextPaint ds)してもハイライト色には影響しません。下線の色の設定 (または非表示/表示) にのみ使用されます。

必要な作業は次 のとおりtextView.setHighlightColor(Color.TRANSPARENT); です。ここで、textView は ClickableSpan を含むものです。

うまくいくことを願っています。関連する質問はお気軽にどうぞ。

于 2016-02-11T19:34:04.500 に答える
8

clickableSpan クラスを拡張し、強調表示する必要があることを知らせるフラグを渡しました。

SpannableStringBuilder tag;
.... tag.setSpan(new WordSpan(i, tokens[i], wordtohighlitedID) { 

.....

import android.graphics.Color;
import android.text.TextPaint;
import android.text.style.ClickableSpan;
import android.view.View;

public class WordSpan extends ClickableSpan 
{

    private int id;
    private TextPaint textpaint;
    public boolean shouldHilightWord = false;
    public WordSpan(int anID, String txt, int selected) {
        id =anID;
        // if the word selected is the same as the ID set the highlight flag
        if(selected == id)  {
            shouldHilightWord = true;

        }


    }

    @Override
    public void updateDrawState(TextPaint ds) {
        textpaint = ds;
        ds.setColor(ds.linkColor);
        if(shouldHilightWord){
            textpaint.bgColor = Color.GRAY;         
            textpaint.setARGB(255, 255, 255, 255);

        }
        //Remove default underline associated with spans
        ds.setUnderlineText(false);

    }

    public void changeSpanBgColor(View widget){
        shouldHilightWord = true;
        updateDrawState(textpaint);
        widget.invalidate();


    }
    @Override
    public void onClick(View widget) {

        // TODO Auto-generated method stub

    }


    /**
     * This function sets the span to record the word number, as the span ID
     * @param spanID
     */
    public void setSpanTextID(int spanID){
        id = spanID;
    }

    /**
     * Return the wordId of this span
     * @return id
     */
    public int getSpanTextID(){
        return id;
    }
}
于 2013-04-26T18:52:29.827 に答える
-2

これを使って:

view.setSelector(new ColorDrawable(Color.BLUE));
于 2013-08-22T12:03:31.300 に答える