Android 仿RxDialog自定义DialogFragment

本文介绍如何仿照RxDialog封装一个自定义的DialogFragment工具,包括LinListDialogFragment(列表弹窗)、LinCustomDialogFragment(自定义弹窗)和BaseDialogFragment(基础弹窗)。详细阐述了实现步骤、功能解析,并提供了Demo地址和相关功能的实现代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

         一、简介

二、效果预览

​三、实现步骤

(1)LinListDialogFragment:列表弹窗

(2)LinCustomDialogFragment:自定义弹窗

(3)BaseDialogFragment:base弹窗

四、功能解析

(1)BaseDialogFragment

(2)LinListDialogFragment

(3)LinCustomDialogFragment

五、Demo地址

六、内容推荐


一、简介

不知道大家有没有用过RxDialog,就是封装Dialog的一个工具。没用过不知道是咋也没关系,可以下载本项目玩一下。项目中有集成了RxDialog。而本篇是仿RxDialog弹窗样式制作的一个DialogFragment工具。为什么还要如此多此一举,主要是个人使用RxDialog没有自己定义的方便。所以仿RxDialog又封装了一个。喜欢的可以收藏下没有RxDialog那么多类就是。

二、效果预览

不吹牛逼了,先看看效果自行决定。没那么绚丽多彩,实用就行。没有找到自己想要的样式也可以自定义布局,只需继承下面的一个类即可。

             

底部弹窗主要还是仿微信,不像没关系。大不了不用就是。。。开心就好

​三、实现步骤

上面实现过程分为两个类:LinListDialogFragment,LinCustomDialogFragment

(1)LinListDialogFragment:列表弹窗

1、调用方式

private LinListDialogFragment init;
init = LinListDialogFragment.init(datas).setOnClickListener(new LinListDialogFragment.OnItemClickListener() {
    @Override
    public void onItemClick(BaseQuickAdapter adapter, View view, int position) {
        Toast.makeText(activity,datas.get(position),Toast.LENGTH_SHORT).show();
        init.dismiss();
    }
});

2、LinListDialogFragment实现过程

import android.os.Bundle;
import android.support.v7.widget.OrientationHelper;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import com.chad.library.adapter.base.BaseQuickAdapter;
import java.util.ArrayList;
import blcs.lwb.lwbtool.R;
import blcs.lwb.lwbtool.adapter.DialogFragmentAdapter;
public class LinListDialogFragment extends BaseDialogFragment {
    private View view;
    private DialogFragmentAdapter mAdapter;
    private ArrayList<String> datas;
    private static LinListDialogFragment dialogFragment;
    private final static String Key = "LinListDialogFragment";
    private RecyclerView rv;

    public static LinListDialogFragment init(ArrayList<String> datas) {
        if (dialogFragment == null) {
            dialogFragment = new LinListDialogFragment();
            Bundle bundle = new Bundle();
            bundle.putStringArrayList(Key, datas);
            dialogFragment.setArguments(bundle);
        }
        return dialogFragment;
    }
    @Override
    public View getView(LayoutInflater inflater, ViewGroup container) {
        view =inflater.inflate(R.layout.tool_recyclerview, container,false);
        rv = view.findViewById(R.id.tool_recyclerView);
        Bundle arguments = getArguments();
        datas = arguments.getStringArrayList(Key);
        initRv();
        return view;
    }
    private void initRv() {
        mAdapter = new DialogFragmentAdapter();
        rv.setLayoutManager(new LinearLayoutManager(getActivity(),OrientationHelper.VERTICAL,false));
        rv.setAdapter(mAdapter);
        mAdapter.setNewData(datas);
        mAdapter.setOnItemClickListener(new BaseQuickAdapter.OnItemClickListener() {
            @Override
            public void onItemClick(BaseQuickAdapter adapter, View view, int position) {
                if (linstener != null) {
                    linstener.onItemClick(adapter, view, position);
                }
            }
        });
    }
    public OnItemClickListener linstener;
    public LinListDialogFragment setOnClickListener(OnItemClickListener onItemClickListener) {
        linstener = onItemClickListener;
        return this;
    }
    public interface OnItemClickListener {
        void onItemClick(BaseQuickAdapter adapter, View view, int position);
    }
}

布局就是一个简单RecyclerView。

