Android 控件 - EditText输入框、ImageView图片、ProgressBar进度条

1、EditText输入框

1.1 输入提示 以及 提示颜色

android:hint : 输入提示
android:textColorHint : 提示颜色

<EditTextandroid:hint="请输入用户名"android:textColorHint="#95a1aa"android:layout_width="200dp"android:layout_height="100dp"/>

在这里插入图片描述

1.2 设置输入类型

android:inputType : 设置输入类型,种类有很多。phone是只能输入数字,textPassword是能输入数字和字符输入后变为点

    <EditTextandroid:hint="请输入用户名"android:textColorHint="#95a1aa"android:inputType="phone"android:layout_width="200dp"android:layout_height="100dp"/><EditTextandroid:hint="请输入用户名"android:textColorHint="#95a1aa"android:inputType="textPassword"android:layout_width="200dp"android:layout_height="100dp"/>

在这里插入图片描述

1.3 在输入框指定方位添加图片

  1. 添加图标 drawable–>new–>vector asset
  2. 引用
    根据需要有:android:drawableStart、android:drawableLeft、android:drawableEnd 等等
    android:drawablePadding : 设置内容与边框的间距
   <EditTextandroid:hint="请输入用户名"android:textColorHint="#95a1aa"android:inputType="textPassword"android:drawableStart="@drawable/ic_baseline_person_24"android:drawablePadding="30dp"android:layout_width="200dp"android:layout_height="100dp"/>

默认间距
在这里插入图片描述

android:drawablePadding=“30dp” :
在这里插入图片描述
android:paddingLeft=“20dp” ,整体内容距离左边的距离

在这里插入图片描述

1.4 设置背景色

android:background :设置背景颜色,当设置为白色时,输入框下划线会消失

   <EditTextandroid:hint="请输入用户名"android:textColorHint="#95a1aa"android:inputType="textPassword"android:drawableStart="@drawable/ic_baseline_person_24"android:drawablePadding="30dp"android:paddingLeft="20dp"android:background="@color/white"android:layout_width="200dp"android:layout_height="100dp"/>

在这里插入图片描述

1.5 获取EditText中的内容

public class MainActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);Button btn = findViewById(R.id.btn);EditText et01 = findViewById(R.id.et01);EditText et02 = findViewById(R.id.et02);btn.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {String et01_str = et01.getText().toString();String et02_str = et02.getText().toString();Log.e("Blake", "输入的内容:" + et01_str);Log.e("Blake", "输入的内容:" + et02_str);}});}
}

在这里插入图片描述

2、ImageView图片

复制两个内容相同但是大小不一样的图片到drawable

2.1 设置图片资源

导入图片并引用,但是可以看出显示的并不友好

 <ImageViewandroid:src="@drawable/test"android:layout_width="200dp"android:layout_height="300dp"/>

在这里插入图片描述

2.2 设置图片显示方式

android:scaleType=“fitXY” 拉伸图片,占满空间,缺点是图片会变形
在这里插入图片描述
android:scaleType=“fitStart” 等比缩放后,放在左上角
在这里插入图片描述
android:scaleType=“fitEnd”,等比缩放后,放在右下角
在这里插入图片描述
android:scaleType=“fitCenter”,等比缩放后,放在中间
在这里插入图片描述
android:scaleType=“center”,保存原图大小,显示在ImageView中心,当原图大小超过ImageView的大小,超过部分裁剪处理
在这里插入图片描述
其他显示方式可自行百度。。。

2.3 设置图片最大宽高

在不超过最大宽高的情况下,等比例缩放图片。
android:maxHeight=“200dp” 最大高度
android:maxWidth=“200dp” 最大宽度
android:adjustViewBounds=“true” 调整view的界限

<ImageViewandroid:src="@drawable/test"android:maxHeight="200dp"android:maxWidth="200dp"android:adjustViewBounds="true"android:layout_width="wrap_content"android:layout_height="wrap_content"/>

在这里插入图片描述

3、ProgressBar进度条

3.1、加载圆圈进度条

activity_main.xml

    <ProgressBarandroid:id="@+id/pb"android:layout_width="200dp"android:layout_height="200dp"/><Buttonandroid:id="@+id/btn"android:text="显示隐藏进度条"android:layout_width="wrap_content"android:layout_height="wrap_content"/>

在MainActivity中设置按钮点击事件

