編輯:關於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) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { // Handle action bar item clicks here. The action bar will // automatically handle clicks on the Home/Up button, so long // as you specify a parent activity in 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, "這是事件的第三種寫法,直接實現OnClickListener接口的OnClick方法", 2000).show(); break; default: Toast.makeText(ButtonActivity3.this, "沒有觸發", 2000).show(); break; } } }
第四種:
需要在layout布局文件xml中指定btnClickEvent方法。
<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, "這是事件的第四種寫法,直接在布局文件的Button標簽上綁定Click事件", 2000).show(); } }
上面的4種寫法當中第3種方法相對用的更多一點。當一個activity當中有多個按鈕需要觸發click事件時,通過第3種寫法更容易管理和維護按鈕事件代碼。
布局是很重要的一塊內容,我將在下面的博客中進行講解,這裡簡單提及一下。
我們用的是LinearLayout(線性布局,其它的還有相對布局、絕對布局等等),設置了Android:orientation屬性值為vertical(垂直),依次從上往下開始顯示控件。
其它3個布局文件跟這個內容一樣,都是只放置了一個按鈕。
activity_main.xml的配置如下(就簡單的放置了4個按鈕):
<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>
最終更重要的一步,需要在AndroidManifest.xml文件中配置注冊Activity,完整的配置如下:
<?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。
下面的多個activity都需要在"清單文件"中注冊,這樣程序中才能找到這些Activity。
strings.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">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中activity跳轉按鈕事件的四種寫法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對本站網站的支持!
4月20號,樂視手機一口氣發布了3款二代超級手機,分別是:樂2、樂2 Pro、樂Max 2,其中除了樂2只有一個版本外,其它2款機型都有多個版本。針對有網友
上一篇,初步開發了這個應用,功能都有了(見http://www.jb51.net/article/96992.htm 點擊打開鏈接)。但是遺留了兩個問題:1、還是無法卸載
微信開放平台和公眾平台的區別1.公眾平台面向的時普通的用戶,比如自媒體和媒體,企業官方微信公眾賬號運營人員使用,當然你所在的團隊或者公司有實力去開發一些內容,也可以調用公
關於Android Studio 在2013 Google IO大會上發布的全新IDE Android Studio相信各位猿們並不陌生,截止2014的Goog