Подтвердить что ты не робот

Получить координаты сенсорного события на Android

Я новичок в Android, я следил за мировым учебным курсом и даю базовое представление о том, что происходит. Меня особенно интересует сенсорный экран моего T-Mobile Pulse, поэтому просто для того, чтобы начать меня. Я хочу иметь возможность писать координаты события tocuh на экране, поэтому скажите, что пользователь коснулся координаты 5, 2 - текстовое изображение на экране отобразило бы это.

В настоящее время у меня есть простая программа, которая просто загружает xml файл, который содержит текстовое представление, которое я намерен написать в координатах.

Заранее спасибо, я сделал Google за помощью и обыскал stackoverflow, но все, что я нашел, либо пошло по моей голове, либо не подходит для этого. Приветствия.

4b9b3361

Ответ 1

Вы можете использовать эту функцию: http://developer.android.com/reference/android/view/View.html#setOnTouchListener(android.view.View.OnTouchListener)

Вы, вероятно, поместите его в свой метод onCreate примерно таким образом (протестированный на этот раз):

Действие onCreate code

@Override
public void onCreate(Bundle savedInstanceState)
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    final TextView textView = (TextView)findViewById(R.id.textView);
    // this is the view on which you will listen for touch events
    final View touchView = findViewById(R.id.touchView);
    touchView.setOnTouchListener(new View.OnTouchListener() {
        @Override
        public boolean onTouch(View v, MotionEvent event) {
            textView.setText("Touch coordinates : " +
                String.valueOf(event.getX()) + "x" + String.valueOf(event.getY()));
                return true;
        }
    });
}

код макета

<?xml version="1.0" encoding="utf-8"?>                                      
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
<TextView  
    android:id="@+id/touchView" 
    android:background="#f00" 
    android:layout_weight="1" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    />
<TextView  
    android:id="@+id/textView" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:text="Hello World, TestActivity"
    />
</LinearLayout>

Изменить. Я пробовал свой код и действительно было несколько ошибок. Во всяком случае, с макетом, который я вам даю, он работает на моем эмуляторе. Можете ли вы предоставить больше кода/контекста, чтобы я мог видеть, что неправильно?

Ответ 2

Похоже, вы хотите получить события касания от всей области вашего макета для этого конкретного теста. Попробуйте подключить сенсорный прослушиватель к родительскому виду, а не к отдельному целевому представлению.

Это не очень общий подход. В большинстве случаев вам нужно прослушивать события касания в определенном дочернем представлении, и если у вас есть другие представления в макете, которые обрабатывают события касания (например, кнопку), они будут иметь приоритет над родительским представлением. См. http://developer.android.com/guide/topics/ui/ui-events.html для получения дополнительной информации об обработке событий пользовательского интерфейса.

Макет (touch_viewer.xml):

<?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:orientation="vertical"
    android:id="@+id/parent" >
    <TextView android:id="@+id/text"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="Hello, World!" />
</LinearLayout>

И в вашей деятельности:

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.touch_viewer);

    final LinearLayout parent = (LinearLayout) findViewById(R.id.parent);
    final TextView text = (TextView) findViewById(R.id.text);
    parent.setOnTouchListener(new OnTouchListener() {
        public boolean onTouch(View v, MotionEvent ev) {
            text.setText("Touch at " + ev.getX() + ", " + ev.getY());
            return true;
        }
    });
}

Ответ 3

Следующее работает, используя сенсорный экран на примере приложения для Android-приложения jetboy. Код Джоса работал с одной настройкой, чтобы он сиял на фоне. Единственная строка, которую я добавил, была

android:background="#0000"
android:layout_height="fill_parent"   
android:layout_height="fill_parent" 

Спасибо Джо (см. выше).

@Override
public void onCreate(Bundle savedInstanceState)
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    final TextView textView = (TextView)findViewById(R.id.textView);
    // this is the view on which you will listen for touch events
    final View touchView = findViewById(R.id.touchView);
    touchView.setOnTouchListener(new View.OnTouchListener() {
        @Override
        public boolean onTouch(View v, MotionEvent event) {
            textView.setText("Touch coordinates : " +
                String.valueOf(event.getX()) + "x" + String.valueOf(event.getY()));
                return true;
        }
    });
}

код макета

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

    <com.android.samples.jetboy.JetBoyView android:id="@+id/JetBoyView"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" />
        <TextView  
                android:id="@+id/touchView" 
                android:background="#0000" 
                android:layout_weight="1" 
                android:layout_width="fill_parent" 
                android:layout_height="fill_parent" 
        />
        <TextView  
                android:id="@+id/textView" 
                android:layout_width="fill_parent" 
                android:layout_height="fill_parent" 
                android:text="Hello World, TestActivity"
        />
</FrameLayout>

Ответ 4

Исправленная версия без ошибок:

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.MotionEvent;
import android.view.View;
import android.widget.TextView;
public class MainActivity extends Activity {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        final TextView textView = (TextView) findViewById(R.id.textView);
        // this is the view on which you will listen for touch events
        final View touchView = findViewById(R.id.touchView);
        touchView.setOnTouchListener(new View.OnTouchListener() {
            @Override
            public boolean onTouch(View v, MotionEvent event) {
                textView.setText("Touch coordinates : "
                        + String.valueOf(event.getX()) + "x"
                        + String.valueOf(event.getY()));
                return true;
            }
        });
    }
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }
}