安卓第6次课:常用控件02 图片框与进度条

案例一:消息提示框
1. Toast(吐丝框)
(1)简介 Toast是Android中的一种简易的消息提示框

  <Button
                             android:layout_width="wrap_content"
                            android:onClick="studyToast"
                             android:text="点击弹出框!"
                             android:layout_height="wrap_content" />
  (2)使用这个类的最简单的方法是调用静态方法构造您所需要的一切,并返回一个新的Toast对象。
         Toast toast=Toast.makeText(getApplicationContext(), "默认的Toast", Toast.LENGTH_SHORT);
         toast.show();
          第一个参数:当前的上下文环境。可用getApplicationContext()或this
          第二个参数:要显示的字符串。也可是R.string中字符串ID
          第三个参数:显示的时间长短。Toast默认的有两个LENGTH_LONG(长)和LENGTH_SHORT(短),也可以使用毫秒
     public void studyToast(View view) {
                 Toast.makeText(this,"你好 toast",Toast.LENGTH_LONG).show();
         }

============================================================================================
案例二:ImageView
(1) 注意事项:res下面的资源名不能使用大写字母,特别是图片资源中的图片的文件名,会造成R.java文件丢失,改正确后即可
例如:smallImage.png错误,small_image.png正确

  (2) scaleType(缩放类型)
        scaleType的属性值有:matrix   fitXY  fitStart   fitCenter  fitEnd  center   centerCrop  centerInside

            (扩大或缩小至)
           图片宽度=======》控件宽度

    它们之间的区别如下:
      ① matrix 用矩阵来绘制(从左上角起始的矩阵区域)
      ② fitXY  不按比例缩放图片,目标是把整个图片塞满整个View
      ③ fitStart  把图片按比例扩大或缩小到View的[[[宽度]]],然后置顶部显示(图片会完整显示)
      ⑤ fitCenter  把图片按比例扩大或缩小到View的[[[宽度]]],然后居中显示(图片会完整显示)
      ⑥ fitEnd   把图片按比例扩大或缩小到View的[[[宽度]]],然后置底部显示(图片会完整显示)
      ⑦ center  不缩放,将图片按原来大小居中显示,当图片宽高超过View的宽高时,则截取图片的居中部分显示
      ⑧ centerCrop  按比例扩大(或缩小)图片的size居中显示,使得图片的长宽的[[[等于或大于]]]View的长宽
      ⑨ centerInside  按比例扩大(或缩小)图片的size居中显示,使得图片的长宽的[[[等于或小于]]]View的长宽 (图片会完整显示)

用得最多还是fitXY fitStart fitCenter fitEnd
 默认是fitCenter

(3)scaleType属性分二种情况分析
     ① 图片比ImageView小(android08_widget03_d01_v1)
<ImageView
                      android:layout_width="50dp"
                      android:layout_height="50dp"
                      android:layout_marginRight="10dp"
                      android:background="#FF0000"
                      android:scaleType="matrix"
                          android:src="@drawable/small_image" />
     ②图片比ImageView大(android08_widget03_d01_v2)
<ImageView
                       android:layout_width="100dp"
                       android:src="@drawable/small_image"
                       android:background="@color/colorAccent"
                       android:layout_height="100dp" />

============================================================================================

案例三:进度条
①常用属性

             //默认为圆形 
             style="?android:attr/progressBarStyleHorizontal" 
             //进度条的进度
              android:progress="33"
              //进度条最大值
              android:max="100" 
 ② 线程休眠
  Thread.sleep(100);//抛异常
  SystemClock.sleep(100);//不会抛异常

③ 线程注意事项:
不能在主线程中执行耗时的操作,只能在子线程中操作
另外,在子线程中不能操作主线程中的控件(ProgressBar除外)

 SubThread->MainThread    错误

④ Handler(重点、面试问得比较多)
用于线程之间的通信,比如:主线程与子线程

⑤ 线程小结
SubThread->MainThread 错误
SubThread->Handler->MainThread 正确

布局 xml
 <FrameLayout
        android:layout_width="match_parent"
        android:layout_height="60dp">
        <TextView
            android:textColor="@color/colorPrimary"
            android:textSize="20dp"
            android:id="@+id/tv_main_tv1"
            android:layout_width="60dp"
            android:layout_height="match_parent" />
        <ProgressBar
            android:id="@+id/pb_main_pb1"
            android:layout_width="match_parent"
            style="?android:attr/progressBarStyleHorizontal"
            android:max="100"
            android:layout_height="60dp" />
    </FrameLayout>
      <Button
       android:id="@+id/btn_main_btn1"
       android:layout_width="wrap_content"
       android:text="启动进度条"
       android:onClick="setProgressBar"
       android:layout_height="wrap_content" />
方法 Activity.JAVA
    //初始化进度条 
    private ProgressBar pb_main_pb1;
    private int prosess;
    private TextView tv_main_tv1;
    private MyHandler myHandler = new MyHandler();
    private int code = 1;

    private class MyHandler extends Handler{
        @Override
        public void handleMessage(Message msg) {
            super.handleMessage(msg);
            if(code == msg.what){
                prosess ++;
                pb_main_pb1.setProgress(prosess);
                tv_main_tv1.setText(prosess + "%");

            }
        }
    }


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        pb_main_pb1 = this.findViewById(R.id.pb_main_pb1);
        tv_main_tv1 = this.findViewById(R.id.tv_main_tv1);
    }
    //启动进度条
    public void setProgressBar(View view) {
        //判断进度条为0时方可启动
        if(0==prosess){
            new MyThread().start();
        }
    }

    //编写子线程  进行具体操作
    public class MyThread extends Thread{
        @Override
        public void run() {
            super.run();
            while (true){
                //设置休眠时间
                try {
                    Thread.sleep(100);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                //判断进度条的进度  如果执行完了 恢复原来的进度
                if(prosess == 100){
                    prosess = 0;
                    break;
                }
                //触发Handler  将子线程的请求通过Handler发送给主线程
                Message msg = new Message();
                //为了方便多个线程同时进行
                msg.what = 1;
                myHandler.sendMessage(msg);

            }
        }
    }

猜你喜欢

转载自blog.csdn.net/weixin_43163062/article/details/82633252