Получить координаты сенсорного события на Android
Я новичок в Android, я следил за мировым учебным курсом и даю базовое представление о том, что происходит. Меня особенно интересует сенсорный экран моего T-Mobile Pulse, поэтому просто для того, чтобы начать меня. Я хочу иметь возможность писать координаты события tocuh на экране, поэтому скажите, что пользователь коснулся координаты 5, 2 - текстовое изображение на экране отобразило бы это.
В настоящее время у меня есть простая программа, которая просто загружает xml файл, который содержит текстовое представление, которое я намерен написать в координатах.
Заранее спасибо, я сделал Google за помощью и обыскал stackoverflow, но все, что я нашел, либо пошло по моей голове, либо не подходит для этого. Приветствия.
Ответы
Ответ 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;
}
}