11

私がこれまでに行ったことは、通常のテキストとクリック可能なスパンを持つテキストビューのリストビューです。 手つかずのアイテム

URLを開いているスパンをクリックし、textViewの周りのアイテムViewをクリックすると、listViewOnItemClickListenerがアイテムの詳細に移動します。 これで問題ありません。textViewの外側に触れたアイテム

今問題は次のとおりです。

アイテムtext通常のテキストを表示 アイテムtextViewスパンがタッチされました textViewに触れると、通常のテキストが少し強調表示され(アイテムが完全に選択されたときと同じ色で)、textViewのOnTouchListenertouchイベントは発生しますが、イベントは発生OnFocusChangeListenerせず、アイテムのViewは選択スタイルを取得しません。FOCUS_BLOCK_DESCENDANTSlistView、item Viewのすべてのバリエーションを試しましたが、textViewfocusableが有効または無効になり、同じ結果になりました。

幸い、textViewOnClickListenerイベントはこのように発生しますが、それは非常に醜いです。選択したテキストの色がアイテムの色と同じであるため、タッチが解放されていない間はテキストが表示されません。ユーザーがアイテムの詳細に移動していることを示す他の兆候はありません。その醜いテキストが消えるより。

textViewのコンテンツがでSpannableあり、CliclableSpanではない部分がこの奇妙な方法で動作するために発生するのではないかと思います。

通常のテキストに触れたら、アイテムを選択できる可能性はありますか?


listViewアイテムのレイアウト:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:descendantFocusability="blocksDescendants"
    android:orientation="horizontal" >

    <ImageView
        android:id="@+id/icon"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_vertical"
        android:layout_marginBottom="5dp"
        android:layout_marginLeft="5dp"
        android:layout_marginRight="5dp"
        android:layout_marginTop="5dp"
        android:focusable="false" />

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical" >

        <TextView
            android:id="@+id/title"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_marginBottom="5dp"
            android:layout_marginTop="5dp"
            android:focusable="false"
            android:text=""
            android:textAppearance="?android:attr/textAppearanceLarge"
            android:textStyle="bold" />

        <TextView
            android:id="@+id/info"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_marginBottom="4dp"
            android:layout_marginLeft="4dp"
            android:layout_marginRight="4dp"
            android:focusable="false"
            android:text=""
            android:textAppearance="?android:attr/textAppearanceSmall" />

        <TextView
            android:id="@+id/details"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_marginBottom="4dp"
            android:layout_marginLeft="4dp"
            android:layout_marginRight="4dp"
            android:focusable="false"
            android:gravity="fill_horizontal|right"
            android:text=""
            android:textAppearance="?android:attr/textAppearanceMedium"/>

    </LinearLayout>

</LinearLayout>

テキストビューsetClickable(false)を使用すると、テキストビュー領域に触れても何も起こらないように、この奇妙な選択スタイルを無効にすることができます。これは良くありませんが、解決に役立つ可能性があります。

また、各アイテムにフォーカス不可およびクリック不可のボタンを追加しようとしました。タッチするとアイテム全体が選択され、タッチを離すとアイテムのクリックイベントが渡されます。これは、Spannableコンテンツを含むtextViewに期待したとおりです。

4

4 に答える 4

4

TextViewの背景をAndroidのデフォルトに設定してみましたlist_selector_backgroundか?

    textView.setMovementMethod(LinkMovementMethod.getInstance());
    textView.setBackgroundResource(android.R.drawable.list_selector_background);

私にとって、それはあなたが望む結果を与えるようです。

更新:アイテムが単一のTextViewではないことを確認した後

まあ、これは完璧な解決策ではありませんが(TextView-ListViewの強調表示の相互作用を何らかの方法で修正する方がおそらく良いため)、十分に機能します。

TextViewで移動方法を設定する(問題をトリガーする)代わりに、onItemClick()(クリックが確実に確認された後) ListViewをチェックしonClick()て、ClickableSpansでを起動する必要があるかどうかを確認する方が簡単であることがわかりました。

public class MyActivity extends Activity {

    private final Rect mLastTouch = new Rect();

    private boolean spanClicked(ListView list, View view, int textViewId) {
        final TextView widget = (TextView) view.findViewById(textViewId);
        list.offsetRectIntoDescendantCoords(widget, mLastTouch);
        int x = mLastTouch.right;
        int y = mLastTouch.bottom;

        x -= widget.getTotalPaddingLeft();
        y -= widget.getTotalPaddingTop();
        x += widget.getScrollX();
        y += widget.getScrollY();

        final Layout layout = widget.getLayout();
        final int line = layout.getLineForVertical(y);
        final int off = layout.getOffsetForHorizontal(line, x);

        final Editable buffer = widget.getEditableText();
        final ClickableSpan[] link = buffer.getSpans(off, off, ClickableSpan.class);

        if (link.length == 0) return false;

        link[0].onClick(widget);
        return true;
    }

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        // ...

        listView.setOnItemClickListener(new OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                if (spanClicked(listView, view, R.id.details)) return;

                // no span is clicked, normal onItemClick handling code here ..                    
            }
        });
        listView.setOnTouchListener(new OnTouchListener() {
            @Override
            public boolean onTouch(View v, MotionEvent event) {
                if (event.getAction() == MotionEvent.ACTION_UP) {
                    mLastTouch.right = (int) event.getX();
                    mLastTouch.bottom = (int) event.getY();
                }
                return false;
            }
        });

        // ...
    }

}

このspanClicked()メソッドは基本的に、フレームワーク内のLinkMovementMethodのonTouchEvent()メソッドの短縮バージョンです。最後のMotionEvent座標をキャプチャするには(クリックイベントをチェックするため)、ListViewにOnTouchListenerを追加するだけです。

于 2012-07-21T20:19:22.937 に答える
1

を使用TextViewするsetHighlightColor(Color.TRANSPARENT);

于 2012-09-18T05:42:08.497 に答える
0

この問題を解決する最善の方法は、セレクターを使用することだと思います。あなたは彼らが同じように見えるように選択の背景色をちゃんにすることができます

セレクターコードの例:

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true"
       android:color="#000000" /> <!-- pressed -->
    <item android:state_focused="true"
       android:color="#000000" /> <!-- focused -->
    <item android:color="#FFFFFF" /> <!-- default -->
</selector>

そのようなsthをリンクに実装します。

結果について教えてください

于 2012-07-19T12:21:27.733 に答える
0

のドキュメントからのsetMovementMethod()引用TextView

このTextViewで使用する移動方法(矢印キーハンドラー)を設定します。これをnullにすると、矢印キーを使用してカーソルを移動したり、ビューをスクロールしたりできなくなります。

キーリスナーまたは移動メソッドのあるTextViewをフォーカス可能にしたくない場合、またはキーリスナーまたは移動メソッドのないTextViewをフォーカス可能にしたい場合は、android.view.View.setFocusable(boolean)を呼び出す必要があることに注意してください。これを呼び出した後、フォーカス可能性を希望どおりに戻します。

setFocusable2番目の段落では、LinkMovementMethodを設定した後、メソッドを明示的に呼び出して、フォーカス可能性を希望どおりに機能させる必要があることを説明しています。

リストアイテムを膨らませた後、コードでそれを行う必要があります。フォーカスを取得できるようになったら、別の色のテキストを持つようにセレクターを設定できます。

setMovementMethodのソースコードは次のとおりです。

于 2012-07-20T11:50:52.693 に答える