標籤:android style blog http java 檔案 資料 io
經過前兩篇blog的鋪墊,我們今天熱身一下,做個簡單的例子。
目錄結構還是引用上篇blog的。
具體實現代碼:
public class MainActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);// 方法1. 採用實現OnClickListener介面的類((Button) findViewById(R.id.btn1)).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {Intent intent = new Intent(MainActivity.this,Button1Activity.class);startActivity(intent);}});// 方法2. 採用匿名內部類((Button) findViewById(R.id.btn2)).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {Intent intent = new Intent(MainActivity.this,Button2Activity.class);startActivity(intent);}});// 方法3. Activity直接實現OnClickListener介面((Button) findViewById(R.id.btn3)).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {Intent intent = new Intent(MainActivity.this,Button3Activity.class);MainActivity.this.startActivity(intent);}});// 方法4.標籤直接標註觸發事件((Button) findViewById(R.id.btn4)).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {Intent intent = new Intent(MainActivity.this,Button4Activity.class);MainActivity.this.startActivity(intent);}});}@Overridepublic 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;}@Overridepublic 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);}}上面的代碼有5點需要說明:
1、我們建立的MainActivity類需要繼承自Activity
2、需要覆寫onCreate方法,並通過setContentView方法載入相應的layout(布局)檔案
3、通過findViewById方法找到相應的控制項(在layout布局檔案中定義的控制項)並綁定一個Click事件(Java中通過監聽器實現,C#中通過委託實現)
4、可以通過Intent對象傳遞資料並跳轉到其它的Activity
5、onCreateOptionsMenu和onOptionsItemSelected是添加和選中功能表項目時的方法。
Button1Activity示範按鈕觸發事件的第一種寫法:
public class Button1Activity extends Activity {Button button;@Overrideprotected 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 {@Overridepublic void onClick(View v) {Toast.makeText(Button1Activity.this, "這是事件的第一種寫法,內部類定義事件", 2000).show();}}}
Button2Activity示範按鈕觸發事件的第二種寫法:
public class Button2Activity extends Activity {Button button ;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_button2);button = (Button)findViewById(R.id.btn1);button.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {Toast.makeText(Button2Activity.this, "這是事件的第二種寫法,匿名內部類的形式", 2000).show();}});}}
Button3Activity示範按鈕觸發事件的第三種寫法:
public class Button3Activity extends Activity implements OnClickListener {Button button;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_button3);button= (Button)findViewById(R.id.btn1);button.setOnClickListener(this);}@Overridepublic void onClick(View v) {switch (v.getId()) {case R.id.btn1:Toast.makeText(Button3Activity.this,"這是事件的第三種寫法,直接實現OnClickListener介面的OnClick方法", 2000).show();break;default:Toast.makeText(Button3Activity.this, "沒有觸發", 2000).show();break;}}}
Button4Activity示範按鈕觸發事件的第四種寫法:
public class Button4Activity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_button4);}public void btnClickEvent(View v){Toast.makeText(Button4Activity.this, "這是事件的第四種寫法,直接在布局檔案的Button標籤上綁定Click事件", 2000).show();}}
這種寫法需要在layout布局檔案中,指定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/btn1" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="點擊我" android:onClick="btnClickEvent"/></LinearLayout>
需要說明的是,上面的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" /></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=".Button1Activity" android:label="@string/button1" /> <activity android:name=".Button2Activity" android:label="@string/button2" /> <activity android:name=".Button3Activity" android:label="@string/button3" /> <activity android:name=".Button4Activity" 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開發所推薦的方法。
最後上一下程式在模擬器中運行: