2015-01-24 09:53:25|?次阅读|上传:wustguangh【已有?条评论】发表评论
关键词:Java, Android, 移动应用, 界面设计|来源:唯设编程网
下面分别对4种Toast的显示特效进行解释:
btn_default = (Button) findViewById(R.id.btn_default);
btn_default.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(getApplicationContext(), "默认Toast样式",
Toast.LENGTH_SHORT).show();
}
});
这种最简单,通过静态函数Toast.makeTest得到Toast实例之后直接调用函数show进行显示即可。
btn_def_pos = (Button) findViewById(R.id.btn_def_pos);
btn_def_pos.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast toast = Toast.makeText(getApplicationContext(),
"自定义位置Toast", Toast.LENGTH_LONG);
toast.setGravity(Gravity.CENTER, 0, 0);
toast.show();
}
});
为了定义Toast的位置,我们调用了Toast的成员函数setGravity。
btn_img = (Button) findViewById(R.id.btn_img);
btn_img.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast toast = Toast.makeText(getApplicationContext(),
"带图片的Toast", Toast.LENGTH_LONG);
toast.setGravity(Gravity.CENTER, 0, 0);
LinearLayout toastView = (LinearLayout) toast.getView();
ImageView imageCodeProject = new ImageView(getApplicationContext());
imageCodeProject.setImageResource(R.drawable.icon);
toastView.addView(imageCodeProject, 0);
toast.show();
}
});
我们先使用Toast的getView函数得到对应的布局:LinearLayout,然后在程序中构建了一个ImageView实例,在使用LinearLayout的函数addView将ImageView添加到布局中。
btn_abs_define = (Button) findViewById(R.id.btn_abs_define);
btn_abs_define.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
LayoutInflater inflater = getLayoutInflater();
View layout = inflater.inflate(R.layout.custom,
(ViewGroup) findViewById(R.id.llToast));
ImageView image = (ImageView) layout
.findViewById(R.id.tvImageToast);
image.setImageResource(R.drawable.icon);
TextView title = (TextView) layout.findViewById(R.id.tvTitleToast);
title.setText("提示");
TextView text = (TextView) layout.findViewById(R.id.tvTextToast);
text.setText("这是一个完全自定义Toast");
Toast toast = new Toast(getApplicationContext());
toast.setGravity(Gravity.CENTER | Gravity.CENTER, 0,0);
toast.setDuration(Toast.LENGTH_LONG);
toast.setView(layout);
toast.show();
}
});
这中方式的核心是我们调用了Toast的setView函数,将我们自定义的布局设置为Toast的布局,从而显示我们自定义的布局内容。