修饰过的Dialog

    public static Dialog showProgressDialog(Context mContext,String content){
        View view=LayoutInflater.from(mContext).inflate(R.layout.view_progress_dialog,null);
        ((TextView)view.findViewById(R.id.progress_tv_content)).setText(content);
        Dialog progressDialog;
        progressDialog = new Dialog(mContext, R.style.progress_dialog);
        progressDialog.setContentView(view);
        progressDialog.setCancelable(true);
        progressDialog.setCanceledOnTouchOutside(false);
        progressDialog.show();
        return progressDialog;
    }

这段代码最好写到一个专门的类里,写成静态的方法,便于其他界面使用。

Dialog所用的布局文件R.layout.view_progress_dialog代码为:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="180dp"
    android:layout_height="180dp"
    android:background="@drawable/shape_progress_dialog"
    android:gravity="center"
    android:orientation="vertical"
    android:padding="16.0dip">

    <ProgressBar
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        style="?android:progressBarStyleInverse"
        />

    <TextView
        android:id="@+id/progress_tv_content"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:layout_marginTop="8.0dip"
        android:textColor="#fff"
        android:text="load..."
        android:textSize="16.0dip" />
</LinearLayout>

Dialog所有的主题R.style.progress_dialog为:

    <style name="progress_dialog" parent="@android:style/Theme.Dialog">
        <item name="android:windowFrame">@null</item>
        <item name="android:windowIsFloating">true</item>
        <item name="android:windowIsTranslucent">true</item>
        <item name="android:windowNoTitle">true</item>
        <item name="android:background">@null</item>
        <item name="android:windowBackground">@android:color/transparent</item>
        <item name="android:backgroundDimEnabled">true</item>
    </style>
### 关于 Vue 原生 Dialog 组件的使用方法 Vue 官方并没有提供名为 "Dialog" 的内置组件[^1]。然而,在实际开发中,开发者通常会借助第三方库来实现对话框功能,比如 Element UI 或者 Vuetify 提供的强大且易于使用的 `el-dialog` 和 `v-dialog` 组件。 如果希望创建自定义的模态窗口效果,则可以通过组合 HTML `<dialog>` 元素和其他 Vue 特性来自行构建。下面是一个简单的例子: ```html <template> <div id="app"> <!-- 触发打开对话框 --> <button @click="open = true">Open Dialog</button> <!-- 对话框本身 --> <dialog open v-if="open"> <p>This is a simple dialog box.</p> <button @click="closeDialog()">Close</button> </dialog> <!-- 背景遮罩层 (可选) --> <div class="overlay" v-if="open" @click.self="closeDialog()"></div> </div> </template> <script> export default { data () { return { open: false, } }, methods: { closeDialog(){ this.open=false; } } } </script> <style scoped> /* 添加一些样式让其看起来更像传统意义上的弹窗 */ .overlay{ position: fixed; /* 固定定位 */ top: 0; bottom: 0; left: 0; right: 0; background-color: rgba(0,0,0,.5); /* 半透明背景色 */ } dialog { width: fit-content; margin: auto; padding: 2em; border-radius: .5em; text-align:center; } </style> ``` 此代码片段展示了如何利用标准HTML `<dialog>`标签配合Vue的数据绑定机制快速搭建一个基础版本的对话框控件。请注意这里的`@click.self`事件修饰符用于确保只有当点击发生在`.overlay`容器内部而非子元素上时才会触发关闭逻辑。 对于更加复杂的需求场景,建议考虑引入成熟的UI框架所提供的现成解决方案,这些方案往往已经过充分测试并具备良好的用户体验设计。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值