Intent in android


– Các bạn đã đi qua được các thành phần giao diện  trong Android, bài tập này các bạn sẽ làm quen với Intent. Intent rất quan trọng nó là linh hồn của Android, là hạt nhân để Android tồn tại, hầu như mọi thứ trong Android đều có dấu ấn của Intent.

– Các bạn cần hiểu rõ Intent, Tôi sẽ đưa ra hàng loạt ví dụ từ dễ tới khó để các bạn có thể thẩm thấu nó từ từ.

– Đối với người bắt đầu tiếp cận Android thì Tôi có thể nói rằng các bạn chỉ dùng Intent để mở các Activity và truyển dữ liệu qua lại giữa chúng mà thôi. Khi đã nâng cao level thì bạn sẽ sử dụng Intent ở những mục đích khác nhau (Tôi sẽ có những ví dụ riêng về nó, nhưng trước tiên các bạn chỉ cần sử dụng tốt trong việc mở Activity và xử lý tác vụ này tốt là ok rồi).

– Vì lý do đó , để phù hợp với các bạn thì Tôi chia Intent ra làm 2 công dụng chính:

1) Dùng Intent để mở một Activity khác nhưng không kiểm soát kết quả trả về.

2) Dùng Intent để mở một Activity khác và có kiểm soát kết quả trả về.

Bây giờ chúng ta vào từng ví dụ cụ thể:

Ví dụ 1: Đơn thuần là mở một Activity khác.

24_intent_0– Tôi giải thích hình trên như sau: Từ Main Activity Tôi có 1 Button, khi nhấn vào Button này thì sẽ mở một Activity khác, tại Activity mới mở này sẽ có 1 Button cho phép quay trở lại MainActivity.

– Bạn phải nhớ lại vòng đời của một ứng dụng Android ở bài tập 5 và bài tập 6 để làm ví dụ này tốt hơn.

– Bạn tạo một Android Project có cấu trúc như hình bên dưới:

24_intent_1– Bạn chú ý là mọi Activity muốn được triệu gọi trong Android thì phải đăng ký trong Manifest, ở các bài tập trước Tôi cũng đã nói rồi, nhưng Tôi vẫn nhắc lại AndroidManifest.xml:

 
<?xml version="1.0" encoding="utf-8"?>
 package="tranduythanh.com"
 android:versionCode="1"
 android:versionName="1.0" >
 <uses-sdk
 android:minSdkVersion="14"
 android:targetSdkVersion="17" >
 </uses-sdk>
 <application
 android:allowBackup="true"
 android:icon="@drawable/ic_launcher"
 android:label="@string/app_name"
 android:theme="@style/AppTheme" >
 <activity
 android:name="tranduythanh.com.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="tranduythanh.com.ChildActivity"
 android:label="@string/title_activity_child" >
 </activity>
 </application>
</manifest>

– Bạn thấy đó cả MainActivity (dòng 16) và ChildActivity (Dòng 24)  đều phải được đăng ký trong Manifest.

– Giờ ta xem giao diện và cách xử lý coding trong MainActivity:

24_intent_2– Đây là cấu trúc XML của activity_main.xml ở trên:

 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:id="@+id/LinearLayout1"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 tools:context=".MainActivity" >
 
<TextView
 android:id="@+id/textView1"
 android:layout_width="match_parent"
 android:layout_height="100dp"
 android:background="#008000"
 android:gravity="center"
 android:text="This is main Activity"
 android:textColor="#FFFF00"
 android:textSize="20sp"
 android:textStyle="bold" />
 
<Button
 android:id="@+id/btnOpenChildActivity"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_gravity="center"
 android:text="Open Child Activity" />
 
</LinearLayout>

– Tiến hành xem coding MainActivity.java:

 
package tranduythanh.com;
 
import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
 
