android基础 [超级详细android常用控件解析(ScollView控件,ProgressBar进度条,PopupWindow控件)]
目录
1 章节目录
2 ScollView控件
2.1 ScrollView简介
2.2 ScrollView使用
2.3 常用属性及方法
3 ProgressBar进度条
3.1 简介
3.2 常用属性
3.3 常用方法
3.4 简单的使用
4 PopupWindow控件
4.1 常用方法
4.2 创建流程:
4.3 PopupWindow的配置参数详解
1 章节目录
ScollView控件
ProgressBar进度条
PopupWindow控件
2 ScollView控件
2.1 ScrollView简介
ScrollView就是可以滚动的用户布局容器
如果手机显示不下子布局,那么可以使用scrollView
2.2 ScrollView使用
不要在scrollView中添加
RecyclerView
或者是ListView
布局,这样会引起不好的体验因为会有滑动冲突的问题出现。ScrollView的直接子View只能有一个。也就是说如果你要在滚动视图中添加多个视图,你需要一个标准的容器,如
LinearLayout
、RelativeLayout
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".MainActivity">
<ScrollViewandroid:layout_width="match_parent"android:layout_height="match_parent"><LinearLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="vertical"><TextViewandroid:id="@+id/textView"android:layout_width="match_parent"android:layout_height="wrap_content"android:text="Hello World1" />
<TextViewandroid:id="@+id/textView2"android:layout_width="match_parent"android:layout_height="wrap_content"android:text="Hello World2" /></LinearLayout></ScrollView>
</LinearLayout>
ScrollView只支持竖直滑动,想要水平滑动需要使用
HorizontalScrollView
。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context=".MainActivity"><HorizontalScrollViewandroid:layout_width="match_parent"android:layout_height="match_parent"><LinearLayoutandroid:layout_width="wrap_content"android:layout_height="match_parent"android:orientation="vertical" ></LinearLayout></HorizontalScrollView>
</LinearLayout>
2.3 常用属性及方法
可以直接利用ScrollView给我们提供的:fullScroll()方法:
scrollView.fullScroll(ScrollView.FOCUS_DOWN);滚动到底部
scrollView.fullScroll(ScrollView.FOCUS_UP);滚动到顶部
隐藏滑块:
android:scrollbars="none"
设置滚动速度: 继承ScrollView,然后重写一个 public void fling (int velocityY)的方法:
@Override
public void fling(int velocityY) {super.fling(velocityY / 2); //速度变为原来的一半
}
public class ScrollViewActivity extends AppCompatActivity implements
View.OnClickListener {private Button btn_down;private Button btn_up;private ScrollView scrollView;private TextView txt_show;@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.scrollview_layout);bindViews();}private void bindViews() {btn_down = (Button) findViewById(R.id.btn_down);btn_up = (Button) findViewById(R.id.btn_up);scrollView = (ScrollView) findViewById(R.id.scrollView);txt_show = (TextView) findViewById(R.id.txt_show);btn_down.setOnClickListener(this);btn_up.setOnClickListener(this);StringBuilder sb = new StringBuilder();for (int i = 1; i <= 100; i++) {sb.append("我是一条文本内容 * " + i + "\n");}txt_show.setText(sb.toString());}@Overridepublic void onClick(View v) {switch (v.getId()) {case R.id.btn_down:scrollView.fullScroll(ScrollView.FOCUS_DOWN);break;case R.id.btn_up:scrollView.fullScroll(ScrollView.FOCUS_UP);break;}}
}
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><Buttonandroid:id="@+id/btn_down"android:layout_width="match_parent"android:layout_height="wrap_content"android:text="滚动到底部" /><Buttonandroid:id="@+id/btn_up"android:layout_width="match_parent"android:layout_height="wrap_content"android:text="滚动到顶部" /><ScrollViewandroid:id="@+id/scrollView"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_weight="1"><TextViewandroid:id="@+id/txt_show"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="" /></ScrollView>
</LinearLayout>
3 ProgressBar进度条
3.1 简介
进度条是UI界面中一种非常实用的组件,通常用于向用户像是某个耗时操作完成的百分比。进度条可动态地显示进度,因此避免长时间地执行某个操作时,让用户感觉程序失去了响应,从而更好地提高用户界面的友好性。
进度条大体分为 水平型(条形)和 环形 如图所示:几乎所有的花样的进度条都主要为这两种类型。
3.2 常用属性
属性名 | 含义 |
---|---|
style | 设置进度条的风格 |
max | 设置该进度条的最大值 |
maxHeight | 进度Widget最大高 |
miniHeight | 进度Widget最小高 |
maxWidth | 进度Widget最大宽 |
minWidth | 进度Widget最小宽 |
progress | 设置该进度条的已完成进度值 |
progressDrawable | 自定义drawable显示 |
indeteminateDrawable | 设置绘制不显示进度的进度条的Drawable对象 |
indeterminate | 该属性设为true,设置进度条不精确显示进度 |
indeteminateDuration | 设置不精确显示进度的持续时间 |
secondaryProgress | 定义二级进度值,值介于0到max。该进度在主进度和背景之间。比如用于网络播放视频时,二级进度用于表示缓冲进度,主进度用于表示播放进度。 |
interpolator | 设置动画速度 |
indeterminateBehavior | 定义当进度达到最大时,不确定模式的表现;该值必须为repeat或者cycle,repeat表示进度从0重新开始;cycle表示进度保持当前值,并且回到0 |
style属性:
@android:style/Widget.ProgressBar.Horizontal:水平进度条
@android:style/Widget.ProgressBar.Inverse:普通大小的进度条
@android:style/Widget.ProgressBar.Large:大环形进度条
@android:style/Widget.ProgressBar.Large.Inverse:大环形进度条
@android:style/Widget.ProgressBar.Small:小环形进度条
@android:style/Widget.ProgressBar.Small.Inverse:小环形进度条
3.3 常用方法
getMax() //返回这个进度条的范围的上限getProgress():返回进度 getsecondaryProgress() //返回二级进度 incrementProgressBy(int diff) //指定增加的进度 isIndeterminate() //指示进度条是否在不确定模式下 setIndeterminate(boolean indeterminate) //设置不确定模式下
3.4 简单的使用
编写布局文件
<!--系统提供的进度条-->
<TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:text="水平进度条"android:layout_marginTop="50dp"android:layout_gravity="center"/>
<ProgressBarandroid:id="@+id/progress_01"android:layout_width="match_parent"android:layout_height="30dp"android:max="100"android:layout_marginTop="100dp"android:padding="20dp"style="@style/Widget.AppCompat.ProgressBar.Horizontal"/>
<TextViewandroid:id="@+id/tv_progress"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_below="@id/progress_01"android:layout_centerHorizontal="true"/>
4 PopupWindow控件
PopupWindow,顾名思义弹窗.PopupWindow是与AlertDialog在形式上类似的弹窗功能,都是为了在activity最上层显示一个弹窗.但是区别是PopupWindow可以自定义出现的位置,并且可以添加入自己需要的View或者导入自己写好的xml布局
4.1 常用方法
方法 | 说明 |
---|---|
setContentView(View contentView) | 设置PopupWindow显示的View |
showAsDropDown(View anchor) | 相对某个控件的位置(正左下方),无偏移 |
showAsDropDown(View anchor, int xoff, int yoff) | 相对某个控件的位置,有偏移 |
setFocusable(boolean focusable) | 设置是否获取焦点 |
setBackgroundDrawable(Drawable background) | 设置背景 |
dismis() | 关闭弹窗 |
setAnimationStyle(int animationStyle) | 设置加载动画 |
setTouchable(boolean touchable) | 设置触摸使能 |
setOutsideTouchable(boolean touchable) | 设置PopupWindow外面的触摸使能 |
4.2 创建流程:
用LayoutInflater获得xml布局View .或者直接在代码上new一个View
实例化一个PopupWindow,将View在实例化作为参数传入
配置PopupWindow参数
代码:
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState);setContentView(R.layout.activity_main2);// 方法1:自定义xml,然后用LayoutInflater获得xml布局View// View popupView = getLayoutInflater().inflate(R.layout.popupview,null);// 方法2:直接在代码上new一个ViewTextView textView = new TextView(Main2Activity.this);textView.setText("测试文本"); final PopupWindow popupWindow = new PopupWindow(textView,200,300);//参数为1.View
2.宽度 3.高度
popupWindow.setOutsideTouchable(true);//设置点击外部区域可以取消popupWindowmTestButton = (Button)findViewById(R.id.test_btn);mTestButton.setOnClickListener(new View.OnClickListener() {@Override public void onClick(View v) {popupWindow.showAsDropDown(mTestButton);//设置popupWindow显示,并且告诉它显示在那个View下面}});}
效果图:
4.3 PopupWindow的配置参数详解
设置内容View
setContentView(View contentView)
除了正常在实例化PopupWindow的时候直接将view传入也可以用这个方法在实例化后重新配置需要的view
设置PopupWindow宽度与高度
setWidth(int width)
setHeight(int height)
除了正常实例化的时候传入宽度与高度,也可以用这个2个方法在实例化后在重新配置需要的宽度与高度
设置PopupWindow背景
setBackgroundDrawable(Drawable background)
final PopupWindow popupWindow = new PopupWindow(textView,200,300);
popupWindow.setOutsideTouchable(true);
popupWindow.setBackgroundDrawable(getResources().getDrawable(R.drawable.ic\_launcher\_background));//设置背景
mTestButton = (Button)findViewById(R.id.test_btn);
mTestButton.setOnClickListener(new View.OnClickListener() {@Override public void onClick(View v) {popupWindow.showAsDropDown(mTestButton);}
});
设置外部点击退出
setOutsideTouchable(boolean touchable)
设置PopupWindow可聚焦
setFocusable(boolean focusable)
除了一般的聚焦选中功能,还有一个用处重点!重点!重点!设置了可聚焦后,返回back键按下后,不会直接退出当前activity而是先退出当 前的PopupWindow.
设置弹窗弹出的动画高度
setElevation(float elevation)
原本没有设置,弹窗的弹出动画效果位置就只会在控件附件,但是设置后弹窗的起始动画位置就变更远了.请看下面的效果图:
popupWindow.setElevation(1000f);//我将动画位置设置为1000f
设置显示方法参数
// 传入 AnchorView ,锚点实际为 Window
// Gravity.TOP 在该锚点的正上方
// Gravity.LEFT 在屏幕左侧
// Gravity.NO_GRAVITY,在屏幕左上角
// x 为坐标系 x轴方向的偏移量,左负右正
// y 为坐标系 y轴方向的偏移量,上负下正
popupWindow.showAtLocation(view, Gravity.TOP, 0, y);
popupWindow.showAtLocation(view, Gravity.NO_GRAVITY,x, y);
popupWindow.showAtLocation(view, Gravity.TOP, 0, y);
显示提供了两种形式:
showAtLocation()显示View的内部在指定位置()
有两个方法重载:
这个属性一般使用在在整个Activity的window里显示,也就是在整个屏幕内,这个也支持在指定View的内部找到锚点.
例子1:如果你需要在一个布局的里面的下方显示就只需要设置属性为
popupWindow.showAtLocation(view,Gravity.BOTTOM,0,0);
例子2:如果你需要在Activity的window里显示的下方显示就需要设置属性为:
popupWindow.showAtLocation(activity.getWindow().getDecorView(),Gravity.BOTTOM,0,0);
public void showAtLocation(View parent, int gravity, int x, int y)
public void showAtLocation(IBinder token, int gravity, int x, int y)
1234
showAsDropDown()显示在一个参照物View的外部周围
有三个方法重载:
注意!这里参照物View的周围,使用这个方法是无法在View的内部找到锚点,它的锚点都是围绕者View的外部四周**
public void showAsDropDown(View anchor) public void showAsDropDown(View anchor, int xoff, int yoff) public void showAsDropDown(View anchor, int xoff, int yoff, int gravity)
带Gravity参数的方法是API 19新引入的。
这里的xoff与yoff是对应view的坐标偏移量,对应的初始坐标位置是view的左下角.
请注意!在实际使用showAsDropDown()方法的时候,如果只使用showAsDropDown(View anchor, int xoff, int yoff),这个形参会出 现在一些品牌的机型上出现一些问题。原因是有些机型初始坐标其实不一定在左下角,而是在左上角。所以,你这个时候设置yoff值就 会出现2种不同去情况。怎么解决这个问题呢? 就是尽量使用showAsDropDown(View anchor, int xoff, int yoff, int gravity),这个形 参主动设置第4个int gravity的值,来确定初始坐标的位置。
这里我们用一个demo演示一下,假设我现在需要把显示位置移动到目标控件的右上角就需要如下代码:
popupWindow.showAsDropDown(mTestButton,mTestButton.getWidth(),-mTestButton.getHeight())
设置PopupWindow叠放效果
setOverlapAnchor(true);
当然你把PopupWindow的位置设置到可以完全覆盖你指定位置显示PopupWindow的view时,如果设置这个方法为true,那么你无论如何都无法覆盖这个view始终会让这个view漏出一小部分,如效果图所示:
设置PopupWindow可触摸
setTouchable(true);
设置false后,将会阻止PopupWindow窗口里的所有点击事件
设置PopupWindow监听拦截指定触摸事件
popupWindow.setTouchInterceptor(new View.OnTouchListener() {@Overridepublic boolean onTouch(View v, MotionEvent event) { //如果这里设置返回true,说明你会消耗这个触摸事件,不会向下传递到内容view里return false;}});
123456
设置PopupWindow覆盖状态栏或者超过屏幕尺寸
允许弹出窗口扩展到屏幕范围之外。默认情况下,窗口被裁剪到屏幕边界。将其设置为false将允许精确定位窗口
popupWindow.setClippingEnabled(false);
设置PopupWindow监听取消事件
popupWindow.setOnDismissListener(new PopupWindow.OnDismissListener() {@Overridepublic void onDismiss() {
}});
设置PopWindow遮罩层
WindowManager.LayoutParams lp = getWindow().getAttributes();lp.alpha = 0.5f;getWindow().setAttributes(lp);pop.setOnDismissListener(new PopupWindow.OnDismissListener() {
@Overridepublic void onDismiss() {WindowManager.LayoutParams lp = getWindow().getAttributes();lp.alpha = 1f;getWindow().setAttributes(lp);}});
android基础 [超级详细android常用控件解析(ScollView控件,ProgressBar进度条,PopupWindow控件)]相关推荐
- android基础 [超级详细android Activity组件解析(Activity综述,Activity生命周期,Activity启动--携带参数启动)]
1 章节目录 2 Android Activity综述 2.1 Activity怎么用 2.2 layout - 界面布局 2.3 Java - 控制界面 2.4 AndroidManifest.xm ...
- 【android】超级详细Android Studio下载安装教程(附:JDK1.8安装教程)
文章目录 一.官网下载 二.安装 三.配置 安装Android的前提是下载安装JDK,如果没有安装JDK,请参照如下步骤安装JDK: JDK_1.8的下载安装和环境变量的配置[详细步骤] 一.官网下载 ...
- Android Studio超级详细安装教程(AMD)
Android Studio超级详细安装教程(AMD) !!!必看!!! 本教程适合CPU为AMD的计算机使用,如果你的CPU为intel/英特尔请移步至Android Studio超级详细安装教程( ...
- ProgressBar(进度条)-常用属性讲解与基础实例
本节给大家带来的是Android基本UI控件中的ProgressBar(进度条),ProgressBar的应用场景很多,比如用户登录时,后台在发请求,以及等待服务器返回信息,这个时候会用到进度条:或者 ...
- android ProgressBar 进度条demo
ProgressBar Demo 进度条没有什么好讲解的,就是几个方法,熟悉了就ok.直接上代码. activity_main.xml <?xml version="1.0" ...
- Android学习笔记之progressBar(进度条)
一.说明 <1>在某项延续性工作的进展过程中为了不让用户觉得程序死掉了,需要有个活动的进度条,表示此过程正在进行中. <2>在某些操作的进度中的可视指示器,为用户呈现操作的进度 ...
- android 自定义背景园,Android 自定义ProgressBar 进度条颜色和背景颜色
Android 自定义ProgressBar 进度条颜色和背景颜色 首先,在drawable目录下新建文件 personal_center_level_progress_bg.xmlandroid a ...
- android 自定义 进度条 旋转,Android_Android ProgressBar进度条使用详解,ProgressBar进度条,分为旋转进 - phpStudy...
Android ProgressBar进度条使用详解 ProgressBar进度条,分为旋转进度条和水平进度条,进度条的样式根据需要自定义,之前一直不明白进度条如何在实际项目中使用,网上演示进度条的案 ...
- android圆形点击效果,Android 三种方式实现自定义圆形页面加载中效果的进度条
[实例简介] Android 三种方式实现自定义圆形页面加载中效果的进度条 [实例截图] [核心代码] ad376a86-a9aa-49bc-8cea-321bcff2c0c3 └── AnimRou ...
最新文章
- 170222、使用Spring Session和Redis解决分布式Session跨域共享问题
- ASP.NET3.5 企业级项目开发 -- 第二章(续) 数据访问层(DAL)的开发解决方案提出...
- Identity Server 4 原理和实战(完结)_建立Identity Server 4项目,Client Credentials 授权实例...
- ITK:将ITK灰度图像转换为CV :: Mat
- 零基础 Amazon Web Services (AWS) 入门教程图文版(二)
- 一个月 200 题,命中 80%,拿下 BAT,我独特的高效刷题法
- 计算机的cpu怎么设计出来的,CPU是如何制作出来的?cpu的制造流程介绍
- VS错误之error LNK2019: 无法解析的外部符号
- python——zip()、map()、enumerate()、filter()、apply函数
- 按键精灵通过句柄获取窗口坐标_按键精灵 句柄 获得句柄 控制windows窗口 后台...
- imx6ull调试sx1268 lora调试记录
- 笔记——衡量回归算法的标准最好的评价指标R Square
- yarn 错误There appears to be trouble with your network connection. Retrying
- 祝贺 弓叶科技总经理莫卓亚荣获“松山湖奋斗之星”
- 语音识别(ASR)论文优选:关注语音识别系统Fairness问题Towards Measuring Fairness in Speech Recognition
- 产品狗的Python之路(2):excel表格拆分桌面小程序
- html实现简易音乐播放器
- 教育网校搭建哪个好?
- P5017 [NOIP2018 普及组] 摆渡车(pj组最后一道蓝) P1027 [NOIP2001 提高组] Car 的旅行路线(提高组第一道蓝)
- Android 自定义桌面(一)