Day 01 -- Dialog

单选

//点选对话框
button01.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
    AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);
    builder.setIcon(R.mipmap.ic_launcher);
    builder.setTitle("单选");

    builder.setPositiveButton("ok", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialog, int which) {
            Toast.makeText(MainActivity.this, "你点击了 ok", Toast.LENGTH_SHORT).show();
        }
    });

    builder.setNegativeButton("cancel", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialog, int which) {
            Toast.makeText(MainActivity.this, "你点击了 cancel", Toast.LENGTH_SHORT).show();
        }
    });

    final String[] strings = {"北京","上海","广州","深圳"};
    builder.setSingleChoiceItems(strings, 3, new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialog, int which) {
            Toast.makeText(MainActivity.this, "您点击了:"+strings[which], Toast.LENGTH_SHORT).show();
        }
    });

    AlertDialog alertDialog = builder.create();
    alertDialog.show();
}
});

多选

//多选
button02.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {

    AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);
    builder.setIcon(R.mipmap.ic_launcher);
    builder.setTitle("多选");
    builder.setPositiveButton("ok", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialog, int which) {
            Toast.makeText(MainActivity.this, "您点击了: ok", Toast.LENGTH_SHORT).show();
        }
    });
    builder.setNegativeButton("cancel", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialog, int which) {
            Toast.makeText(MainActivity.this, "您点击了: cancel", Toast.LENGTH_SHORT).show();
        }
    });
    final String[] strings = {"赤","橙","红","绿"};
    boolean[] booleans = {true,true,true,true};
    builder.setMultiChoiceItems(strings, booleans, new DialogInterface.OnMultiChoiceClickListener() {
        @Override
        public void onClick(DialogInterface dialog, int which, boolean isChecked) {
            Toast.makeText(MainActivity.this, "您点击了:"+strings[which], Toast.LENGTH_SHORT).show();
        }
    });

自定义布局

//自定义布局
button03.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {

    View inflate = LayoutInflater.from(MainActivity.this).inflate(R.layout.zidingyi_layout, null);

    AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);
    builder.setView(inflate);
    builder.setPositiveButton("ok", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialog, int which) {
            Toast.makeText(MainActivity.this, "ok", Toast.LENGTH_SHORT).show();
        }
    });

    builder.setNegativeButton("cancel", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialog, int which) {
            Toast.makeText(MainActivity.this, "cancel", Toast.LENGTH_SHORT).show();
        }
    });

    AlertDialog alertDialog = builder.create();
    alertDialog.show();
}
});

水平

//水平
button04.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
    final ProgressDialog dialog = new ProgressDialog(MainActivity.this);
    dialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
    dialog.setMax(100);
    dialog.setMessage("开始下载。。。");
    dialog.show();

    new CountDownTimer(5000, 50) {
        @Override
        public void onTick(long millisUntilFinished) {
            //增加进度
            dialog.incrementProgressBy(1);
        }

        @Override
        public void onFinish() {
            //结束
            dialog.dismiss();
        }
    }.start();
}
});

圆形

//圆形
button05.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
    final ProgressDialog dialog = new ProgressDialog(MainActivity.this);
    dialog.setProgressStyle(ProgressDialog.STYLE_SPINNER);
    dialog.setMax(100);
    dialog.setMessage("请稍等,开始下载。。。");
    dialog.show();

    //开启增加方法
    new CountDownTimer(5000, 50) {
        @Override
        public void onTick(long millisUntilFinished) {
            //增加进度
            dialog.incrementProgressBy(1);
        }

        @Override
        public void onFinish() {
            //结束方法
            dialog.dismiss();
        }
    }.start();
}
});

日期

//日期
button06.setOnClickListener(new View.OnClickListener() {
@RequiresApi(api = Build.VERSION_CODES.N)
@Override
public void onClick(View v) {
    //这是日期类对象
    Calendar instance = Calendar.getInstance();
    //设置监听
    new DatePickerDialog(MainActivity.this, new DatePickerDialog.OnDateSetListener() {
        @Override
        public void onDateSet(DatePicker view, int year, int month, int dayOfMonth) {
            Toast.makeText(MainActivity.this, ""+year+"\t"+(month+1)+"\t"+dayOfMonth, Toast.LENGTH_SHORT).show();
        }
    },instance.get(Calendar.YEAR),instance.get(Calendar.MONTH),instance.get(Calendar.DAY_OF_MONTH)).show();
}

});

时间