RecyclerView的适配器大家应该都玩腻了,就不贴了省的浪费空间。如果觉得比较麻烦可以下载本项目直接CP好了

BaseDialogFragment类下面再贴。基础封装类都会被用到。

详细实现过程下面再细说,因为有的可能看了代码就不需要作者再啰嗦了(什么意思都表现在代码里面,任何解释都没代码来的直接、飘逸)。

(2)LinCustomDialogFragment:自定义弹窗

1、调用方式

LinCustomDialogFragment comDialog = LinCustomDialogFragment.init();
//下面的代码写在点击事件当中

//显示透明图片弹窗
comDialog.setImage(R.mipmap.img_view).setType(LinCustomDialogFragment.TYPE_IMAGE).show(getFragmentManager());
//显示确定弹窗
comDialog.setTitle("提示").
        setContent("内容不能为空").
        setType(LinCustomDialogFragment.TYPE_SURE)
        .setOnClickListener(new LinCustomDialogFragment.OnSureListener() {
            @Override
            public void clickSure() {
                 Toast.makeText(activity,"确定",Toast.LENGTH_SHORT).show();
            }
        }).show(getFragmentManager());
//显示确定取消弹窗
comDialog.setTitle(getString(R.string.app_name)).
        setContent("是否退出登录?").
        setType(LinCustomDialogFragment.TYPE_CANCLE)
        .setOnClickListener(new LinCustomDialogFragment.OnSureCancleListener() {
            @Override
            public void clickSure(String str) {
                RxToast.info(activity,"确定");
            }
            @Override
            public void clickCancle() {
                RxToast.info(activity,"取消");
            }
        }).show(getFragmentManager());
//显示输入弹窗
comDialog.setTitle(getString(R.string.app_name)).
        setType(LinCustomDialogFragment.TYPE_EDITEXT)
        .setOnClickListener(new LinCustomDialogFragment.OnSureCancleListener() {
            @Override
            public void clickSure(String str) {
                RxToast.info(activity,str);
            }
            @Override
            public void clickCancle() {
                RxToast.info(activity,"取消");
            }
        }).show(getFragmentManager());
//显示加载弹窗
comDialog.setType(LinCustomDialogFragment.TYPE_LOADING).show(getFragmentManager());
//显示大图弹窗
comDialog.setImage(R.mipmap.ic1).setType(LinCustomDialogFragment.TYPE_IMAGE_BIG).show(getFragmentManager());

2、LinCustomDialogFragment实现过程

import android.text.TextUtils;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.RelativeLayout;
import android.widget.TextView;
import blcs.lwb.lwbtool.R;
import blcs.lwb.lwbtool.View.RxScaleImageView;
import blcs.lwb.lwbtool.utils.dialog.decoder.ImageSource;

public class LinCustomDialogFragment extends BaseDialogFragment implements View.OnClickListener {
    private static final String TAG = "CustomDialogFragment";
    private static LinCustomDialogFragment customDialogFragment;

    private int mipmap;
    private String title;
    private String content;

    private int DialogType;

    public static final int TYPE_IMAGE = 0;
    public static final int TYPE_SURE = 1;
    public static final int TYPE_CANCLE = 2;
    public static final int TYPE_EDITEXT = 3;
    public static final int TYPE_LOADING = 4;
    public static final int TYPE_IMAGE_BIG = 5;
    private EditText et_dialog_fragment_content;
    private TextView tv_dialog_fragment_content;


    public static LinCustomDialogFragment init() {
        if (customDialogFragment == null) {
            customDialogFragment = new LinCustomDialogFragment();
        }
        return customDialogFragment;
    }

    @Override
    public View getView(LayoutInflater inflater, ViewGroup container) {
        View view = inflater.inflate(R.layout.fragment_dialog_custom, container, false);
        initUI(view);
        return view;
    }

    private void initUI(View view) {
        LinearLayout ll_dialog_fragment = view.findViewById(R.id.ll_dialog_fragment);
        //TYPE_IMAGE
        ImageView iv_dialog_fragment = view.findViewById(R.id.iv_dialog_fragment);
        //TYPE_SURE
        LinearLayout ll_dialog_fragment_sure = view.findViewById(R.id.ll_dialog_fragment_sure);
        TextView tv_dialog_fragment_title = view.findViewById(R.id.tv
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值