安卓开发imageview是什么控件
‘壹’ 在android中按钮共分为几种
在Android开发中,View控件被广泛应用于各种界面设计,根据其功能和用途,可以将它们分为多种类型。其中,文本类控件包括TextView、EditText、AutoCompleteTextView、MultAutoCompletTextView、TextSwitcher、DigitalClock、ExtractEditText、CheckedTextView和Chronometer,这些控件主要用于显示或编辑文本信息。
按钮类控件包括Button、CheckBox、RadioButton(RadioGroup)、ToggleButton和ImageButton,它们主要用于用户交互,实现按钮点击、复选框选择、单选按钮选择等功能。
缩放按钮主要指ZoomButton和ZoomControls,用于实现缩放功能。
图片类控件则包括ImageView、ZoomButton、ImageButton和ImageSwitcher,它们用于显示图像资源,可以进行放大、缩小等操作。
时间控件如DigitalClock、AnalogClock、TimePicker和DatePicker,用于显示和选择时间或日期。
进度显示控件包括ProgressBar、AbsSeekBar、SeekBar和RatingBar,它们用于显示进度条或评分。
导航控件如TabHost和TabWidget,用于实现标签页导航。
视频媒体控件包括VideView和MediaController,用于播放视频内容。
Dialog对话框包括CharacherPickerDialog、AlertDialog、DatePickerDialog、ProgressDialog和TimePickerDialog,它们用于弹出对话框,提供选择、输入等功能。
布局类控件包括AbsoluteLayout、LinearLayout、RadioGroup、TableLayout、TableRow、RelativeLayout和FrameLayout,用于实现复杂的界面布局。
需要适配器的布局类控件包括AdapterView、AbsListView、GridView、ListView、AbsSpinner和Gallery,它们用于显示列表或网格数据。
滚动条控件包括HorizontalScrollView和ScrollView,用于实现垂直或水平滚动功能。
网页显示控件为WebView,用于显示网页内容。
动画类控件包括ViewAnimator、ViewFilpper、ViewSwitcher、ImageSwitcher和TextSwitcher,用于实现界面动画效果。
‘贰’ android常用控件有哪些
Android常用控件有:
1. Button
2. TextView
3. EditText
4. ImageView
5. ListView
6. RecyclerView
7. ScrollView
8. ProgressBar
9. WebView等。
以下是部分控件的详细解释:
Button:用于触发事件或操作的控件,用户可以通过点击按钮来执行特定的动作或功能。在Android开发中,按钮是最常用的控件之一。
TextView:用于显示文本信息,可以显示静态文本或动态数据。在界面上展示文字信息时,TextView是最常用的控件之一。
EditText:允许用户输入或编辑文本信息。常用于表单、登录界面等需要用户输入数据的地方。
ImageView:用于显示图像或视频。通过此控件,开发者可以轻松地将图像显示在应用程序的界面上。此外,还可以通过该控件显示图片序列,形成简单的动画效果。
‘叁’ Android 圆角、圆形 ImageView 实现
我们要实现的图片控件继承自 AppCompatImageView ,它是 ImageView 的子类,但提供了更好的兼容性,我们在此基础上添加了若干自定义的属性和方法以实现最终的 NiceImageView :
要实圆角或者圆形的显示效果,就是对图片显示的内容区域进行“裁剪”,只显示指定的区域即可。如何做呢?
一种比较直接的办法是这样的,由于图片是被绘制在画布上的,所以用 canvas 的 clipPath() 方法先将画布裁剪成指定形状,这样就能让图片按指定形状显示了,重新 draw() 方法即可:
这样使用 src 、 background 属性给ImageView设置显示的图片都能达到预期的显示效果。但是由于 clipPath() 方法不支持抗锯齿,图片边缘会有明显的毛糙感,体验并不理想,所以需要寻找其它方法。
另一种方法是使用图像的 Alpha 合成模式 ,即
PorterDuff 来实现, 官方文档 。这里我们使用其中的 DST_IN 模式。整个过程就是先绘制目标图像,也就是图片;再绘制原图像,即一个圆角矩形或者圆形,这样最终目标图像只显示和原图像重合的区域。
到这里就实现了显示为圆角或者圆形了。但是需要通过 src 属性或者对应的方法来设置图片,否则不能达到预期效果。
绘制边框就相对容易理解了,只需要绘制一个指定样式的圆角矩形或者圆形即可:
当图片显示为圆形时,还可以绘制一个内边框,但圆角矩形的话由于圆角大小的问题,目前只能设置一个边框咯。
但是有个问题,绘制的边框会覆盖在图片上,如果边框太宽会导致图片的可见区域变小了,影像显示效果,像这样,左下角的花盆不见了:
那么如何让边框不覆盖在图片上呢?可以在 Alpha 合成绘制前先将画布缩小一定比例,最后再绘制边框,这样问题就解决了。
缩放后的ImageView显示区域的宽高就是原宽、高分别减去2倍的边框宽度,这样缩小的比例也就显而易见了。效果如下,左下角的花盆出来了:
遮罩可以理解为一层带透明度的颜色,遮罩默认不绘制,当制定了遮罩颜色时才会绘制,实现很简单:
例如加一个透明度30%的红色遮罩后的效果:
核心的实现逻辑就这些了,剩下的就是自定义属性和方法了,有兴趣的可以看源码,都很简单,希望对你有所帮助吧!
更多细节及用法见GitHub: https://github.com/SheHuan/NiceImageView
如果你需要实现类似钉钉的圆形组合头像,例如: