Android 仿RxDialog自定义DialogFragment

         一、简介

二、效果预览

​三、实现步骤

(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,"取消");
  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您介绍一下Android仿IOS自定义AlertDialog提示框的实现方法。 首先,我们需要在Android项目中创建一个自定义布局文件,用于显示弹框的内容。可以使用LinearLayout或RelativeLayout等布局容器来组织弹框的内容,例如: ```xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <TextView android:id="@+id/title" android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center" android:text="标题" android:textSize="18sp" /> <TextView android:id="@+id/message" android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center" android:text="内容" android:textSize="14sp" /> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" android:gravity="center"> <Button android:id="@+id/confirm" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="确定" /> <Button android:id="@+id/cancel" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="取消" /> </LinearLayout> </LinearLayout> ``` 接下来,我们需要创建一个自定义AlertDialog类,用于显示弹框和处理按钮点击事件。在这个类中,我们需要实现onCreateDialog方法来加载自定义布局文件,并设置弹框的标题、内容和按钮监听器等。例如: ```java public class IOSAlertDialog extends DialogFragment { private String title; private String message; private DialogInterface.OnClickListener confirmListener; private DialogInterface.OnClickListener cancelListener; public IOSAlertDialog(String title, String message, DialogInterface.OnClickListener confirmListener, DialogInterface.OnClickListener cancelListener) { this.title = title; this.message = message; this.confirmListener = confirmListener; this.cancelListener = cancelListener; } @Override public Dialog onCreateDialog(Bundle savedInstanceState) { LayoutInflater inflater = LayoutInflater.from(getActivity()); View view = inflater.inflate(R.layout.dialog_ios_alert, null); TextView titleView = view.findViewById(R.id.title); TextView messageView = view.findViewById(R.id.message); Button confirmButton = view.findViewById(R.id.confirm); Button cancelButton = view.findViewById(R.id.cancel); titleView.setText(title); messageView.setText(message); confirmButton.setOnClickListener(confirmListener); cancelButton.setOnClickListener(cancelListener); AlertDialog.Builder builder = new AlertDialog.Builder(getActivity()); builder.setView(view); return builder.create(); } } ``` 最后,在我们的Activity中,我们可以通过创建一个实例对象,并调用show方法来显示弹框。例如: ```java IOSAlertDialog dialog = new IOSAlertDialog( "提示", "确定要删除吗?", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { // 确定按钮点击事件 } }, new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { // 取消按钮点击事件 } }); dialog.show(getSupportFragmentManager(), "IOSAlertDialog"); ``` 这样,我们就可以实现一个Android仿IOS自定义AlertDialog提示框了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值