public class MainActivity extends Activity {
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 Button btnOpen=(Button)
 findViewById(R.id.btnOpenChildActivity);
 btnOpen.setOnClickListener(new
 View.OnClickListener() {
 public void onClick(View arg0) {
 doOpenChildActivity();
 }
 });
 }
 public void doOpenChildActivity()
 {
 Intent myIntent=new Intent(this, ChildActivity.class);
 startActivity(myIntent);
 }
 public boolean onCreateOptionsMenu(Menu menu) {
 // Inflate the menu; this adds items to the action bar if it is present.
 getMenuInflater().inflate(R.menu.activity_main, menu);
 return true;
 }
}

– Quan sát dòng lệnh 25:

Intent myIntent=new Intent(thisChildActivity.class);

Đối số 1 là context hiện tại, nếu bạn muốn chắc ăn ở đâu nó cũng hiểu thì bạn gán tên class Activity như thế này:

Intent myIntent=new Intent(MainActivity.thisChildActivity.class);

Với MainActivity là một Activity tùy ý (trong Context hiện tại), viết như trên thì bạn sẽ luôn luôn đúng trong mọi trường hợp.

Đối số 2 là :  ChildActivity.class, Tức là bạn muốn mở Activity nào thì lấy tên Activity đó .class; trong trường hợp này Tôi muốn mở ChildActivity nên Tôi ghi là ChildActivity.class

– Quan sát dòng lệnh 26
startActivity(myIntent); Hàm này có tác dụng mở Activity được truyền vào đối số thứ 2 ở trên.

– Tiến hành khám phá ChildActivity:

24_intent_3-Đầy là source XML của ChildActivity:

 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:id="@+id/LinearLayout1"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 tools:context=".ChildActivity" >
 
<TextView
 android:id="@+id/textView1"
 android:layout_width="match_parent"
 android:layout_height="100dp"
 android:background="#FFFF00"
 android:gravity="center"
 android:text="This is Child Activity"
 android:textColor="#008040"
 android:textSize="20sp"
 android:textStyle="bold" />
 
<Button
 android:id="@+id/btnBacktoMainActivity"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_gravity="center"
 android:text="Back to Main Activity" />
 
</LinearLayout>

-Giao diện của ChildActivity chỉ có một Button cho phép quay lại MainActivity.

– Bạn xem coding của ChildActivity:

 
package tranduythanh.com;
 
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
 
public class ChildActivity extends Activity {
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_child);
 Button btnBack= (Button)
 findViewById(R.id.btnBacktoMainActivity);
 btnBack.setOnClickListener(new
 View.OnClickListener() {
 public void onClick(View v) {
 finish();
 }
 });
 }
 public boolean onCreateOptionsMenu(Menu menu) {
 // Inflate the menu; this adds items to the action bar if it is present.
 getMenuInflater().inflate(R.menu.activity_child, menu);
 return true;
 }
}

-Dòng lệnh 18:  finish() có nhiệm vụ đóng Activity hiện tại.

– Bạn vừa đi qua 1 ví dụ vô cùng đơn giản.

– Tải coding ở đây:http://www.mediafire.com/?awoq5mkffm00qes

———————————————————————————-

Ví dụ 2: Mở một Activity khác đồng thời truyền dữ liệu qua.

– Bạn xem hình Tôi minh họa dưới này:

24_intent_4– Ở đây Ta thường dùng đối tượng Bundle để đóng gói dữ liệu để truyền tải qua các Activity khác.

– Tại sao lại nên dùng Bundle để truyền tải dữ liệu qua lại giữa các Activity?

+ Tối lấy ví dụ sau: Giả sử bạn phải chuyển toàn bộ hàng hóa từ Việt Nam sang Singapore, trường hợp này Ta sẽ bỏ tất cả các hàng hóa vào trong 1 Container rồi chuyển Container này đi, Không phải chuyển từng món hàng 1 qua Singapore. Tương tự như vậy, đối với Android khi truyền dữ liệu chúng ta cũng có thể truyền từng thông số riêng lẻ nhưng chúng ta không nên, chúng ta phải bỏ tất cả các dữ liệu riêng lẻ đó vào 1 Bundle rồi gửi Bundle này qua Activity nào đó. Bên kia chỉ cần lấy Bundle này ra, mọi dữ liệu đều nằm trong Bundle và ta dễ dàng xử lý.