public class MainActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);Button btn = findViewById(R.id.btn);ProgressBar progressBar = findViewById(R.id.pb);btn.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {if (progressBar.getVisibility() == View.GONE) { // 如果进度条消失progressBar.setVisibility(View.VISIBLE);  // 设置为可见} else {progressBar.setVisibility(View.GONE);  // 设置为消失}}});}
}

默认:
在这里插入图片描述
点击按钮:
在这里插入图片描述

3.2、水平进度条

activity_main.xml
android:max : 设置进度条最大值,可以随便设置,因为最后会按照百分比去显示。

<ProgressBarandroid:id="@+id/pb2"style="?android:attr/progressBarStyleHorizontal"android:max="100"android:layout_width="300dp"android:layout_height="wrap_content"/><Buttonandroid:id="@+id/btn02"android:text="模拟下载"android:layout_width="wrap_content"android:layout_height="wrap_content"/>

在MainActivity中设置按钮点击事件

public class MainActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);Button btn = findViewById(R.id.btn);Button btn02 = findViewById(R.id.btn02);ProgressBar progressBar = findViewById(R.id.pb);ProgressBar progressBar2 = findViewById(R.id.pb2);btn.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {if (progressBar.getVisibility() == View.GONE) { // 如果进度条消失progressBar.setVisibility(View.VISIBLE);  // 设置为可见} else {progressBar.setVisibility(View.GONE);  // 设置为消失}}});btn02.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {int progress = progressBar2.getProgress(); // 获取当前进度条的值progress += 10;progressBar2.setProgress(progress);}});}
}

点击模拟下载按钮,每次进度条增加百分之10

还可以设置只显示加载状态,不显示百分比 android:indeterminate=“true”

<!-- 只显示加载状态,不显示百分比   --><ProgressBarstyle="?android:attr/progressBarStyleHorizontal"android:max="100"android:layout_width="300dp"android:indeterminate="true"android:layout_height="wrap_content"/>

在这里插入图片描述

https://www.bilibili.com/video/BV13y4y1E7pF?p=8
https://www.bilibili.com/video/BV13y4y1E7pF?p=9
https://www.bilibili.com/video/BV13y4y1E7pF?p=10

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/518056.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

项目启动时flowable报错提示 version mismatch: library version is *, db version is *

项目启动时flowable报错提示 version mismatch: library version is *, db version is * 可能原因 1.项目中的flowable版本更换了但是数据库中缓存了之前的版本信息 解决&#xff1a; 找到数据库中act_ge_property(ACT_GE_PROPERTY)表更改schema.version的版本或者全部改掉&…

云控平台的双向音频解决方案

导读 随着移动互联网的发展&#xff0c;行业内衍生了基于移动平台的各类解决方案。其中&#xff0c;设备规模化管理的云控能力是各互联网公司在设备集群控制背景下的诉求。因此涌现了大批提供类似解决方案的平台。如&#xff1a;阿里系的阿里云MQC、阿里无线和菜鸟Nimitz等&am…

蚂蚁金服高要求的领域建模能力,对研发来说到底指什么?

来源 | 独自慎思责编 | Carol封图由 CSDN 付费下载于视觉中国最近&#xff0c;由于工作需要&#xff0c;作者接触了网商银行的一个项目。项目里对应的业务模型设计&#xff0c;是我工作这三年来见过的所有模型里最复杂的。于是&#xff0c;利用五一这个短暂的假期&#xff0c;我…

如何造一个“钉钉”?谈谈消息系统架构的实现

阿里妹导读&#xff1a;消息类场景是表格存储&#xff08;Tablestore&#xff09;主推的方向之一&#xff0c;因其数据存储结构在消息类数据存储上具有天然优势。为了方便用户基于Tablestore为消息类场景建模&#xff0c;Tablestore封装Timeline模型&#xff0c;旨在让用户更快…

SprinBoot 集成 Flowable 工作流引擎镜像制作

文章目录一、实现原理1. 镜像制作个数2. 调用流程3. 调用流程分析二、前期准备2.1. 克隆项目到本地2.2. 修改数据库连接和容器别名2.3. 修改请求地址为容器别名&#xff08;后端&#xff09;三、 修改请求地址为容器别名&#xff08;前端&#xff09;3.1. 环境配置3.2. 安装依赖…

Android 控件 - Notification通知、Toolbar、AlertDiallog、PopupWindow

1、Notification通知 创建一个NotificationManager NotificationManager类是一个通知管理器类&#xff0c;这个对象是由系统维护的服务&#xff0c;是以单例模式的方式获得&#xff0c;所以一般并不直接实例化这个对象。在Activity中&#xff0c;可以使用Activity.getSystemSe…

阿里云 ESSD 采用自研新一代存储网络协议,打造“超级高速”

8月26日&#xff0c;阿里云透露&#xff0c;正投入自研数据存储“超级高速”&#xff0c;核心存储产品ESSD已率先采用这一最新的自研存储网络协议&#xff0c;并实现大规模商用&#xff0c;数据传输效率提高50%。 据了解&#xff0c;未来该协议还将继续演进&#xff0c;有望取…

1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and contai

文章目录1. 现象2. docker内部mysql容器 解决方案3. windows和linux 解决方案1. 现象 在使用sql语句创建表时&#xff0c;报错&#xff1a; 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated column ‘information_schema.PRO…

10 人,2 个月 | 虾米音乐的监控体系升级之路

背景 监控一直是服务端掌握应用运行状态的重要手段&#xff0c;经过近几年的发展&#xff0c;阿里虾米服务端目前已经有 100 多个 Java 应用&#xff0c;承担核心业务的应用也有将近 50 个&#xff0c;对于应用的监控配置也是因人而异。有的人配置的监控比较细&#xff0c;有的…

Python 本身真的没什么用!

越来越多的人学习编程不再只是为了当程序员&#xff0c;而是为了提升效率&#xff0c;多一份职业技能&#xff0c;正面应对瞬息万变的全球大环境。据麦肯锡全球研究院发布的一份就业报告中显示&#xff0c;到 2030 年&#xff0c;中国预计将有 1200 万&#xff5e; 1.02 亿人面…

Timestream开发最佳实践

背景 Timestream模型是针对时序场景设计的特有模型&#xff0c;可以让用户快速完成业务代码的开发&#xff0c;实现相关业务需求。但是&#xff0c;如果业务系统不仅想实现基础的相关业务功能&#xff0c;还要达到最佳的性能&#xff0c;并且兼顾到未来的扩展性的话&#xff0…

linux-ubuntu-16.04 安装系统、安装 SSH 服务、设置root用户密码

1、ubuntu-16.04安装 使用UltraISO 软碟通 将 ubuntu-16.04-desktop-amd64.iso 制作为U盘镜像插入U盘&#xff0c;开机按F12选择U盘启动安装过程参考 https://blog.csdn.net/weixin_59605625/article/details/125807363 2、ubuntu-16.04 安装 SSH 服务 $ 在linux中代表普通用…

Error starting userland proxy: listen tcp 0.0.0.0:8080: bind: address already in use.

文章目录一、现象二、解决方案一、现象 [rootlocalhost app]# docker run -p 8080:8080 -p 9326:9326 --name eblog --link es_643:ees --link myrabbit:erabbit --link mymysql:emysql --link myredis:eredis -d eblog:1.0a74c2caaca88203c1ca575cd2f8a0e0426d892d5800c487…

助力企业应用与基础架构现代化 VMware这波组合拳够强!

顺应时代的发展&#xff0c;“数字化转型”已经成为企业发展的必由之路。应用作为数字化转型的核心&#xff0c;能够帮助企业向客户提供定制化的数字化体验&#xff0c;创造新的收入来源。在数字化转型道路上&#xff0c;中国企业走的并不慢甚至非常之快&#xff0c;在此过程中…

应用架构的核心使命是什么?阿里高级技术专家这样说

阿里妹导读&#xff1a;什么是架构&#xff1f;关于架构这个概念很难给出一个明确的定义&#xff0c;也没有一个标准的定义。如果&#xff0c;硬是要给一个概述&#xff0c;阿里巴巴高级技术专家张建飞认为架构就是对系统中的实体以及实体之间的关系所进行的抽象描述。今天&…

2分钟学会Docker部署SpringBoot项目

文章目录一、安装docker1. 在线安装docker2. 换镜像源二、安装redis三、安装mysql四、安装RabbitMq五、安装ElasticSearch5.1. 修改服务器配置5.2. 创建容器并启动 ES5.3. 查看启动日志5.4. 进入镜像5.5. 修改cluster-name5.6. 安装中文分词插件5.7. 退出并重启镜像5.8. 查看启…

linux-ubuntu-16.04 安装 java8、 firewalld、 mysql5.7、Redis 5.0.3、FastDFS、nginx1.18

1、安装java 新建jdk目录 cd /usr/local mkdir java下载JDK8上传到java目录下&#xff0c;解压文件 cd java tar -zxvf jdk-8u201-linux-x64.tar.gz链接&#xff1a;https://pan.baidu.com/s/155P1Y5YetBD0E4PhcPgNfg 提取码&#xff1a;z27j 配置环境变量 vi /etc/profi…

K8s 学习者绝对不能错过的最全知识图谱(内含 56个知识点链接)

导读&#xff1a;Kubernetes 作为云原生时代的“操作系统”&#xff0c;熟悉和使用它是每名用户的必备技能。本篇文章概述了容器服务 Kubernetes 的知识图谱&#xff0c;部分内容参考了网上的知识图谱&#xff0c;旨在帮助用户更好的了解 K8s 的相关知识。 1. 概述 容器服务 …

利用 Docker 在不同宿主机做 CentOS 系统容器 | 原力计划

作者 | 于先森2017责编 | 伍杏玲出品 | CSDN博客最近公司新接到一个项目&#xff0c;惯例是通过技术架构、业务需求、用户量还有以往的经验大概评估出一份资源配置表格提供给客户&#xff0c;让客户参考采购的服务器资源。但这次客户根本没有根据我们提供的参考表格来&#xff…

编程界的“二向箔”——Dart元编程

阅读过《三体》的同学肯定知道“降维打击”&#xff0c;从更高维度看问题&#xff0c;直接将对手KO。今天我们闲聊一下编程界的“二向箔”——元编程。 1. 什么是元编程 我们听过了太多太多的名词&#xff0c;耳朵似乎都有点名词麻痹症了。比如&#xff0c;有些名词为了装x&a…