java.lang.Object | ||
↳ | android.view.View | |
↳ | android.widget.ImageView |
![]() |
![]() |
Displays an arbitrary image, such as an icon. The ImageView class can load images from various sources (such as resources or content providers), takes care of computing its measurement from the image so that it can be used in any layout manager, and provides various display options such as scaling and tinting.
Nested Classes | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
|
ImageView.ScaleType | Options for scaling the bounds of an image to the bounds of this view. |
XML Attributes | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
|
|
|
|||||||||
android:adjustViewBounds | setAdjustViewBounds(boolean) | Set this to true if you want the ImageView to adjust its bounds to preserve the aspect ratio of its drawable. | |||||||||
android:baseline | setBaseline(int) | The offset of the baseline within this view. | |||||||||
android:baselineAlignBottom | setBaselineAlignBottom(boolean) | If true, the image view will be baseline aligned with based on its bottom edge. | |||||||||
android:cropToPadding | setCropToPadding(boolean) | If true, the image will be cropped to fit within its padding. | |||||||||
android:maxHeight | setMaxHeight(int) | An optional argument to supply a maximum height for this view. | |||||||||
android:maxWidth | setMaxWidth(int) | An optional argument to supply a maximum width for this view. | |||||||||
android:scaleType | setScaleType(ImageView.ScaleType) | Controls how the image should be resized or moved to match the size of this ImageView. | |||||||||
android:src | setImageResource(int) | Sets a drawable as the content of this ImageView. | |||||||||
android:tint | setColorFilter(int,PorterDuff.Mode) | Set a tinting color for the image. |
[Expand]
Inherited XML Attributes
|
|||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
![]() |
[Expand]
Inherited Constants
|
|||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
![]() |
[Expand]
Inherited Fields
|
|||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
![]() |
Public Constructors | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
|
|
||||||||||
|
|
||||||||||
|
|
Public Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
|
|
|
|||||||||
|
|
True when ImageView is adjusting its bounds to preserve the aspect ratio of its drawable
|
|||||||||
|
|
Return the offset of the widget's text baseline from the widget's top boundary. |
|||||||||
|
|
Return whether this view's baseline will be considered the bottom of the view.
|
|||||||||
|
|
Returns the active color filter for this ImageView.
|
|||||||||
|
|
Return whether this ImageView crops to padding.
|
|||||||||
|
|
Return the view's drawable, or null if no drawable has been assigned.
|
|||||||||
|
|
Returns the alpha that will be applied to the drawable of this ImageView.
|
|||||||||
|
|
Return the view's optional matrix.
|
|||||||||
|
|
The maximum height of this view.
|
|||||||||
|
|
The maximum width of this view.
|
|||||||||
|
|
Return the current scale type in use by this ImageView.
|
|||||||||
|
|
Returns whether this View has content which overlaps.
|
|||||||||
|
|
Invalidates the specified Drawable.
|
|||||||||
|
|
Call
Drawable.jumpToCurrentState() on all Drawable objects associated with this view.
|
|||||||||
|
|
Generate the new
Drawable state for this view.
|
|||||||||
|
|
Initializes an
AccessibilityEvent with information about this View which is the event source.
|
|||||||||
|
|
Initializes an
AccessibilityNodeInfo with information about this view.
|
|||||||||
|
|
Called from
dispatchPopulateAccessibilityEvent(AccessibilityEvent) giving a chance to this View to populate the accessibility event with its text content.
|
|||||||||
|
|
Set this to true if you want the ImageView to adjust its bounds to preserve the aspect ratio of its drawable.
|
|||||||||
|
|
This method was deprecated in API level 16. use #setImageAlpha(int) instead
|
|||||||||
|
|
Set the offset of the widget's text baseline from the widget's top boundary. |
|||||||||
|
|
Set whether to set the baseline of this view to the bottom of the view.
|
|||||||||
|
|
Set a tinting option for the image.
|
|||||||||
|
|
Apply an arbitrary colorfilter to the image.
|
|||||||||
|
|
Set a tinting option for the image.
|
|||||||||
|
|
Sets whether this ImageView will crop to padding.
|
|||||||||
|
|
Sets the alpha value that should be applied to the image.
|
|||||||||
|
|
Sets a Bitmap as the content of this ImageView.
|
|||||||||
|
|
Sets a drawable as the content of this ImageView.
|
|||||||||
|
|
Sets the image level, when it is constructed from a
LevelListDrawable .
|
|||||||||
|
|
|
|||||||||
|
|
Sets a drawable as the content of this ImageView.
|
|||||||||
|
|
|
|||||||||
|
|
Sets the content of this ImageView to the specified Uri.
|
|||||||||
|
|
An optional argument to supply a maximum height for this view.
|
|||||||||
|
|
An optional argument to supply a maximum width for this view.
|
|||||||||
|
|
Controls how the image should be resized or moved to match the size of this ImageView.
|
|||||||||
|
|
Changes the selection state of this view.
|
|||||||||
|
|
Set the enabled state of this view.
|
Protected Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
|
This function is called whenever the state of the view changes in such a way that it impacts the state of drawables being shown.
|
||||||||||
|
This is called when the view is attached to a window.
|
||||||||||
|
This is called when the view is detached from a window.
|
||||||||||
|
Implement this to do your drawing.
|
||||||||||
|
Measure the view and its content to determine the measured width and the measured height. |
||||||||||
|
Assign a size and position to this view.
|
||||||||||
|
If your view subclass is displaying its own Drawable objects, it should override this function and return true for any Drawable it is displaying.
|
[Expand]
Inherited Methods
|
|||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
![]() |
|||||||||||
![]() |
|||||||||||
![]() |
|||||||||||
![]() |
|||||||||||
![]() |
Set this to true if you want the ImageView to adjust its bounds to preserve the aspect ratio of its drawable.
Must be a boolean value, either "true
" or "false
".
This may also be a reference to a resource (in the form "@[package:]type:name
") or theme attribute (in the form "?[package:][type:]name
") containing a value of this type.
This corresponds to the global attribute resource symbol adjustViewBounds
.
The offset of the baseline within this view. See {see android.view.View#getBaseline} for details
Must be a dimension value, which is a floating point number appended with a unit such as "14.5sp
". Available units are: px (pixels), dp (density-independent pixels), sp (scaled pixels based on preferred font size), in (inches), mm (millimeters).
This may also be a reference to a resource (in the form "@[package:]type:name
") or theme attribute (in the form "?[package:][type:]name
") containing a value of this type.
This corresponds to the global attribute resource symbol baseline
.
If true, the image view will be baseline aligned with based on its bottom edge.
Must be a boolean value, either "true
" or "false
".
This may also be a reference to a resource (in the form "@[package:]type:name
") or theme attribute (in the form "?[package:][type:]name
") containing a value of this type.
This corresponds to the global attribute resource symbol baselineAlignBottom
.
If true, the image will be cropped to fit within its padding.
Must be a boolean value, either "true
" or "false
".
This may also be a reference to a resource (in the form "@[package:]type:name
") or theme attribute (in the form "?[package:][type:]name
") containing a value of this type.
This corresponds to the global attribute resource symbol cropToPadding
.
An optional argument to supply a maximum height for this view. See {see android.widget.ImageView#setMaxHeight} for details.
Must be a dimension value, which is a floating point number appended with a unit such as "14.5sp
". Available units are: px (pixels), dp (density-independent pixels), sp (scaled pixels based on preferred font size), in (inches), mm (millimeters).
This may also be a reference to a resource (in the form "@[package:]type:name
") or theme attribute (in the form "?[package:][type:]name
") containing a value of this type.
This corresponds to the global attribute resource symbol maxHeight
.
An optional argument to supply a maximum width for this view. See {see android.widget.ImageView#setMaxWidth} for details.
Must be a dimension value, which is a floating point number appended with a unit such as "14.5sp
". Available units are: px (pixels), dp (density-independent pixels), sp (scaled pixels based on preferred font size), in (inches), mm (millimeters).
This may also be a reference to a resource (in the form "@[package:]type:name
") or theme attribute (in the form "?[package:][type:]name
") containing a value of this type.
This corresponds to the global attribute resource symbol maxWidth
.
Controls how the image should be resized or moved to match the size of this ImageView.
Must be one of the following constant values.
Constant | Value | Description |
---|---|---|
matrix |
0 | |
fitXY |
1 | |
fitStart |
2 | |
fitCenter |
3 | |
fitEnd |
4 | |
center |
5 | |
centerCrop |
6 | |
centerInside |
7 |
This corresponds to the global attribute resource symbol scaleType
.
Sets a drawable as the content of this ImageView.
May be a reference to another resource, in the form "@[+][package:]type:name
" or to a theme attribute in the form "?[package:][type:]name
".
May be a color value, in the form of "#rgb
", "#argb
", "#rrggbb
", or "#aarrggbb
".
This corresponds to the global attribute resource symbol src
.
Set a tinting color for the image.
Must be a color value, in the form of "#rgb
", "#argb
", "#rrggbb
", or "#aarrggbb
".
This may also be a reference to a resource (in the form "@[package:]type:name
") or theme attribute (in the form "?[package:][type:]name
") containing a value of this type.
This corresponds to the global attribute resource symbol tint
.
True when ImageView is adjusting its bounds to preserve the aspect ratio of its drawable
Return the offset of the widget's text baseline from the widget's top boundary.
Return whether this view's baseline will be considered the bottom of the view.
Returns the active color filter for this ImageView.
Return whether this ImageView crops to padding.
Return the view's drawable, or null if no drawable has been assigned.
Returns the alpha that will be applied to the drawable of this ImageView.
Return the view's optional matrix. This is applied to the view's drawable when it is drawn. If there is not matrix, this method will return null. Do not change this matrix in place. If you want a different matrix applied to the drawable, be sure to call setImageMatrix().
The maximum height of this view.
The maximum width of this view.
Return the current scale type in use by this ImageView.
Returns whether this View has content which overlaps. This function, intended to be overridden by specific View types, is an optimization when alpha is set on a view. If rendering overlaps in a view with alpha < 1, that view is drawn to an offscreen buffer and then composited it into place, which can be expensive. If the view has no overlapping rendering, the view can draw each primitive with the appropriate alpha value directly. An example of overlapping rendering is a TextView with a background image, such as a Button. An example of non-overlapping rendering is a TextView with no background, or an ImageView with only the foreground image. The default implementation returns true; subclasses should override if they have cases which can be optimized.
Invalidates the specified Drawable.
dr | the drawable to invalidate |
---|
Call Drawable.jumpToCurrentState()
on all Drawable objects associated with this view.
Generate the new Drawable
state for this view. This is called by the view system when the cached Drawable state is determined to be invalid. To retrieve the current state, you should use getDrawableState()
.
extraSpace | if non-zero, this is the number of extra entries you would like in the returned array in which you can place your own states. |
---|
Drawable
state of the view.Initializes an AccessibilityEvent
with information about this View which is the event source. In other words, the source of an accessibility event is the view whose state change triggered firing the event.
Example: Setting the password property of an event in addition to properties set by the super implementation:
public void onInitializeAccessibilityEvent(AccessibilityEvent event) { super.onInitializeAccessibilityEvent(event); event.setPassword(true); }
If an View.AccessibilityDelegate
has been specified via calling setAccessibilityDelegate(AccessibilityDelegate)
its onInitializeAccessibilityEvent(View, AccessibilityEvent)
is responsible for handling this call.
Note: Always call the super implementation before adding information to the event, in case the default implementation has basic information to add.
event | The event to initialize. |
---|
Initializes an AccessibilityNodeInfo
with information about this view. The base implementation sets:
setParent(View)
,setBoundsInParent(Rect)
,setBoundsInScreen(Rect)
,setPackageName(CharSequence)
,setClassName(CharSequence)
,setContentDescription(CharSequence)
,setEnabled(boolean)
,setClickable(boolean)
,setFocusable(boolean)
,setFocused(boolean)
,setLongClickable(boolean)
,setSelected(boolean)
,Subclasses should override this method, call the super implementation, and set additional attributes.
If an View.AccessibilityDelegate
has been specified via calling setAccessibilityDelegate(AccessibilityDelegate)
its onInitializeAccessibilityNodeInfo(View, AccessibilityNodeInfo)
is responsible for handling this call.
info | The instance to initialize. |
---|
Called from dispatchPopulateAccessibilityEvent(AccessibilityEvent)
giving a chance to this View to populate the accessibility event with its text content. While this method is free to modify event attributes other than text content, doing so should normally be performed in onInitializeAccessibilityEvent(AccessibilityEvent)
.
Example: Adding formatted date string to an accessibility event in addition to the text added by the super implementation:
public void onPopulateAccessibilityEvent(AccessibilityEvent event) { super.onPopulateAccessibilityEvent(event); final int flags = DateUtils.FORMAT_SHOW_DATE | DateUtils.FORMAT_SHOW_WEEKDAY; String selectedDateUtterance = DateUtils.formatDateTime(mContext, mCurrentDate.getTimeInMillis(), flags); event.getText().add(selectedDateUtterance); }
If an View.AccessibilityDelegate
has been specified via calling setAccessibilityDelegate(AccessibilityDelegate)
its onPopulateAccessibilityEvent(View, AccessibilityEvent)
is responsible for handling this call.
Note: Always call the super implementation before adding information to the event, in case the default implementation has basic information to add.
event | The accessibility event which to populate. |
---|
Set this to true if you want the ImageView to adjust its bounds to preserve the aspect ratio of its drawable.
adjustViewBounds | Whether to adjust the bounds of this view to presrve the original aspect ratio of the drawable |
---|
This method was deprecated in API level 16.
use #setImageAlpha(int) instead
Sets the alpha value that should be applied to the image.
alpha | the alpha value that should be applied to the image |
---|
Set the offset of the widget's text baseline from the widget's top boundary. This value is overridden by the setBaselineAlignBottom(boolean)
property.
baseline | The baseline to use, or -1 if none is to be provided. |
---|
Set whether to set the baseline of this view to the bottom of the view. Setting this value overrides any calls to setBaseline.
aligned | If true, the image view will be baseline aligned with based on its bottom edge. |
---|
Set a tinting option for the image. Assumes SRC_ATOP
blending mode.
color | Color tint to apply. |
---|
Apply an arbitrary colorfilter to the image.
cf | the colorfilter to apply (may be null) |
---|
Set a tinting option for the image.
color | Color tint to apply. |
---|---|
mode | How to apply the color. The standard mode is SRC_ATOP |
Sets whether this ImageView will crop to padding.
cropToPadding | whether this ImageView will crop to padding |
---|
Sets the alpha value that should be applied to the image.
alpha | the alpha value that should be applied to the image |
---|
Sets a Bitmap as the content of this ImageView.
bm | The bitmap to set |
---|
Sets a drawable as the content of this ImageView.
drawable | The drawable to set |
---|
Sets the image level, when it is constructed from a LevelListDrawable
.
level | The new level for the image. |
---|
Sets a drawable as the content of this ImageView.
This does Bitmap reading and decoding on the UI thread, which can cause a latency hiccup. If that's a concern, consider using setImageDrawable(android.graphics.drawable.Drawable)
or setImageBitmap(android.graphics.Bitmap)
and BitmapFactory
instead.
resId | the resource identifier of the the drawable |
---|
Sets the content of this ImageView to the specified Uri.
This does Bitmap reading and decoding on the UI thread, which can cause a latency hiccup. If that's a concern, consider using setImageDrawable(android.graphics.drawable.Drawable)
or setImageBitmap(android.graphics.Bitmap)
and BitmapFactory
instead.
uri | The Uri of an image |
---|
An optional argument to supply a maximum height for this view. Only valid if setAdjustViewBounds(boolean)
has been set to true. To set an image to be a maximum of 100 x 100 while preserving the original aspect ratio, do the following: 1) set adjustViewBounds to true 2) set maxWidth and maxHeight to 100 3) set the height and width layout params to WRAP_CONTENT.
Note that this view could be still smaller than 100 x 100 using this approach if the original image is small. To set an image to a fixed size, specify that size in the layout params and then use setScaleType(android.widget.ImageView.ScaleType)
to determine how to fit the image within the bounds.
maxHeight | maximum height for this view |
---|
An optional argument to supply a maximum width for this view. Only valid if setAdjustViewBounds(boolean)
has been set to true. To set an image to be a maximum of 100 x 100 while preserving the original aspect ratio, do the following: 1) set adjustViewBounds to true 2) set maxWidth and maxHeight to 100 3) set the height and width layout params to WRAP_CONTENT.
Note that this view could be still smaller than 100 x 100 using this approach if the original image is small. To set an image to a fixed size, specify that size in the layout params and then use setScaleType(android.widget.ImageView.ScaleType)
to determine how to fit the image within the bounds.
maxWidth | maximum width for this view |
---|
Controls how the image should be resized or moved to match the size of this ImageView.
scaleType | The desired scaling mode. |
---|
Changes the selection state of this view. A view can be selected or not. Note that selection is not the same as focus. Views are typically selected in the context of an AdapterView like ListView or GridView; the selected view is the view that is highlighted.
selected | true if the view must be selected, false otherwise |
---|
This function is called whenever the state of the view changes in such a way that it impacts the state of drawables being shown.
Be sure to call through to the superclass when overriding this function.
This is called when the view is attached to a window. At this point it has a Surface and will start drawing. Note that this function is guaranteed to be called before onDraw(android.graphics.Canvas)
, however it may be called any time before the first onDraw -- including before or after onMeasure(int, int)
.
This is called when the view is detached from a window. At this point it no longer has a surface for drawing.
Implement this to do your drawing.
canvas | the canvas on which the background will be drawn |
---|
Measure the view and its content to determine the measured width and the measured height. This method is invoked by measure(int, int)
and should be overriden by subclasses to provide accurate and efficient measurement of their contents.
CONTRACT: When overriding this method, you must call setMeasuredDimension(int, int)
to store the measured width and height of this view. Failure to do so will trigger an IllegalStateException
, thrown by measure(int, int)
. Calling the superclass' onMeasure(int, int)
is a valid use.
The base class implementation of measure defaults to the background size, unless a larger size is allowed by the MeasureSpec. Subclasses should override onMeasure(int, int)
to provide better measurements of their content.
If this method is overridden, it is the subclass's responsibility to make sure the measured height and width are at least the view's minimum height and width (getSuggestedMinimumHeight()
and getSuggestedMinimumWidth()
).
widthMeasureSpec | horizontal space requirements as imposed by the parent. The requirements are encoded with View.MeasureSpec . |
---|---|
heightMeasureSpec | vertical space requirements as imposed by the parent. The requirements are encoded with View.MeasureSpec . |
Assign a size and position to this view. This is called from layout.
l | Left position, relative to parent |
---|---|
t | Top position, relative to parent |
r | Right position, relative to parent |
b | Bottom position, relative to parent |
If your view subclass is displaying its own Drawable objects, it should override this function and return true for any Drawable it is displaying. This allows animations for those drawables to be scheduled.
Be sure to call through to the super class when overriding this function.
dr | The Drawable to verify. Return true if it is one you are displaying, else return the result of calling through to the super class. |
---|