如何在同一时间不处理View.onClick()并处理View.onLongClick()?

时间:2013-03-26 13:17:51

标签: java android onclick onlongclicklistener

我只需要处理TextView的长按事件(并在此事件上显示popupmenu)。但是,如果只是简单点击,我应该将此事件转移到托管此视图的布局。

如何实现这一目标?

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();
    }
}

...
}

通过这种方式,我们将收到两个连续点击事件,并且在android中将有两个标准点击声音。不好。

是否有一些简单的方法来实现这一目标?

这是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中将clickable和focusable设置为false)并且没有传递给mTopLayout

4 个答案:

答案 0 :(得分:1)

我不清楚你想要点击什么,但是android只能在onClick或onLongClick上一次只捕获一个点击列表。

答案 1 :(得分: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

        }
    });

答案 2 :(得分:0)

我刚创建了一个演示项目。同样的问题 OnLongClick 它正在解雇 OnClick 也 但当我将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;
            }
        });

我实现了它,但如果你要求解释oooohhh我几乎放弃了,不知道这些返回值是如何管理的

答案 3 :(得分: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
    }
}

非常简单。