24_intent_5– Bundle có 2 loại phương thức: putXXX dùng để cho bên gửi đi, ứng với kiểu dữ liệu nào thì put đúng kiểu đó. ở ví dụ trên putInt và putDouble là tương ứng với 2 loại dữ liệu khác nhau (phải đi kèm với key để bên nhận có thể xử lý đúng)

– Ở bên nhận Bundle thì dùng các phương thức getXXX tương ứng để lấy dữ liệu theo key bên gửi.

– key này phải giống nhau cho cả 2 nơi. Nơi nhận đặt key=soa thì bên nhận cũng phải dùng key=soa.

– Ta cũng có thể truyền Đối Tượng qua lại giữa các Activity, các đối tượng này phải được Serialize

24_intent_6– Trong trường hợp truyền đối tượng thì ta dùng putSerializable và getSerializable

– Tôi sẽ làm một ví dụ đơn giản với giao diện như bên dưới:

24_intent_7– Từ MainActivity có 2 thông số là a và b. Khi nhấn nút Kết quả nó sẽ truyền 2 thông số này qua ResultActivity và tiến hành giải phương trình bậc 1. Muốn trở về để tiếp tục giải phương trình khác khi nhấn nút Back.

– Bạn xem cấu trúc chương trình để dễ xử lý:

24_intent_8– Bạn xem giao diện của MainActivity (activity_main.xml):

24_intent_9– Đây là Source XML của MainActivity:

 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:id="@+id/LinearLayout1"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 tools:context=".MainActivity" >
 <TextView
 android:id="@+id/textView1"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:layout_gravity="center"
 android:background="#008040"
 android:gravity="center"
 android:text="Giải phương trình bậc 1"
 android:textColor="#FFFF00" />
 <TableLayout
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:stretchColumns="*"
 >
 <TableRow
 android:id="@+id/tableRow1"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content" >
 <TextView
 android:id="@+id/textView2"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:background="#E5E5E5"
 android:text="Nhập a:" />
 <EditText
 android:id="@+id/txta"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:inputType="text"
 android:ems="10" >
 <requestFocus />
 </EditText>
 </TableRow>
 <TableRow
 android:id="@+id/tableRow2"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content" >
 <TextView
 android:id="@+id/textView3"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:background="#E5E5E5"
 android:text="Nhập b:" />
 <EditText
 android:id="@+id/txtb"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:inputType="text"
 android:ems="10" />
 </TableRow>
 <TableRow
 android:id="@+id/tableRow3"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 >
 <Button
 android:id="@+id/btnketqua"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_column="1"
 android:text="Kết quả" />
 </TableRow>
 </TableLayout>
</LinearLayout>

– Trong xml layout Bạn có thể chọn layout nào cũng được, ở trên Tôi dùng TableLayout

– Tiến hành xem coding của MainActivity.java:

 
package tranduythanh.com;
import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
 
public class MainActivity extends Activity {
 EditText txta,txtb;
 Button btnketqua;
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 txta=(EditText) findViewById(R.id.txta);
 txtb=(EditText) findViewById(R.id.txtb);
 btnketqua=(Button) findViewById(R.id.btnketqua);
 btnketqua.setOnClickListener(new View.OnClickListener() {
 public void onClick(View arg0) {
 //Tạo Intent để mở ResultActivity
 Intent myIntent=new Intent(MainActivity.this, ResultActivity.class);
 //Khai báo Bundle
 Bundle bundle=new Bundle();
 int a=Integer.parseInt(txta.getText().toString());
 int b=Integer.parseInt(txtb.getText().toString());
 //đưa dữ liệu riêng lẻ vào Bundle
 bundle.putInt("soa", a);
 bundle.putInt("sob", b);
 //Đưa Bundle vào Intent
 myIntent.putExtra("MyPackage", bundle);
 //Mở Activity ResultActivity
 startActivity(myIntent);
 }
 });
 }
 public boolean onCreateOptionsMenu(Menu menu) {
 // Inflate the menu; this adds items to the action bar if it is present.
 getMenuInflater().inflate(R.menu.activity_main, menu);
 return true;
 }
}