//时间
button07.setOnClickListener(new View.OnClickListener() {
@RequiresApi(api = Build.VERSION_CODES.N)
@Override
public void onClick(View v) {
    //这是日期类对象
    Calendar instance = Calendar.getInstance();
    //设置监听
    new TimePickerDialog(MainActivity.this, new TimePickerDialog.OnTimeSetListener() {
        @Override
        public void onTimeSet(TimePicker view, int hourOfDay, int minute) {
            Toast.makeText(MainActivity.this, ""+hourOfDay+"\t"+minute, Toast.LENGTH_SHORT).show();
        }
    },instance.get(Calendar.HOUR),instance.get(Calendar.MONTH),true).show();
}
});

自定义

首先是自定义的布局

布局
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
and	roid:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#11ffffff">
<LinearLayout
    android:layout_width="300dp"
    android:layout_height="wrap_content"
    android:layout_centerInParent="true"
    android:orientation="vertical">
 	   <TextView
        android:id="@+id/title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
            android:layout_marginTop="10dp"
        android:text="警告"

        android:textColor="#38ADFF"
        android:textSize="16sp"/>
    <TextView
        android:id="@+id/message"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="20dp"
        android:layout_gravity="center"
        android:text="保护视力,少玩手机"/>
    <View
        android:layout_width="match_parent"
        android:layout_height="1px"
        android:layout_marginTop="15dp"
        android:background="#E4E4E4"/>
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="40dp"
        android:orientation="horizontal">
        <Button
            android:id="@+id/no"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:layout_marginLeft="10dp"
            android:background="@null"
            android:gravity="center"
            android:lines="1"
            android:text="取消"
            android:textColor="#7D7D7D"
            android:textSize="16sp"/>
        <View
            android:layout_width="1px"
            android:layout_height="match_parent"
            android:background="#E4E4E4"/>
        <Button
            android:id="@+id/yes"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:layout_marginRight="10dp"
            android:background="@null"
            android:gravity="center"
            android:lines="1"
            android:text="确定"
            android:textColor="#38ADFF"
            android:textSize="16sp"/>

    </LinearLayout>

</LinearLayout>
继承Dialog
package com.example.day_01_dialog;

import android.app.Dialog;
import android.content.Context;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.annotation.PluralsRes;
import android.support.annotation.StyleRes;
import android.view.Display;
import android.view.View;
import android.view.Window;
import android.view.WindowManager;
import android.widget.Button;
import android.widget.TextView;

class DiyDialog extends Dialog {

private Button yes;
private Button no;
private TextView titleTV;
private TextView message;
private String titleStr;
private String messageStr;
private String yesStr, noStr;
private onNoOnclickListener noOnclickListener;
private onYesOnclickListener yesOnclickListener;

public DiyDialog(@NonNull Context context, @StyleRes int themeResId) {
    super(context, themeResId);


    WindowManager windowManager = getWindow().getWindowManager();
    Display display = windowManager.getDefaultDisplay();
    WindowManager.LayoutParams lp = getWindow().getAttributes();
    lp.width = display.getWidth()*4/5;
    getWindow().setAttributes(lp);

}
public DiyDialog(@NonNull Context context) {

    super(context);
    requestWindowFeature(Window.FEATURE_NO_TITLE);
}


public void setNoOnclickListener(String str, onNoOnclickListener onNoOnclickListener) {
    if (str != null) {
        noStr = str;
    }
    this.noOnclickListener = onNoOnclickListener;
}

public void setYesOnclickListener(String str, onYesOnclickListener yesOnclickListener) {
    if (str != null) {
        yesStr = str;
    }
    this.yesOnclickListener = yesOnclickListener;
}

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

    initView();

    initData();

    initEvent();
}

private void initView() {
    yes = findViewById(R.id.yes);
    no = findViewById(R.id.no);
    titleTV = (TextView) findViewById(R.id.title);
    message = (TextView) findViewById(R.id.message);
}


private void initData() {
    if (titleStr != null) {
        titleTV.setText(titleStr);
    }
    if (messageStr != null) {
        message.setText(messageStr);
    }
    if (yesStr != null) {
        yes.setText(yesStr);
    }
    if (noStr != null) {
        no.setText(noStr);
    }
}

private void initEvent() {
    yes.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            if (yesOnclickListener != null) {
                yesOnclickListener.onYesOnclick();
            }
        }
    });
    no.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            if (noOnclickListener != null) {
                noOnclickListener.onNoClick();
            }
        }
    });
}

public void setTitle(String title) {
    titleStr = title;
}

public void setMessage(String message) {
    messageStr = message;
}

public interface onNoOnclickListener {
    public void onNoClick();
}

