android java切换图片_Android图片切换

有时候,不希望图片突然出现在屏幕上,而要应用某种形式的动画显示图片时,从一个图像转换到另一个。这是在Android中支持的ImageSwitcher

图像切换器允许通过它们出现在屏幕上的方式上的图像添加一些过渡。为了使用图像切换,需要先定义它的XML组件。它的语法如下:

现在创建ImageSwitcher的Java实例,并得到这个XML组件的引用。它的语法如下:

privateImageSwitcherimageSwitcher;imageSwitcher=(ImageSwitcher)findViewById(R.id.imageSwitcher1);

我们需要做的下一件事是实现的ViewFactory接口,并实现返回一个ImageView的未实现的方法。它的语法如下:

imageSwitcher.setImageResource(R.drawable.ic_launcher);imageSwitcher.setFactory(newViewFactory(){publicViewmakeView(){ImageViewmyView=newImageView(getApplicationContext());returnmyView;}}

需要做的最后一件事是添加动画到ImageSwitcher。需要通过调用AnimationUtilities类的对象一个静态方法loadAnimation定义动画类。它的语法如下:

Animationin=AnimationUtils.loadAnimation(this,android.R.anim.slide_in_left);imageSwitcher.setInAnimation(in);imageSwitcher.setOutAnimation(out);

setInAnimaton设置对象的外观的动画在画面上,而setOutAnimation则正好是相反的方法。该loadAnimation()方法创建一个动画对象。

除了这些方法,也有在ImageSwitcher类中定义的其他方法。它们被定义如下:

Sr.No

Method & description

1

setImageDrawable(Drawable drawable)

设置使用图像切换图像。图像以位图的形式被传递

2

setImageResource(int resid)

设置使用图像切换图像。图像被传递整数标识符的形式

3

setImageURI(Uri uri)

设置使用图像切换图像。该图像是通过URI的形式

4

ImageSwitcher(Context context, AttributeSet attrs)

返回图像切换对象已经设置一些属性的方法传递

5

onInitializeAccessibilityEvent (AccessibilityEvent event)

初始化一个AccessibilityEvent与此有关查看信息是事件源

6

onInitializeAccessibilityNodeInfo (AccessibilityNodeInfo info)

初始化一个AccessibilityNodeInfo提供有关该视图的信息

例子

下面的例子演示了一些对位图图像转换器的效果。它创建了一个基本的应用程序,它允许查看的影像的动画效果。

为了试验这个例子,需要在实际设备上运行此程序。

Steps

描述

1

使用Android Studio创建Android应用程序,并将其命名为ImageSwitcher。在创建这个项目时确保目标SDK编译在Android SDK的最新版本或使用更高级别的API

2

修改src/MainActivity.java 文件中添加必要的代码

3

修改res/layout/activity_main添加相应的XML组件

4

运行应用程序并选择运行Android的设备,并在其上安装的应用和验证结果

以下是修改主活动文件的内容 src/com.yiibai.imageswithcer/MainActivity.java.

packagecom.example.imageswitcher;importandroid.app.ActionBar.LayoutParams;importandroid.app.Activity;importandroid.os.Bundle;importandroid.view.Menu;importandroid.view.View;importandroid.view.animation.Animation;importandroid.view.animation.AnimationUtils;importandroid.widget.ImageButton;importandroid.widget.ImageSwitcher;importandroid.widget.ImageView;importandroid.widget.Toast;importandroid.widget.ViewSwitcher.ViewFactory;publicclassMainActivityextendsActivity{privateImageButtonimg;privateImageSwitcherimageSwitcher;@OverrideprotectedvoidonCreate(BundlesavedInstanceState){super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);img=(ImageButton)findViewById(R.id.imageButton1);imageSwitcher=(ImageSwitcher)findViewById(R.id.imageSwitcher1);imageSwitcher.setFactory(newViewFactory(){@OverridepublicViewmakeView(){ImageViewmyView=newImageView(getApplicationContext());myView.setScaleType(ImageView.ScaleType.FIT_CENTER);myView.setLayoutParams(newImageSwitcher.LayoutParams(LayoutParams.FILL_PARENT,LayoutParams.FILL_PARENT));returnmyView;}});}publicvoidnext(Viewview){Toast.makeText(getApplicationContext(),"Next Image",Toast.LENGTH_LONG).show();Animationin=AnimationUtils.loadAnimation(this,android.R.anim.slide_in_left);Animationout=AnimationUtils.loadAnimation(this,android.R.anim.slide_out_right);imageSwitcher.setInAnimation(in);imageSwitcher.setOutAnimation(out);imageSwitcher.setImageResource(R.drawable.ic_launcher);}publicvoidprevious(Viewview){Toast.makeText(getApplicationContext(),"previous Image",Toast.LENGTH_LONG).show();Animationin=AnimationUtils.loadAnimation(this,android.R.anim.slide_out_right);Animationout=AnimationUtils.loadAnimation(this,android.R.anim.slide_in_left);imageSwitcher.setInAnimation(out);imageSwitcher.setOutAnimation(in);imageSwitcher.setImageResource(R.drawable.ic_launcher);}@OverridepublicbooleanonCreateOptionsMenu(Menumenu){// Inflate the menu; this adds items to the action bar if it is present.getMenuInflater().inflate(R.menu.main,menu);returntrue;}}

以下是经修改的XML文件的内容 res/layout/activity_main.xml.

以下是AndroidManifest.xml文件的内容

让我们试着来运行修改后的图像切换应用程序。安装程序在AVD并启动它,如果一切设置和应用程序都没有问题,它会显示以下仿真器窗口:

269ee3273bc5d93bebf104214afb0080.png

现在,如果看手机屏幕,会看到两个按钮。

现在,只需选择上按钮的右箭头。图像将出现在右走向左边。它如下所示:

2e0acd7a01f93f10d15f05d0fe2de0dc.png

现在点选下面的按钮,将带回以前样式以及一些过渡。它如下所示:

d091d8414a133338631755632fb3e438.png

¥ 我要打赏

纠错/补充

收藏

加QQ群啦,易百教程官方技术学习群

注意:建议每个人选自己的技术方向加群,同一个QQ最多限加 3 个群。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值