– Tôi đã giải thích mã lệnh trong đoạn code ở trên rồi.

– Ở dòng 31, key nhận dạng Bundle là MyPackage, bên ResultActivity sẽ dựa vào key này để lấy Bundle ra.

– Sau khi có Bundle rồi thì dựa vào soasob ở dòng lệnh 28,29 để lấy đúng dữ liệu.

– Bây giờ ta qua giao diện ResultActivity:

24_intent_10– Bạn xem XML Resource của ResultActivity:

 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:id="@+id/LinearLayout1"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 tools:context=".ResultActivity" >
 
<TextView
 android:id="@+id/textView1"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:gravity="center"
 android:text="Kết quả giải phương trình bậc 1" />
 
<TextView
 android:id="@+id/txtketqua"
 android:layout_width="match_parent"
 android:layout_height="50sp"
 android:gravity="center"
 android:background="#CCFFD9"
 />
 
<Button
 android:id="@+id/btnBack"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_gravity="center"
 android:text="Back" />
 
</LinearLayout>

– Tiếp tục xem xử lý coding của ResultActivity:

 
package tranduythanh.com;
 
import java.text.DecimalFormat;
 
import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
 
public class ResultActivity extends Activity {
 TextView txtketqua;
 Button btnBack;
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_result);
 btnBack=(Button) findViewById(R.id.btnBack);
 txtketqua=(TextView) findViewById(R.id.txtketqua);
 //lấy intent gọi Activity này
 Intent callerIntent=getIntent();
 //có intent rồi thì lấy Bundle dựa vào MyPackage
 Bundle packageFromCaller=
 callerIntent.getBundleExtra("MyPackage");
 //Có Bundle rồi thì lấy các thông số dựa vào soa, sob
 int a=packageFromCaller.getInt("soa");
 int b=packageFromCaller.getInt("sob");
 //tiến hành xử lý
 giaipt(a, b);
 btnBack.setOnClickListener(new View.OnClickListener() {
 public void onClick(View v) {
 finish();
 }
 });
 }
 public void giaipt(int a,int b)
 {
 String kq="";
 if(a==0 && b==0)
 {
 kq="Vô số nghiệm";
 }
 else if(a==0 && b!=0)
 {
 kq="Vô nghiệm";
 }
 else
 {
 DecimalFormat dcf=new DecimalFormat("0.##");
 kq=dcf.format(-b*1.0/a);
 }
 txtketqua.setText(kq);
 }
 @Override
 public boolean onCreateOptionsMenu(Menu menu) {
 // Inflate the menu; this adds items to the action bar if it is present.
 getMenuInflater().inflate(R.menu.activity_result, menu);
 return true;
 }
}

-Bạn xem dòng lệnh 22: Intent callerIntent=getIntent(); lệnh này cho phép lấy Intent start Activity này. Tức là lấy Intent mà ta khai báo bên MainActivity để start ResultActivity.

– Có được Intent này rồi thì mọi thứ bạn làm như  Tôi giải thích trong Coding ở trên.

– Bạn có thể tải coding mẫu ở đây:http://www.mediafire.com/?vb8ddcoos7dupv7

http://duythanhcse.wordpress.com/

Leave a Reply

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out / Change )

Twitter picture

You are commenting using your Twitter account. Log Out / Change )

Facebook photo

You are commenting using your Facebook account. Log Out / Change )

Google+ photo

You are commenting using your Google+ account. Log Out / Change )

Connecting to %s

%d bloggers like this: