1

TextViewのロングクリックイベントのみを処理する必要があります(そしてこのイベントにポップアップメニューを表示します)。ただし、クリックするだけの場合は、このイベントをこのビューをホストしているレイアウトに転送する必要があります。

これを達成する方法は?

public class MainActivity extends Activity implements OnLongClickListener, OnClickListener {

TextView mTextView;
RelativeLayout mTopLayout;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    mTextView = (TextView) findViewById(R.id.mTextView);
    mTopLayout = (RelativeLayout) findViewById(R.id.mTopLayout);

    mTextView.setOnLongClickListener(this);
    mTopLayout.setOnClickListener(this);
    mTextView.setOnClickListener(this);
}

@Override
public void onClick(View v) {
    Toast.makeText(this, v.getClass().getName() + " clicked!", Toast.LENGTH_SHORT).show();
    if (v.getId() == R.id.mTextView) {
        ((View) v.getParent()).performClick();
    }
}

...
}

このようにして、2つの連続したクリックイベントを受け取り、Androidには2つの標準的なクリック音があります。良くない。

これを達成する簡単な方法はありますか?

xmlは次のとおりです。

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/mTopLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity" >

    <TextView
        android:id="@+id/mTextView"
        android:layout_width="match_parent"
        android:layout_height="200dp"
        android:background="#FFFF0000"
        android:clickable="false"
        android:focusable="false"
        android:text="@string/hello_world" />

</RelativeLayout>

編集: 詳細を追加するだけです。onClickListenerを設定しない場合、TextViewでのクリックは効果なしで実行され、このイベントはmTextViewによって消費され(xmlでクリック可能およびフォーカス可能がfalseに設定されている場合でも)、mTopLayoutに渡されません。

4

4 に答える 4

1

クリックのみで何をしたいのかわかりませんが、AndroidはonClickまたはonLongClickのいずれかで一度に1つのクリックリスターのみを対象としています。

于 2013-03-26T13:21:29.280 に答える
1

個別のリスナーを追加します。

mTextView.setOnLongClickListener(new OnLongClickListener() {
        @Override
        public boolean onLongClick(View v) {
            // do something;
        }
    });

mTextView.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View v) {
            // do something

        }
    });
于 2013-03-26T13:21:47.737 に答える
0

デモプロジェクトを作成しました。同じ問題OnLongClickOnClickを起動していまし たが、の戻り値を変更するsetOnLongClickListenerと、false これらのクリックを個別に管理し始めました。

 mbuttton = (Button)findViewById(R.id.View1);

        mbuttton.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                Toast.makeText(getBaseContext(), "single click", Toast.LENGTH_LONG).show();
                Log.i("Single Click", "Single click");
            }
        });

        mbuttton.setOnLongClickListener(new OnLongClickListener() {

            @Override
            public boolean onLongClick(View v) {
                // TODO Auto-generated method stub              
                Toast.makeText(getBaseContext(), "LONG click", Toast.LENGTH_LONG).show();
                Log.i("Long Click", "Long click");
                return true;
            }
        });

私はそれを実現させましたが、あなたが説明を求めているなら、私はほとんどあきらめています、これらの戻り値がどのように管理されているのかわかりません

于 2013-03-26T13:26:11.573 に答える
0

ついに...

なぜこのonClickListenersに異なるハンドラーを使用させる必要があるのですか?愚か。

@Override
public void onClick(View v) {
    Toast.makeText(this, v.getClass().getName() + " clicked!", Toast.LENGTH_SHORT).show();
    if (v.getId() == R.id.mTextView || v.getId() == R.id.mTopLayout) {
        //do whatever I need
    }
}

本当に簡単です。

于 2013-03-26T15:15:19.177 に答える