public interface onYesOnclickListener {
    public void onYesOnclick();
}
}
点击监听。。在activity里
//自定义
button08.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {

    final Dialog dialog = new DiyDialog(MainActivity.this);
    ((DiyDialog) dialog).setTitle("自定义对话框");
    ((DiyDialog) dialog).setMessage("标题");
    ((DiyDialog) dialog).setNoOnclickListener("cancel", new DiyDialog.onNoOnclickListener() {
        @Override
        public void onNoClick() {
            Toast.makeText(MainActivity.this, "您点击了: "+"cancel", Toast.LENGTH_SHORT).show();
            dialog.dismiss();
        }
    });
    ((DiyDialog) dialog).setYesOnclickListener("ok", new DiyDialog.onYesOnclickListener() {
        @Override
        public void onYesOnclick() {
            Toast.makeText(MainActivity.this, "您点击了: "+"ok", Toast.LENGTH_SHORT).show();
            dialog.dismiss();
        }
    });
    dialog.show();
}
});
内容概要:该研究通过在黑龙江省某示范村进行24小时实地测试,比较了燃煤炉具与自动/手动进料生物质炉具的污染物排放特征。结果显示,生物质炉具相比燃煤炉具显著降低了PM2.5、CO和SO2的排放(自动进料分别降低41.2%、54.3%、40.0%;手动进料降低35.3%、22.1%、20.0%),但NOx排放未降低甚至有所增加。研究还发现,经济性和便利性是影响生物质炉具推广的重要因素。该研究不仅提供了实际排放数据支持,还通过Python代码详细复现了排放特征比较、减排效果计算和结果可视化,进一步探讨了燃料性质、动态排放特征、碳平衡计算以及政策建议。 适合人群:从事环境科学研究的学者、政府环保部门工作人员、能源政策制定者、关注农村能源转型的社会人士。 使用场景及目标:①评估生物质炉具在农村地区的推广潜力;②为政策制定者提供科学依据,优化补贴政策;③帮助研究人员深入了解生物质炉具的排放特征和技术改进方向;④为企业研发更高效的生物质炉具提供参考。 其他说明:该研究通过大量数据分析和模拟,揭示了生物质炉具在实际应用中的优点和挑战,特别是NOx排放增加的问题。研究还提出了多项具体的技术改进方向和政策建议,如优化进料方式、提高热效率、建设本地颗粒厂等,为生物质炉具的广泛推广提供了可行路径。此外,研究还开发了一个智能政策建议生成系统,可以根据不同地区的特征定制化生成政策建议,为农村能源转型提供了有力支持。
在 Vue 中,`el-dialog` 是 Element Plus 提供的一个弹出对话框组件。若需要实现点击关闭时出现向左缩小的动画效果,可以通过自定义 `close` 事件结合 CSS 动画来实现。 首先,在模板中为 `el-dialog` 组件绑定一个自定义的关闭方法,并禁用默认的关闭行为: ```vue <el-dialog :model-value="dialogVisible" @close="handleClose" :show-close="false" > <!-- 对话框内容 --> </el-dialog> ``` 接着,在脚本部分定义 `dialogVisible` 控制对话框的显示与隐藏,并定义 `handleClose` 方法用于触发自定义的关闭逻辑: ```ts import { ref } from 'vue' export default { setup() { const dialogVisible = ref(true) const handleClose = () => { // 触发动画前的状态变更 dialogVisible.value = false // 可以在这里添加额外的逻辑,比如延迟隐藏对话框等 } return { dialogVisible, handleClose } } } ``` 最后,在样式部分使用 CSS 定义一个向左缩小的动画效果。这里可以利用 `animate.css` 提供的动画类[^3],或者自定义关键帧动画: ```css @keyframes zoomOutLeft { 0% { opacity: 1; transform: scale(1) translateX(0); } 100% { opacity: 0; transform: scale(0.5) translateX(-100%); } } .zoom-out-left-enter-active, .zoom-out-left-leave-active { animation: zoomOutLeft 0.5s ease-in-out; } ``` 为了将上述动画应用到 `el-dialog` 上,可以在其父容器上添加相应的类名,或者直接修改 `el-dialog` 的类名属性以确保动画生效。需要注意的是,由于 `el-dialog` 实际上是在 body 的其他位置渲染的,因此可能需要通过全局样式或使用 scoped 样式中的深度选择器来覆盖默认样式。 此外,如果项目中已经引入了 `animate.css`,可以直接在 `el-dialog` 上使用其提供的类名来快速实现动画效果,而无需手动编写关键帧动画。 ### 注意事项 - 在实际开发过程中,应考虑动画对用户体验的影响,避免过度动画造成用户不适。 - 如果使用了第三方动画库(如 `animate.css`),请确保正确引入并了解其使用方式。 - 动画效果应当在不影响功能的前提下增强界面交互体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值