使用DialogFragment实现弹出框

类似于这种弹出框。

其实很简单,只不过看着很好看一时间不知道是怎么做的了。

步骤很简单。

第一步:写弹出框的style.xml文件


<style name="dialog" >
    <item name="android:windowBackground">@android:color/transparent</item>
    <item name="android:background">@android:color/transparent</item>
    <item name="android:windowFrame">@null</item>
    <item name="android:windowNoTitle">true</item>
    <item name="android:windowIsFloating">true</item>
    <item name="android:windowIsTranslucent">false</item>
    <item name="android:windowContentOverlay">@null</item>
</style>

记不住就直接复制就行了,就是关于dialog的一些设置,背景,边框,是否浮动什么的。死东西。复制直接用。


第二步:写一个类DiaFragment以及整个对话框的layout文件。


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    >
    <RelativeLayout
        android:orientation="vertical"
        android:id="@+id/ll_back"
        android:background="@mipmap/back"
        android:layout_width="wrap_content"
        android:layout_height="300dp">
        <ImageView
            android:layout_alignParentRight="true"
            android:layout_alignParentTop="true"
            android:src="@mipmap/close"
            android:id="@+id/iv"
            android:layout_width="25dp"
            android:layout_height="25dp" />
    </RelativeLayout>
</LinearLayout>

public class DiaFragment extends DialogFragment {

    public static DiaFragment newInstance() {
        
        Bundle args = new Bundle();
        
        DiaFragment fragment = new DiaFragment();
        fragment.setArguments(args);
        return fragment;
    }
    @Override
    public void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setStyle(DialogFragment.STYLE_NO_TITLE,R.style.dialog);
    }


    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

        View view = inflater.inflate(R.layout.fragment_dialog,null,false);
        view.setElevation(30);//设置阴影,貌似没效果
        ImageView iv = (ImageView) view.findViewById(R.id.iv);
        iv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                dismiss();
            }
        });
        return view;
    }
}

第三步:在需要的时候使用


public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

    }

    public void click(View v){
        DiaFragment.newInstance().show(getSupportFragmentManager(),"dialog");
    }
}

效果如下:


图片再精美一些,效果就会更好,这里只是一个简单的实现,不过原理也就这样,不复杂。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值