Android之Dialog

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android之Dialog相关的知识,希望对你有一定的参考价值。

一 : UI设计
1 , Dialog(对话框)
1-1 : 新建 dialog_bay.xml , 方法 : 右击“layout” -> new -> XML -> Layout XML File , 如下图
技术分享图片
1-2 : ui当中的重要的控件
①,(RadioGroup)rg_type : 单选按钮组
①-1 : (RadioButton)rb_zfb : 支付宝
①-2 : (RadioButton)rb_wx : 微信
②, (Button)btn_ok : 确定按钮
1-3 : 界面布局如下:
技术分享图片

            2,activity_main.xml(主界面UI)设计
                        2-1 : ui当中的重要的控件
                                    ①  , (Button) btn_pay : 确定支付
                        2-2 : 界面如下:

技术分享图片
2-3 : 注意 , 为简化起见,没有放商品图片 。这里重点讲解对话框

二 :代码设计
①,DialogPay.java

package com.example.kayer.dialogdemo;

import android.app.DialogFragment;
import android.graphics.Color;
import android.graphics.drawable.ColorDrawable;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.util.Log;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.Window;
import android.view.WindowManager;
import android.widget.Button;
import android.widget.RadioGroup;

public final class DialogPay extends DialogFragment {
    private final String TAG = "测试Pay";
    private View _contentView = null;
    private OnDialogPayListener _listener = null;

    public interface OnDialogPayListener{
        void onDialogPayReturn( String $option );
    }

    public void setOnDialogPayListener( OnDialogPayListener $listener ){
        this._listener = $listener;
    }
    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, Bundle savedInstanceState) {
        //创建View
        this._contentView = inflater.inflate( R.layout.dialog_pay  , container);

        //点击按钮关闭对话框
        Button $button = (Button)this._contentView.findViewById(R.id.btn_ok);
        $button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //关闭
                DialogPay.this.dismiss();
                //返回数据
                DialogPay.this.returnInfos();

            }
        });
        return this._contentView;
    }

    public void returnInfos(){
        RadioGroup $rg = (RadioGroup)this._contentView.findViewById(R.id.rg_type);
        int $rb_id = $rg.getCheckedRadioButtonId();
        String $option = $rb_id == R.id.rb_zfb ? "支付宝" : "微信";
        Log.d(this.TAG , "对话框选择的支付方式: " + $option );
        if(null != this._listener){
            this._listener.onDialogPayReturn( $option );
        }
    }

    @Override
    public void onStart() {
        super.onStart();
        //当对话框显示时 , 调整对话框的窗口位置
        Window $win = getDialog().getWindow();
        if( null != $win ){
            $win.setBackgroundDrawable( new ColorDrawable(Color.WHITE));
            //设置对话框的窗口显示
            WindowManager.LayoutParams $lp = $win.getAttributes();
            $lp.dimAmount = 0.3f;//背景灰度
            $lp.gravity = Gravity.BOTTOM;//靠下显示
            $lp.width = ViewGroup.LayoutParams.MATCH_PARENT;
            $lp.height = ViewGroup.LayoutParams.WRAP_CONTENT;
            $win.setAttributes($lp);
        }
    }
}

注意 : DialogFragment 是出自 android.app.Dialogfragment 包
定义了一个类似与一个监听器
技术分享图片
② ,MainActivity.java

package com.example.kayer.dialogdemo;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {
    private Button btn_pay = null;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        this.init();
    }

    private void init(){
        this.btn_pay = (Button)findViewById(R.id.btn_pay);
        this.btn_pay.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                DialogPay $dl = new DialogPay();
                $dl.setOnDialogPayListener(new DialogPay.OnDialogPayListener() {
                    @Override
                    public void onDialogPayReturn(String $option) {
                        //处理对话框返回来的数据
                        Toast.makeText(MainActivity.this, "对话框返回的数据:" + $option, Toast.LENGTH_SHORT).show();
                    }
                });
                $dl.show(getFragmentManager(),"DialogPay");
            }
        });
    }
}

注意 , 为对话框注册监听器
技术分享图片

以上是关于Android之Dialog的主要内容,如果未能解决你的问题,请参考以下文章

Android之底部Dialog里面放EditText点击布局顶上去效果

Android开发实战之底部Dialog弹出效果

Android 自定义控件之 日期选择控件

Android之Dialog

我的Android进阶之旅NDK开发之在C++代码中使用Android Log打印日志,打印出C++的函数耗时以及代码片段耗时详情

Android之Dialog半透明背景消失