English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Четыре способа записи事件的 перехода activity в Android

Конкретное реализация кода:

public class MainActivity extends Activity { 
@Override 
protected void onCreate(Bundle savedInstanceState) { 
super.onCreate(savedInstanceState); 
setContentView(R.layout.activity_main); 
// Метод 1. Использование класса, реализующего интерфейс OnClickListener 
((Button) findViewById(R.id.btn1)) 
.setOnClickListener(new View.OnClickListener() { 
@Override 
public void onClick(View v) { 
Intent intent = new Intent(MainActivity.this, 
ButtonActivity1.class); 
startActivity(intent); 
} 
}); 
// Метод 2. Использование анонимного внутреннего класса 
((Button) findViewById(R.id.btn2)) 
.setOnClickListener(new View.OnClickListener() { 
@Override 
public void onClick(View v) { 
Intent intent = new Intent(MainActivity.this, 
ButtonActivity2.class); 
startActivity(intent); 
} 
}); 
// Метод 3. Activity напрямую реализует интерфейс OnClickListener 
((Button) findViewById(R.id.btn3)) 
.setOnClickListener(new View.OnClickListener() { 
@Override 
public void onClick(View v) { 
Intent intent = new Intent(MainActivity.this, 
ButtonActivity3.class); 
MainActivity.this.startActivity(intent); 
} 
}); 
// Метод 4. Прямая маркировка события 
((Button) findViewById(R.id.btn4)) 
.setOnClickListener(new View.OnClickListener() { 
@Override 
public void onClick(View v) { 
Intent intent = new Intent(MainActivity.this, 
ButtonActivity4.class); 
MainActivity.this.startActivity(intent); 
} 
}); 
} 
@Override 
public boolean onCreateOptionsMenu(Menu menu) { 
// Вставить меню; это добавляет элементы в панель инструментов, если она присутствует. 
getMenuInflater().inflate(R.menu.main, menu); 
return true; 
} 
@Override 
public boolean onOptionsItemSelected(MenuItem item) { 
// Обработать клики на элементах действия панели инструментов. Панель инструментов будет 
// автоматически обрабатывать клики на кнопке Домой/Вверх, если это необходимо 
// как вы указали родительскую активность в AndroidManifest.xml. 
int id = item.getItemId(); 
if (id == R.id.action_settings) { 
return true; 
} 
return super.onOptionsItemSelected(item); 
}

上面代码中:

1、我们创建的MainActivity类需要继承自Activity

2、需要重写onCreate方法,并通过setContentView方法加载相应的layout(布局)文件

3、通过findViewById方法找到相应的控件(在layout布局文件中定义的控件)并绑定一个Click事件(Java中通过监听器实现,C#中通过委托实现)

4、可以通过Intent对象传递数据并跳转到其他Activity

5、onCreateOptionsMenu和onOptionsItemSelected是添加和选中菜单项时的方法。

以下是分别四个activity的内容:

第一种:

public class ButtonActivity1 extends Activity { 
Button button; 
@Override 
protected void onCreate(Bundle savedInstanceState) { 
super.onCreate(savedInstanceState); 
setContentView(R.layout.activity_button1); 
button = (Button) findViewById(R.id.btn1); 
button.setOnClickListener(new MyListener()); 
} 
public class MyListener implements OnClickListener { 
@Override 
public void onClick(View v) { 
Toast.makeText(ButtonActivity1.this, "Это первый способ записи события, определение события в внутреннем классе", 2000).show(); 
} 
} 
}

Второй вариант:

public class ButtonActivity2 extends Activity { 
Button button ; 
@Override 
protected void onCreate(Bundle savedInstanceState) { 
super.onCreate(savedInstanceState); 
setContentView(R.layout.activity_button2); 
button = (Button)findViewById(R.id.btn1); 
button.setOnClickListener(new View.OnClickListener() { 
@Override 
public void onClick(View v) { 
Toast.makeText(ButtonActivity2.this, "Это второй способ записи события, форма анонимного внутреннего класса", 2000).show(); 
} 
}); 
} 
}

Третий вариант:

public class ButtonActivity3 extends Activity implements OnClickListener { 
Button button; 
@Override 
protected void onCreate(Bundle savedInstanceState) { 
super.onCreate(savedInstanceState); 
setContentView(R.layout.activity_button3); 
button = (Button)findViewById(R.id.btn1); 
button.setOnClickListener(this); 
} 
@Override 
public void onClick(View v) { 
switch (v.getId()) { 
case R.id.btn1: 
Toast.makeText(ButtonActivity3.this, 
Toast.makeText(ButtonActivity3.this, "Это третий способ записи события, реализация метода OnClick интерфейса OnClickListener", 2000).show(); 
break; 
default: 
Toast.makeText(ButtonActivity3.this, "Не было триггера", 2000).show(); 
break; 
} 
} 
}

Четвертый вариант:

Необходимо указать метод btnClickEvent в файле layout.xml.

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:tools="http://schemas.android.com/tools" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:orientation="vertical" 
tools:context="com.example.test.Button4Activity" > 
<Button 
android:id="@+id/btn4" 
android:layout_width="match_parent" 
android:layout_height="wrap_content" 
android:text="Нажми меня" 
android:onClick="btnClickEvent"/> 
</LinearLayout> 
public class ButtonActivity4 extends Activity { 
@Override 
protected void onCreate(Bundle savedInstanceState) { 
super.onCreate(savedInstanceState); 
setContentView(R.layout.activity_button4); 
} 
public void btnClickEvent(View v){ 
Toast.makeText(ButtonActivity4.this, "Это четвертый способ события, связанного с click, напрямую в теге Button файла макета", 2000).show(); 
} 
}

Из четырех указанных способов третий используется чаще всего. Когда в activity есть несколько кнопок, которые необходимо вызывать click событие, через третий способ легче управлять и поддерживать код событий кнопок.

Макет - это важная часть, я расскажу о нем в следующем блоге, здесь я только кратко упомяну.

Мы используем LinearLayout (линейный макет, также есть относительный макет, абсолютный макет и т.д.), установили атрибут Android:orientation в значение vertical (вертикальный), и элементы управления отображаются сверху вниз.

Другие три файла макета такие же, они содержат только одну кнопку.

Конфигурация файла activity_main.xml следующая (включает простое placement four buttons):

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:tools="http://schemas.android.com/tools" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:orientation="vertical" 
android:paddingBottom="@dimen/activity_vertical_margin" 
android:paddingLeft="@dimen/activity_horizontal_margin" 
android:paddingRight="@dimen/activity_horizontal_margin" 
android:paddingTop="@dimen/activity_vertical_margin" 
tools:context="com.example.test.MainActivity" > 
<Button 
android:id="@+id/btn1" 
android:layout_width="match_parent" 
android:layout_height="wrap_content" 
android:text="@string/clickMe1" /> 
<Button 
android:id="@+id/btn2" 
android:layout_width="match_parent" 
android:layout_height="wrap_content" 
android:text="@string/clickMe2" /> 
<Button 
android:id="@+id/btn3" 
android:layout_width="match_parent" 
android:layout_height="wrap_content" 
android:text="@string/clickMe3" /> 
<Button 
android:id="@+id/btn4" 
android:layout_width="match_parent" 
android:layout_height="wrap_content" 
android:text="@string/clickMe4" 
android:onClick="btnClickEvent"/> 
</LinearLayout>

Важное шаг, который необходимо выполнить, это настройка зарегистрированного Activity в файле AndroidManifest.xml, полная конфигурация следующая:

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
package="com.example.test" 
android:versionCode="1" 
android:versionName="1.0" > 
<uses-sdk 
android:minSdkVersion="14" 
android:targetSdkVersion="14" /> 
<uses-permission android:name="android.permission.CALL_PHONE" /> 
<uses-permission android:name="android.permission.INTERNET" /> 
<application 
android:allowBackup="true" 
android:icon="@drawable/ic_launcher" 
android:label="@string/app_name" 
android:theme="@style/AppTheme" > 
<activity 
android:name=".MainActivity" 
android:label="@string/app_name" > 
<intent-filter> 
<action android:name="android.intent.action.MAIN" /> 
<category android:name="android.intent.category.LAUNCHER" /> 
</intent-filter> 
</activity> 
<activity 
android:name=".ButtonActivity1" 
android:label="@string/button1" /> 
<activity 
android:name=".ButtonActivity2" 
android:label="@string/button2" /> 
<activity 
android:name=".ButtonActivity3" 
android:label="@string/button3" /> 
<activity 
android:name=".ButtonActivity4" 
android:label="@string/button4" /> 
</application> 
</manifest>

Здесь есть один момент, на который нужно обратить внимание:

<action android:name="android.intent.action.MAIN" />

Установите MainActivity в качестве "главной Activity", то есть это Activity будет最先显示。

Несколько活動 необходимо зарегистрировать в "файле списка", чтобы эти Activities могли быть найдены в программе.

Содержание файла configurations.xml:

<?xml version="1.0" encoding="utf-8"?> 
<resources> 
<string name="app_name">test</string> 
<string name="hello_world">Hello world!</string> 
<string name="action_settings">Настройки</string> 
<string name="clickMe1">Событие кнопки 1</string> 
<string name="clickMe2">Событие кнопки 2</string> 
<string name="clickMe3">Событие кнопки 3</string> 
<string name="clickMe4">Событие кнопки 4</string> 
<string name="button1">Кнопка 1</string> 
<string name="button2">Кнопка 2</string> 
<string name="button3">Кнопка 3</string> 
<string name="button4">Кнопка 4</string> 
</resources>

Конечно, вы также можете直接 написать это в файле layout, но это более利于 поддержку, это также方法是 Android разработка рекомендует.

Ниже перечислены четыре способа перехода активностей в Android,介绍的四种写法,希望对大家有所帮助。如果您有任何疑问, пожалуйста, оставьте комментарий, я отвечу вам в кратчайшие сроки. Вновь благодарю всех за поддержку сайта呐喊教程!

Заявление: содержание этой статьи предоставлено из Интернета, авторские права принадлежат соответствующему автору, контент предоставлен пользователями Интернета, веб-сайт не обладает правами собственности, не был отредактирован вручную, не несет ответственности за связанные с этим法律责任. Если вы обнаружите подозрительное содержимое, пожалуйста, отправьте письмо по адресу: notice#oldtoolbag.com (при отправке письма, пожалуйста, замените # на @) для сообщения о нарушении авторских прав,并提供 соответствующие доказательства. При обнаружении факта нарушения авторских прав сайт немедленно удаляет подозрительное содержимое.

Давай посмотрим, что тебе нравится