常用控件之常用属性
android:visibility="visible/invisible/gone"
visible表示控件可见(默认)/invisible表示控件不可见/gone表示控件不可见且不再占用任何屏幕空间
TextView
android:layout_height/width(match_parent/wrap_content)前者由父布局决定,后者由控件内容决定
android:gravity指定文字的对齐方式
android:textSize 指定文字的大小(sp单位)
android:textColor 指定文字颜色
Button
android:textAllCaps 是否将字母自动进行大写转换 默认true
EditText
android:hint="提示文字" 指定一段提示性文本
android:maxLines="2" 指定最大行数为2
ImageView
android:src="drawable/img_1" 指定一张图片
ProgressBar
用于在屏幕上显示进度条
style="?android:attr/progressBarStyleHorizontal" 通过style属性设置成水平进度条
android:max="100" 通过max设定进度条最大值
AlertDialog
弹出对话框,置顶于所有界面元素之上,能够屏蔽掉其他控件的交互能力
public class MainActivity extends AppCompatActivity implements View.OnClickListener{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button button = findViewById(R.id.button_useful);
button.setOnClickListener(this);
}
@Override
public void onClick(View view) {
switch (view.getId()){
case R.id.button_useful:
AlertDialog.Builder dialog = new AlertDialog.Builder(this);
dialog.setTitle("This is dialog");
dialog.setMessage("Something important.");
dialog.setCancelable(false);
dialog.setPositiveButton("OK", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
}
});
dialog.setNegativeButton("cancel", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
}
});
dialog.show();
break;
default:
break;
}
}
}
ProgressDialog
和AlertDialog相类似,区别是,此控件会在对话框中显示一个进度条
注意,如果progressDialog.setCancelable()填写的是false,则你点击back键无法取消掉,需要自行使用dismiss()来关闭对话框,否则该控件将会一直存在
case R.id.button_progress_dialog:
ProgressDialog progressDialog = new ProgressDialog(this);
progressDialog.setTitle("This is ProgressDialog");
progressDialog.setMessage("Loading...");
progressDialog.setCancelable(true);
progressDialog.show();
break;
Toast
Toast.makeText(context,显示的内容,显示的时间长短);
context--Activity实例或getApplicationContext()得到
时间长短有两种:Toast.LENGTH_LONG/Toast.LENGHT-SHORT
最后.show()用来显示文本
在写Android的XML布局文件时,在ImageView或ImageButton中经常会碰到一个提示:
Missing contentDescription attribute on image.
这个属性是做什么的呢?
这个属性是方便一些生理功能有缺陷的人使用应用程序的。比如我们有一个ImageView里面放置一张颜色复杂的图片,可能一些色弱色盲的人,分不清这张图片中画的是什么东西。如果用户安装了辅助浏览工具比如TalkBack,TalkBack就会大声朗读出用户目前正在浏览的内容。TextView控件TalkBack可以直接读出里面的内容,但是ImageView TalkBack就只能去读contentDescription的值,告诉用户这个图片到底是什么。
public void buttonToImage(View view) {
Toast toast = new Toast(this);
ImageView imageView = new ImageView(this);
//设置图片
imageView.setImageResource(R.drawable.head);
//显示图片
toast.setView(imageView);
toast.setDuration(Toast.LENGTH_LONG);
//设置图片位置
toast.setGravity(Gravity.TOP,0,0);
toast.show();
}
public void buttonToBoth(View view) {
Toast toast = new Toast(this);
TextView textView = new TextView(this);
textView.setText("这是头像");
textView.setGravity(Gravity.CENTER);
textView.setTextSize(20);
ImageView imageView = new ImageView(this);
imageView.setImageResource(R.drawable.head);
//组合
LinearLayout layout = new LinearLayout(this);
//设置垂直
layout.setOrientation(LinearLayout.VERTICAL);
//设置居中
layout.setGravity(Gravity.CENTER);
layout.addView(imageView);
layout.addView(textView);
toast.setView(layout);
toast.setGravity(Gravity.TOP,0,0);
toast.setDuration(Toast.LENGTH_LONG);
toast.show();
}
Menu
节省更多的空间,位于右上角的三点
<item android:id="@+id/item_add"
android:title="Add" />
然后在Activity里重写onCreateOptionsMenu()方法
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main,menu);
return true;
}
getMenuInflater()得到MenuInflater对象,再调用其方法inflate()给当前activity创建菜单
第一个参数用于指定通过哪一个资源文件夹创建菜单,第二个参数用于指定我们的菜单将添加到哪一个Menu对象中
返回true,表示显示菜单,否则菜单无法显示
重写onOptionsItemSelected()方法来定义菜单响应事件
@Override
public boolean onOptionsItemSelected(@NonNull MenuItem item) {
switch(item.getItemId()){
case R.id.item_add:
Toast.makeText(this,"You click Add",Toast.LENGTH_SHORT).show();
break;
case R.id.item_remove:
Toast.makeText(this,"You click Remove",Toast.LENGTH_SHORT).show();
break;
default:
break;
}
return true;
}
|