progressdialog进度框_进度对话框 ProgressDialog 用法总结[通俗易懂]

progressdialog进度框_进度对话框 ProgressDialog 用法总结[通俗易懂]ProgressDialog继承自AlertDialog,AlertDialog继承自DialogpublicclassProgressDialogextendsAlertDialogProgressDialog的创建方式有两种,一种是newProgressDialog,一种是调用ProgressDialog的静态方法show()创建并显示,这种进度条只能是圆形条。imageProgr…

大家好,又见面了,我是你们的朋友全栈君。

ProgressDialog 继承自AlertDialog,AlertDialog继承自Dialog

public class ProgressDialog extends AlertDialog

ProgressDialog的创建方式有两种,一种是new ProgressDialog,一种是调用ProgressDialog的静态方法show()创建并显示,这种进度条只能是圆形条。

a9855cdc4712

image

ProgressDialog dialog = ProgressDialog.show(this, “提示”, “正在登陆中…”, true, false, null);

常用方法

setProgressStyle:设置进度条风格,风格为圆形,旋转的。

setTitlt:设置标题

setMessage:设置提示信息;

setIcon:设置标题图标;

setIndeterminate:设置ProgressDialog 的进度条是否不明确;这个属性对于ProgressDailog默认的转轮模式没有实际意义,默认下设置为true,它仅仅对带有ProgressBar的Dialog有作用。修改这个属性为false后可以实时更新进度条的进度。

setCancelable:设置ProgressDialog 是否可以按返回键取消;

cancelListner:当前Dialog强制取消之后将会被执行,通常用来清理未完成的任务。

setButton:设置ProgressDialog 的一个Button(需要监听Button事件);

show:显示ProgressDialog。

cancel:删除progressdialog

dismiss: 删除progressdialog 作用和cancel相同

setMax(int)、getMax:设置最大进度条的值

setProgress(int)、getProgress:更新进度条,当然一般都需要Handler的结合来更新进度条

incrementProgressBy(int)增加进度条

setProgressDrawable:设置progress发生变化时的进度指示条的背景图

Mainactivity

public class MainActivity extends ListActivity {

private ProgressDialog dialog;

private AlertDialog alertDialog;

private ProgressDialogFragment dialogFragment;

private Handler mHandler = new Handler() {

@Override

public void handleMessage(android.os.Message msg) {

switch (msg.what) {

case 0:

dialog.cancel();// cancel和dismiss唯一的区别是,调用cancel方法会【回调】OnCancelListener

break;

case 1:

int progress = (Integer) msg.obj;

if (progress < 20) {

dialog.incrementProgressBy(5);// 增加进度条的进度

mHandler.sendMessageDelayed(Message.obtain(mHandler, 1, progress + 1), 150);

} else dialog.dismiss();

break;

case 2:

alertDialog.dismiss();

break;

case 3:

getFragmentManager().beginTransaction().remove(dialogFragment).commit();

break;

}

};

};

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

String[] array = { “ProgressDialog.STYLE_SPINNER:不确定的圆形滚动条”,//

“ProgressDialog.STYLE_HORIZONTAL:确定的水平滚动条”, //

“通过AlertDialog实现不确定圆形滚动条效果,其View包含一个ProgressBar”,//

“通过DialogFragment实现不确定圆形滚动条效果,其View包含一个ProgressBar”, };

setListAdapter(new ArrayAdapter(this, android.R.layout.simple_list_item_1, new ArrayList(Arrays.asList(array))));

Fragment fragment = getFragmentManager().findFragmentByTag(“ProgressDialogFragment”);

//旋转屏幕后dialogFragment为空,但是findFragmentByTag的结果不为空,所以dialogFragment将永远不会消失

if (fragment != null) {

if (dialogFragment == null) Toast.makeText(MainActivity.this, “dialogFragment为空,findFragmentByTag不为空”, Toast.LENGTH_SHORT).show();

getFragmentManager().beginTransaction().remove(fragment).commit();

}

}

@Override

protected void onDestroy() {

super.onDestroy();

if (mHandler != null) mHandler.removeCallbacksAndMessages(null);

}

@Override

protected void onListItemClick(ListView l, View v, int position, long id) {

switch (position) {

case 0://旋转屏幕后直接消失

showPD();

mHandler.sendEmptyMessageDelayed(0, 3000);

break;

case 1://旋转屏幕后直接消失

showHorizontalPD();

mHandler.sendMessageDelayed(Message.obtain(mHandler, 1, 0), 150);

break;

case 2://旋转屏幕后直接消失

showAlertDialog();

mHandler.sendEmptyMessageDelayed(2, 3000);

break;

case 3://旋转屏幕后会重新创建

showDialogFragment();

mHandler.sendEmptyMessageDelayed(3, 3000);

break;

}

}

* //跟AlertDailog的样式一摸一样,还有一个圆形进度条!!!!!!!

private void showPD() {

dialog = new ProgressDialog(this);

dialog.setProgressStyle(ProgressDialog.STYLE_SPINNER);//转盘

dialog.setCancelable(false);

dialog.setCanceledOnTouchOutside(false);

dialog.setTitle(“提示”);

dialog.setOnDismissListener(new DialogInterface.OnDismissListener() {

@Override

public void onDismiss(DialogInterface dialog) {

Toast.makeText(MainActivity.this, “消失了”, Toast.LENGTH_SHORT).show();

}

});

dialog.setMessage(“正在加载,请稍后……”);

dialog.show();

}

private void showHorizontalPD() {

dialog = new ProgressDialog(this);

dialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);

dialog.setCancelable(true);

dialog.setCanceledOnTouchOutside(false);

dialog.setIcon(R.drawable.ic_launcher);//这里指的是标题左侧的图标。注意:如果没有设置title只设置Icon的话,是不会显示图标的

dialog.setTitle(“提示”);

dialog.setMax(100);

dialog.setButton(DialogInterface.BUTTON_POSITIVE, “确定…”, new DialogInterface.OnClickListener() {

@Override

public void onClick(DialogInterface dialog, int which) {

Toast.makeText(MainActivity.this, “确定”, Toast.LENGTH_SHORT).show();

}

});

dialog.setButton(DialogInterface.BUTTON_NEGATIVE, “取消…”, new DialogInterface.OnClickListener() {

@Override

public void onClick(DialogInterface dialog, int which) {

Toast.makeText(MainActivity.this, “取消”, Toast.LENGTH_SHORT).show();

}

});

dialog.setMessage(“正在加载,请稍后……”);

dialog.show();

}

private void showAlertDialog() {

alertDialog = new AlertDialog.Builder(this).setView(R.layout.layout).create();

alertDialog.getWindow().setBackgroundDrawableResource(android.R.color.transparent);//设置Dialog背景透明效果

alertDialog.show();

}

private void showDialogFragment() {

dialogFragment = ProgressDialogFragment.newInstance(“加载中…”);

dialogFragment.show(getFragmentManager(), “ProgressDialogFragment”);

}

}

ProgressDialogFragment

public class ProgressDialogFragment extends DialogFragment {

/**构造时把传入的参数带进来,注意一定要通过Bundle及setArguments传递数据*/

public static ProgressDialogFragment newInstance(String message) {

Bundle bundle = new Bundle();//把所有需要传递的数据都放在Bundle中

bundle.putString(“message”, message);

ProgressDialogFragment dialog = new ProgressDialogFragment();

dialog.setArguments(bundle);//通过setArguments把Bundle传递过去

return dialog;

}

@SuppressLint(“InflateParams”)

@Override

public Dialog onCreateDialog(Bundle savedInstanceState) {

View contentView = getActivity().getLayoutInflater().inflate(R.layout.layout, null);

TextView tv_messag = (TextView) contentView.findViewById(R.id.tv_messag);

if (getArguments() != null && !TextUtils.isEmpty(getArguments().getString(“message”))) {

tv_messag.setVisibility(View.VISIBLE);

tv_messag.setText(getArguments().getString(“message”));

} else tv_messag.setVisibility(View.GONE);

Dialog dialog = new Dialog(getActivity());

dialog.requestWindowFeature(Window.FEATURE_NO_TITLE);//设置Dialog没有标题。需在setContentView之前设置,在之后设置会报错

dialog.getWindow().setBackgroundDrawableResource(android.R.color.transparent);//设置Dialog背景透明效果

dialog.setCancelable(false);

dialog.setContentView(contentView);

return dialog;

}

}

@希望能帮助到大家!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/159233.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月14日 上午8:00
下一篇 2022年7月14日 上午8:16


相关推荐

  • 2021最新Java面经系列整理,持续更新「建议收藏」

    2021最新Java面经系列整理,持续更新。。。欢迎大家关注收藏,一起加油O(∩_∩)O哈~2021最新Java面经系列 系列 内容 地址 框架篇 2021最新Java面经整理|框架篇(一)Spring框架 https://blog.csdn.net/shipfei_csdn/article/details/109530018 2021最新Java面经整理|框架篇(二)SpringMVC框架 https://blog.csdn.net/..

    2022年4月18日
    52
  • 斯皮尔曼等级相关称名数据_等级相关系数中的等级怎么算

    斯皮尔曼等级相关称名数据_等级相关系数中的等级怎么算转自:http://blog.csdn.net/wsywl/article/details/58597511、简介在统计学中,斯皮尔曼等级相关系数以CharlesSpearman命名,并经常用希

    2022年8月5日
    11
  • QMovie的使用

    QMovie的使用QMovie是一个可以存放动态视频的类今天第一次使用,记录一下一般是配合QLabel使用的,可以用来存放GIF动态图 m_background=newQLabel(this);m_background->setGeometry(0,0,MENU_WINDOW_WIDTH,MENU_WINDOW_HEIGHT);QMovie*backgroundMovie=newQMovie(“:/images/menu/MenuBackground.gif”,QByteArra

    2022年6月16日
    63
  • linux find命令的使用_linux打包命令tar

    linux find命令的使用_linux打包命令tarLinux中find命令是系统中查找文件的命令,可以帮助用户快速找出自己所需要的文件。通过文件名查找find-name文件名find/etc/-namepasswd###查找/etc目录下的passwd通过文件嵌套层数查找find-maxdepth层数###查找文件时最大层数find-mindepth层数###查找文件时最小层数12例;我们查找/etc中所有.conf文件,可以看…

    2022年10月9日
    4
  • lppl模型 matlab,【数学】用LPPL模型对2015年股灾回测

    lppl模型 matlab,【数学】用LPPL模型对2015年股灾回测来源 雪球 App 作者 阿饭同学 https xueqiu com 前言挺无聊的一个话题 预测才有意思 但是现在用后视镜看问题 本来想做的事情 是考虑人在做一些理性选择的时候 一些特别理性的事情 比如方差在选择中的应用 正期望值或者负期望下的行为 但是显然 这个难度很大 刚好有人提到用 lppl 模型来做下预测 人性太复杂 用一种函数来描述 这个函数还

    2026年3月19日
    2
  • FPN网络详解

    FPN网络详解特征图金字塔网络FPN(FeaturePyramidNetworks)是2017年提出的一种网络,FPN主要解决的是物体检测中的多尺度问题,通过简单的网络连接改变,在基本不增加原有模型计算量的情况下,大幅度提升了小物体检测的性能。低层的特征语义信息比较少,但是目标位置准确;高层的特征语义信息比较丰富,但是目标位置比较粗略。另外虽然也有些算法采用多尺度特征融合的方式,但是一般是采用融合后的特…

    2022年6月12日
    215

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号