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的布局,从而显示我们自定义的布局内容。