常用控件———按钮、图像视图与图像按钮

常用控件———按钮、图像视图与图像按钮

学习目标
1.了解按钮的常用属性和时间绑定
2.了解图像视图和图像按钮的重要属性

一,按钮
继承关系图
在这里插入图片描述
按钮常用属性

  • text(文本内容)
  • textSize(文本大小)
  • textColor(文本颜色)
  • onClick(用于绑定事件)

二,图像视图
继承关系图
在这里插入图片描述
图像视图重要属性

  • src(用于设置图片源)
  • background(用于设置背景图片)
  • scaleType(缩放类型)
  • tint(蒙版)

三,图像按钮
继承关系图
在这里插入图片描述
图像重要属性

  • src(用于设置图片源)
  • background(用于设置背景图片)

四,教学案例——按钮缩放图片
(一)运行效果
通过按钮对图片进行控制
在这里插入图片描述
(二)涉及知识点
1、线性布局(LinearLayout)
2、标签(TextView)
3、按钮(Button)
4、图片(imageView)
5、图像按钮(imageButton)
(三)实现步骤
1、创建安卓应用Dome0603
在这里插入图片描述
2、准备两张背景图片back.jpg与exit.jpg,拷贝到mipmap目录里
在这里插入图片描述
3、注册界面布局资源文件ativity_main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center_horizontal"
    android:padding="10dp"
    android:orientation="vertical" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:gravity="center" >

        <Button
            android:id="@+id/btn_minus"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:onClick="doMinus"
            android:text="@string/X" />

        <Button
            android:id="@+id/btn_plus"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:onClick="doPlus"
            android:text="@string/x" />

        <ImageButton
            android:id="@+id/btn_exit"
            android:layout_width="40dp"
            android:layout_height="40dp"
            android:onClick="doExit"
            android:background="@mipmap/exit" />
    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:gravity="center" >

        <ImageView
            android:id="@+id/iv_bear"
            android:layout_width="200dp"
            android:layout_height="300dp"
            android:src="@mipmap/back" />
    </LinearLayout>

</LinearLayout>

4、字符串资源文件strings.xml

<resources>
    <string name="app_name">Dome0603 button</string>
    <string name="X">缩小图片</string>
    <string name="x">放大图片</string>
</resources>

5、创建显示窗口MainActivity

package net.hw.dome0603button;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.ImageButton;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.Toast;

public class MainActivity extends Activity {
    /**
     * 图像视图
     */
    private ImageView ivBear;
    /**
     * 图像宽度
     */
    private double imageWidth;
    /**
     * 图像高度
     */
    private double imageHeight;
    /**
     * 屏幕宽度
     */
    private double screenWidth;
    /**
     * 屏幕高度
     */
    private double screenHeight;
    /**
     * 缩放比例
     */
    private double zoomScale = 0.9;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_main);

        // 通过资源标识获得控件实例
        ivBear = (ImageView) findViewById(R.id.iv_bear);

        // 获得屏幕尺寸
        screenWidth = getWindowManager().getDefaultDisplay().getWidth();
        screenHeight = getWindowManager().getDefaultDisplay().getHeight();

        // 获得图像尺寸
        imageWidth = ivBear.getLayoutParams().width;
        imageHeight = ivBear.getLayoutParams().height;
    }

    /**
     * 缩小图片单击事件处理方法
     *
     * @param view
     */
    public void doMinus(View view) {
        // 获得图像新尺寸
        int newWidth = (int) (ivBear.getLayoutParams().width * zoomScale);
        int newHeight = (int) (ivBear.getLayoutParams().height * zoomScale);
        // 按新尺寸设置图像(不能缩小为零,否则不能再放大)
        if (newWidth > 10) {
            ivBear.setLayoutParams(new LinearLayout.LayoutParams(newWidth, newHeight));
        } else {
            Toast.makeText(this, "温馨提示:图片不能再缩小,要不然看不见咯!", Toast.LENGTH_LONG)
                    .show();
        }
    }

    /**
     * 放大图片单击事件处理方法
     *
     * @param view
     */
    public void doPlus(View view) {
        // 获得图像新尺寸
        int newWidth = (int) (ivBear.getLayoutParams().width / zoomScale);
        int newHeight = (int) (ivBear.getLayoutParams().height / zoomScale);
        // 按新尺寸设置图像(不能缩小为零,否则不能再放大)
        if (ivBear.getLayoutParams().width < screenWidth) {
            ivBear.setLayoutParams(new LinearLayout.LayoutParams(newWidth, newHeight));
        } else {
            Toast.makeText(this, "温馨提示:图片不能再放大,要不然就出界咯!", Toast.LENGTH_LONG)
                    .show();
        }
    }

    /**
     * 退出应用程序
     *
     * @param view
     */
    public void doExit(View view) {
        finish();
    }

}

五、要点提示
如何设置图像的尺寸?不能像以前设置标签字体属性那样:控件名.set属性名(属性值); 必须通过布局参数类(LayoutParams)来实现。
(1)获得图像尺寸
通过图像视图对象的getLayoutParams()方法得到布局参数对象,然后再利用布局参数对象提供的width与height属性即可获得图像的尺寸。
imageWidth = ivBear.getLayoutParams().width;
imageHeight = ivBear.getLayoutParams().height;
(2)设置图像尺寸
通过图像视图对象的setLayoutParams()方法来设置,必须要传入一个布局参数对象,而该布局参数对象初始化时传入新的图像尺寸。
ivBear.setLayoutParams(new LinearLayout.LayoutParams(newWidth, newHeight));

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值