Android自訂Dialog

來源:互聯網
上載者:User

標籤:

Android開發過程中,常常會遇到一些需求情境——在介面上彈出一個彈框,對使用者進行提醒並讓使用者進行某些選擇性的操作,

如退出登入時的彈窗,讓使用者選擇“退出”還是“取消”等操作。

Android系統提供了Dialog類,以及Dialog的子類,常見如AlertDialog來實現此類功能。

一般情況下,利用Android提供的Dialog及其子類能夠滿足多數此類需求,然而,其不足之處體現在:

1. 基於Android提供的Dialog及其子類樣式單一,風格上與App本身風格可能不太協調;

2. Dialog彈窗在布局和功能上有所限制,有時不一定能滿足實際的業務需求。

本文將通過在Dialog基礎上構建自訂的Dialog彈窗,以最常見的確認彈框為例。

本樣式相對比較簡單:上面有一個彈框標題(提示),下面左右分別是“確認”和“取消”按鈕,當使用者點擊“確認”按鈕時,彈框執行

相應的確認邏輯,當點擊“取消”按鈕時,執行相應的取消邏輯。

首先,自訂彈框樣式:

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="match_parent"    android:layout_height="wrap_content"    android:background="@drawable/dialog_bg"    android:orientation="vertical" >    <TextView        android:id="@+id/title"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_gravity="center"        android:paddingTop="14dp"        android:textColor="@color/login_hint"        android:textSize="@dimen/text_size_18" />    <LinearLayout        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_marginBottom="14dp"        android:layout_marginLeft="20dp"        android:layout_marginRight="20dp"        android:layout_marginTop="30dp" >        <TextView            android:id="@+id/confirm"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_marginRight="10dp"            android:layout_weight="1"            android:background="@drawable/btn_confirm_selector"            android:gravity="center"            android:textColor="@color/white"            android:textSize="@dimen/text_size_16" />        <TextView            android:id="@+id/cancel"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_marginLeft="10dp"            android:layout_weight="1"            android:background="@drawable/btn_cancel_selector"            android:gravity="center"            android:textColor="@color/login_hint"            android:textSize="@dimen/text_size_16" />    </LinearLayout></LinearLayout>

  然後,通過繼承Dialog類構建確認彈框控制項ConfirmDialog:

package com.corn.widget;import android.app.Dialog;import android.content.Context;import android.os.Bundle;import android.util.DisplayMetrics;import android.view.LayoutInflater;import android.view.View;import android.view.Window;import android.view.WindowManager;import android.widget.TextView;import com.corn.R;public class ConfirmDialog extends Dialog {    private Context context;    private String title;    private String confirmButtonText;    private String cacelButtonText;    private ClickListenerInterface clickListenerInterface;    public interface ClickListenerInterface {        public void doConfirm();        public void doCancel();    }    public ConfirmDialog(Context context, String title, String confirmButtonText, String cacelButtonText) {        super(context, R.style.MyDialog);        this.context = context;        this.title = title;        this.confirmButtonText = confirmButtonText;        this.cacelButtonText = cacelButtonText;    }    @Override    protected void onCreate(Bundle savedInstanceState) {        // TODO Auto-generated method stub        super.onCreate(savedInstanceState);        init();    }    public void init() {        LayoutInflater inflater = LayoutInflater.from(context);        View view = inflater.inflate(R.layout.confirm_dialog, null);        setContentView(view);        TextView tvTitle = (TextView) view.findViewById(R.id.title);        TextView tvConfirm = (TextView) view.findViewById(R.id.confirm);        TextView tvCancel = (TextView) view.findViewById(R.id.cancel);        tvTitle.setText(title);        tvConfirm.setText(confirmButtonText);        tvCancel.setText(cacelButtonText);        tvConfirm.setOnClickListener(new clickListener());        tvCancel.setOnClickListener(new clickListener());        Window dialogWindow = getWindow();        WindowManager.LayoutParams lp = dialogWindow.getAttributes();        DisplayMetrics d = context.getResources().getDisplayMetrics(); // 擷取螢幕寬、高用        lp.width = (int) (d.widthPixels * 0.8); // 高度設定為螢幕的0.6        dialogWindow.setAttributes(lp);    }    public void setClicklistener(ClickListenerInterface clickListenerInterface) {        this.clickListenerInterface = clickListenerInterface;    }    private class clickListener implements View.OnClickListener {        @Override        public void onClick(View v) {            // TODO Auto-generated method stub            int id = v.getId();            switch (id) {            case R.id.confirm:                clickListenerInterface.doConfirm();                break;            case R.id.cancel:                clickListenerInterface.doCancel();                break;            }        }    };}

  

在如上空間構造代碼中,由於控制項的"確認"和"取消"邏輯與實際的應用情境有關,因此,控制項中通過定義內部介面來實現。

 

在需要使用此控制項的地方,進行如下形式調用

public static void Exit(final Context context) {        final ConfirmDialog confirmDialog = new ConfirmDialog(context, "確定要退出嗎?", "退出", "取消");        confirmDialog.show();        confirmDialog.setClicklistener(new ConfirmDialog.ClickListenerInterface() {            @Override            public void doConfirm() {                // TODO Auto-generated method stub                confirmDialog.dismiss();                //toUserHome(context);                AppManager.getAppManager().AppExit(context);            }            @Override            public void doCancel() {                // TODO Auto-generated method stub                confirmDialog.dismiss();            }        });    }

  調用中實現了此控制項的內部介面,並賦給控制項本身,以此在點擊按鈕時實現基於外部具體商務邏輯的函數回調。

Android自訂Dialog

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.