android中提示&對話方塊----ProgressDialog&DatePickerDialog &TimePickerDialog&PopupWindow,android提示
ProgressDialog(精度條對話方塊):
1.直接調用ProgressDialog提供的靜態方法show()顯示
2.建立ProgressDialog,再設定對話方塊的參數,最後show()出來
package com.example.test3;import android.app.Activity;import android.app.ProgressDialog;import android.content.Context;import android.os.Bundle;import android.os.Handler;import android.os.Message;import android.view.View;import android.widget.Button;public class MainActivity extends Activity implements View.OnClickListener{ private Button btn_one; private Button btn_two; private Button btn_three; private ProgressDialog pd1 = null; private ProgressDialog pd2 = null; private final static int MAXVALUE = 100; private int progressStart = 0; private int add = 0; private Context mContext = null; //定義一個用於更新進度的Handler,因為只能由主線程更新介面,所以要用Handler傳遞資訊 final Handler hand = new Handler() { @Override public void handleMessage(Message msg) { //這裡的話如果接受到資訊碼是123 if(msg.what == 123) { //設定進度條的當前值 pd2.setProgress(progressStart); } //如果當前大於或等於進度條的最大值,調用dismiss()方法關閉對話方塊 if(progressStart >= MAXVALUE) { pd2.dismiss(); } } }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mContext = MainActivity.this; bindViews(); } private void bindViews() { btn_one = (Button) findViewById(R.id.btn1); btn_two = (Button) findViewById(R.id.btn2); btn_three = (Button) findViewById(R.id.btn3); btn_one.setOnClickListener(this); btn_two.setOnClickListener(this); btn_three.setOnClickListener(this); } @Override public void onClick(View v) { switch (v.getId()){ case R.id.btn1: //這裡的話參數依次為,上下文,標題,內容,是否顯示進度,是否可以用取消按鈕關閉 ProgressDialog.show(MainActivity.this, "資源載入中", "資源載入中,請稍後...",false,true); break; case R.id.btn2: pd1 = new ProgressDialog(mContext); //依次設定標題,內容,是否用取消按鈕關閉,是否顯示進度 pd1.setTitle("軟體更新中"); pd1.setMessage("軟體正在更新中,請稍後..."); pd1.setCancelable(true); //這裡是設定進度條的風格,HORIZONTAL是水平進度條,SPINNER是圓形進度條 pd1.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL); pd1.setIndeterminate(true); //調用show()方法將ProgressDialog顯示出來 pd1.show(); break; case R.id.btn3: //初始化屬性 progressStart = 0; add = 0; //依次設定一些屬性 pd2 = new ProgressDialog(MainActivity.this); pd2.setMax(MAXVALUE); pd2.setTitle("檔案讀取中"); pd2.setMessage("檔案載入中,請稍後..."); //這裡設定為不可以通過按取消按鈕關閉進度條 pd2.setCancelable(false); pd2.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL); //這裡設定的是是否顯示進度,設為false才是顯示的哦! pd2.setIndeterminate(false); pd2.show(); //這裡的話建立一個線程,重寫run()方法, new Thread() { public void run() { while(progressStart < MAXVALUE) { //這裡的演算法是決定進度條變化的,可以按需要寫 progressStart = 2 * usetime() ; //把資訊碼發送給handle讓更新介面 hand.sendEmptyMessage(123); } } }.start(); break; } } //這裡設定一個耗時的方法: private int usetime() { add++; try{ Thread.sleep(100); }catch (InterruptedException e) { e.printStackTrace(); } return add; }}
2.Date/TimePickerDialog只是供使用者來選擇日期時間,對於android系統的系統時間, 日期沒有任何影響
他們兩個的構造方法非常相似: DatePickerDialog(上下文;DatePickerDialog.OnDateSetListener()監聽器;年;月;日)
TimePickerDialog(上下文;TimePickerDialog.OnTimeSetListener()監聽器;小時,分鐘,是否採用24小時制)
public class MainActivity extends AppCompatActivity implements View.OnClickListener{ private Button btn_date; private Button btn_time; private String result = ""; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); bindViews(); } private void bindViews() { btn_date = (Button) findViewById(R.id.btn_date); btn_time = (Button) findViewById(R.id.btn_time); btn_date.setOnClickListener(this); btn_time.setOnClickListener(this); } @Override public void onClick(View v) { result = ""; switch (v.getId()){ case R.id.btn_date: Calendar cale1 = Calendar.getInstance(); new DatePickerDialog(MainActivity.this,new DatePickerDialog.OnDateSetListener() { @Override public void onDateSet(DatePicker view, int year, int monthOfYear, int dayOfMonth) { //這裡擷取到的月份需要加上1哦~ result += "你選擇的是"+year+"年"+(monthOfYear+1)+"月"+dayOfMonth+"日"; Toast.makeText(getApplicationContext(), result, Toast.LENGTH_SHORT).show(); } } ,cale1.get(Calendar.YEAR) ,cale1.get(Calendar.MONTH) ,cale1.get(Calendar.DAY_OF_MONTH)).show(); break; case R.id.btn_time: Calendar cale2 = Calendar.getInstance(); new TimePickerDialog(MainActivity.this, new TimePickerDialog.OnTimeSetListener() { @Override public void onTimeSet(TimePicker view, int hourOfDay, int minute) { result = ""; result += "您選擇的時間是:"+hourOfDay+"時"+minute+"分"; Toast.makeText(getApplicationContext(), result, Toast.LENGTH_SHORT).show(); } }, cale2.get(Calendar.HOUR_OF_DAY), cale2.get(Calendar.MINUTE), true).show(); break; } }}
最後一個用於顯示資訊的UI控制項——PopupWindow(懸浮框),如果你想知道 他長什麼樣子,你可以開啟你手機的QQ,長按列表中的某項,這個時候後彈出一個黑色的小 對話方塊,這種就是PopupWindow了,和AlertDialog對話方塊不同的是,他的位置可以是隨意的; 另外AlertDialog是非堵塞線程的,而PopupWindow則是堵塞線程的
1)幾個常用的構造方法
我們在文檔中可以看到,提供給我們的PopupWindow的構造方法有九種之多,這裡只貼實際 開發中用得較多的幾個構造方法:
- public PopupWindow (Context context)
- public PopupWindow(View contentView, int width, int height)
- public PopupWindow(View contentView)
- public PopupWindow(View contentView, int width, int height, boolean focusable)
參數就不用多解釋了吧,contentView是PopupWindow顯示的View,focusable是否顯示焦點
2)常用的一些方法
下面介紹幾個用得較多的一些方法,其他的可自行查閱文檔:
- setContentView(View contentView):設定PopupWindow顯示的View
- getContentView():獲得PopupWindow顯示的View
- showAsDropDown(View anchor):相對某個控制項的位置(正左下方),無位移
- showAsDropDown(View anchor, int xoff, int yoff):相對某個控制項的位置,有位移
- showAtLocation(View parent, int gravity, int x, int y): 相對於父控制項的位置(例如正中央Gravity.CENTER,下方Gravity.BOTTOM等),可以設定位移或無位移 PS:parent這個參數只要是activity中的view就可以了!
- setWidth/setHeight:設定寬高,也可以在構造方法那裡指定好寬高, 除了可以寫具體的值,還可以用WRAP_CONTENT或MATCH_PARENT, popupWindow的width和height屬性直接和第一層View相對應。
- setFocusable(true):設定焦點,PopupWindow彈出後,所有的觸屏和物理按鍵都由PopupWindows 處理。其他任何事件的響應都必鬚髮生在PopupWindow消失之後,(home 等系統層面的事件除外)。 比如這樣一個PopupWindow出現的時候,按back鍵首先是讓PopupWindow消失,第二次按才是退出 activity,準確的說是想退出activity你得首先讓PopupWindow消失,因為不並是任何情況下按back PopupWindow都會消失,必須在PopupWindow設定了背景的情況下 。
- setAnimationStyle(int):設定動畫效果
public class MainActivity extends Activity { private Button btn_show; private Context mContext; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mContext = MainActivity.this; btn_show = (Button) findViewById(R.id.btn_show); btn_show.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { initPopWindow(v); } }); } private void initPopWindow(View v) { View view = LayoutInflater.from(mContext).inflate(R.layout.item_popup, null, false); Button btn_xixi = (Button) view.findViewById(R.id.btn_xixi); Button btn_hehe = (Button) view.findViewById(R.id.btn_hehe); //1.構造一個PopupWindow,參數依次是載入的View,寬高 final PopupWindow popWindow = new PopupWindow(view, ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT, true); popWindow.setAnimationStyle(R.anim.anim_pop); //設定載入動畫 //這些為了點擊非PopupWindow地區,PopupWindow會消失的,如果沒有下面的 //代碼的話,你會發現,當你把PopupWindow顯示出來了,無論你按多少次後退鍵 //PopupWindow並不會關閉,而且退不出程式,加上下述代碼可以解決這個問題 popWindow.setTouchable(true); popWindow.setTouchInterceptor(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { return false; // 這裡如果返回true的話,touch事件將被攔截 // 攔截後 PopupWindow的onTouchEvent不被調用,這樣點擊外部地區無法dismiss } }); popWindow.setBackgroundDrawable(new ColorDrawable(0x00000000)); //要為popWindow設定一個背景才有效 //設定popupWindow顯示的位置,參數依次是參照View,x軸的位移量,y軸的位移量 popWindow.showAsDropDown(v, 50, 0); //設定popupWindow裡的按鈕的事件 btn_xixi.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Toast.makeText(MainActivity.this, "你點擊了嘻嘻~", Toast.LENGTH_SHORT).show(); } }); btn_hehe.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Toast.makeText(MainActivity.this, "你點擊了呵呵~", Toast.LENGTH_SHORT).show(); popWindow.dismiss(); } }); }}