|  | /* | 
|  | * Copyright (C) 2006 The Android Open Source Project | 
|  | * | 
|  | * Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | * you may not use this file except in compliance with the License. | 
|  | * You may obtain a copy of the License at | 
|  | * | 
|  | *      http://www.apache.org/licenses/LICENSE-2.0 | 
|  | * | 
|  | * Unless required by applicable law or agreed to in writing, software | 
|  | * distributed under the License is distributed on an "AS IS" BASIS, | 
|  | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | * See the License for the specific language governing permissions and | 
|  | * limitations under the License. | 
|  | */ | 
|  |  | 
|  | package android.widget; | 
|  |  | 
|  | import android.annotation.DrawableRes; | 
|  | import android.content.Context; | 
|  | import android.graphics.drawable.Drawable; | 
|  | import android.net.Uri; | 
|  | import android.util.AttributeSet; | 
|  |  | 
|  | /** | 
|  | * {@link ViewSwitcher} that switches between two ImageViews when a new | 
|  | * image is set on it. The views added to an ImageSwitcher must all be | 
|  | * {@link ImageView ImageViews}. | 
|  | */ | 
|  | public class ImageSwitcher extends ViewSwitcher | 
|  | { | 
|  | /** | 
|  | * Creates a new empty ImageSwitcher. | 
|  | * | 
|  | * @param context the application's environment | 
|  | */ | 
|  | public ImageSwitcher(Context context) | 
|  | { | 
|  | super(context); | 
|  | } | 
|  |  | 
|  | /** | 
|  | * Creates a new empty ImageSwitcher for the given context and with the | 
|  | * specified set attributes. | 
|  | * | 
|  | * @param context the application environment | 
|  | * @param attrs a collection of attributes | 
|  | */ | 
|  | public ImageSwitcher(Context context, AttributeSet attrs) { | 
|  | super(context, attrs); | 
|  | } | 
|  |  | 
|  | /** | 
|  | * Sets a new image on the ImageSwitcher with the given resource id. | 
|  | * This will set that image resource on the next ImageView in the switcher and will | 
|  | * then switch to that view. | 
|  | * | 
|  | * @param resid a Drawable resource id | 
|  | * | 
|  | * @see ImageView#setImageResource(int) | 
|  | */ | 
|  | public void setImageResource(@DrawableRes int resid) | 
|  | { | 
|  | ImageView image = (ImageView)this.getNextView(); | 
|  | image.setImageResource(resid); | 
|  | showNext(); | 
|  | } | 
|  |  | 
|  | /** | 
|  | * Sets a new image on the ImageSwitcher with the given Uri. | 
|  | * This will set that image on the next ImageView in the switcher and will | 
|  | * then switch to that view. | 
|  | * | 
|  | * @param uri the Uri of an image | 
|  | * | 
|  | * @see ImageView#setImageURI(Uri) | 
|  | */ | 
|  | public void setImageURI(Uri uri) | 
|  | { | 
|  | ImageView image = (ImageView)this.getNextView(); | 
|  | image.setImageURI(uri); | 
|  | showNext(); | 
|  | } | 
|  |  | 
|  | /** | 
|  | * Sets a new drawable on the ImageSwitcher. | 
|  | * This will set that drawable on the next ImageView in the switcher and will | 
|  | * then switch to that view. | 
|  | * | 
|  | * @param drawable the drawable to be set or {@code null} to clear the content | 
|  | * | 
|  | * @see ImageView#setImageDrawable(Drawable) | 
|  | */ | 
|  | public void setImageDrawable(Drawable drawable) | 
|  | { | 
|  | ImageView image = (ImageView)this.getNextView(); | 
|  | image.setImageDrawable(drawable); | 
|  | showNext(); | 
|  | } | 
|  |  | 
|  | @Override | 
|  | public CharSequence getAccessibilityClassName() { | 
|  | return ImageSwitcher.class.getName(); | 
|  | } | 
|  | } |