目的:
ImageSwitcher控件控制图片滑动样式
(一) 效果实现图:
在图形切换控件中轮流显示,并有慢进慢出的动画效果
data:image/s3,"s3://crabby-images/7868c/7868c4841f2520f62bb9bd227b0c7627312dd630" alt="在这里插入图片描述"
(二) 项目结构图:
- 新建AndroidStudio项目
data:image/s3,"s3://crabby-images/d3410/d34106623e778c04122cff8bc8e5a66a4a8f66c4" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/543e5/543e58bc69b9d1c6aab66d5ce0fe2db580ce1497" alt="在这里插入图片描述"
- 引入内容
anim:
left_in、left_out、right_in、right_out
Drawable:
样式:shape_button_main.xml
图片:tian1.png、tian2.png、tian3.png、movieback.png
(三)具体的编码实现
- 布局界面比较简单,加入ImageSwitcher组件,以及2个button,imageSwitcher.xml:
data:image/s3,"s3://crabby-images/2242c/2242cf93c47039e0aae679ecd8182aceee7cc7f4" alt="在这里插入图片描述"
<LinearLayout xmlns:android&#61;"http://schemas.android.com/apk/res/android"xmlns:tools&#61;"http://schemas.android.com/tools"android:layout_width&#61;"match_parent"android:layout_height&#61;"match_parent"android:orientation&#61;"vertical"android:gravity&#61;"center"android:background&#61;"#a98175"><ImageSwitcherandroid:id&#61;"&#64;&#43;id/is_1"android:layout_width&#61;"match_parent"android:layout_height&#61;"243dp"/><LinearLayoutandroid:layout_width&#61;"match_parent"android:layout_height&#61;"wrap_content"android:orientation&#61;"horizontal"android:paddingTop&#61;"15dp"><Buttonandroid:id&#61;"&#64;&#43;id/btn_previous"android:layout_width&#61;"0dip"android:layout_height&#61;"wrap_content"android:layout_weight&#61;"1"android:layout_marginLeft&#61;"15dp"android:layout_marginRight&#61;"15dp"android:background&#61;"&#64;drawable/shape_button_main"style&#61;"?android:attr/borderlessButtonStyle"android:text&#61;"上一张"android:textSize&#61;"18dp"android:textColor&#61;"#ffffff"/><Buttonandroid:id&#61;"&#64;&#43;id/btn_next"android:layout_width&#61;"0dip"android:layout_height&#61;"wrap_content"android:layout_weight&#61;"1"android:layout_marginLeft&#61;"15dp"android:layout_marginRight&#61;"15dp"android:background&#61;"&#64;drawable/shape_button_main"style&#61;"?android:attr/borderlessButtonStyle"android:text&#61;"下一张"android:textSize&#61;"18dp"android:textColor&#61;"#ffffff"/>LinearLayout>
LinearLayout>
-
引入 图片4张&#xff1a;把需要的图片复制到drawable中&#xff08;注意图片png形式且不要过大&#xff09;
data:image/s3,"s3://crabby-images/69e8c/69e8ccbf1d1736848405da1eec24ff683322fc08" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/7733e/7733e2bceaf92481ac0ae14758ec5ccb812cc6be" alt="在这里插入图片描述"
-
button样式1种&#xff1a;
data:image/s3,"s3://crabby-images/69e8c/69e8ccbf1d1736848405da1eec24ff683322fc08" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/d087e/d087e07e57879051955e14818442cbc034b0a188" alt="在这里插入图片描述"
3.1 在drawable右键新建Drawabler esource file
data:image/s3,"s3://crabby-images/5e182/5e1822f83b7c36f3294076f94f6e7b8591778807" alt="在这里插入图片描述"
3.2命名为shape_button_main&#xff1a;
data:image/s3,"s3://crabby-images/840c7/840c7646c392b7ac8e163a35b93ed2a0c079c812" alt="在这里插入图片描述"
3.3创建完成&#xff0c;并为其设置样式&#xff1a;
data:image/s3,"s3://crabby-images/d087e/d087e07e57879051955e14818442cbc034b0a188" alt="在这里插入图片描述"
<shape xmlns:android&#61;"http://schemas.android.com/apk/res/android"xmlns:tools&#61;"http://schemas.android.com/tools"android:shape&#61;"rectangle"tools:ignore&#61;"MissingDefaultResource"><solid android:color&#61;"#b36d61" /><strokeandroid:width&#61;"1dip"android:color&#61;"#b36d61" /><paddingandroid:bottom&#61;"10dp"android:left&#61;"10dp"android:right&#61;"10dp"android:top&#61;"10dp" /><corners android:radius&#61;"200dp" />shape>
3.4完成如图&#xff1a;data:image/s3,"s3://crabby-images/542fe/542fe02b2aca590bc0e983407705fbd5ee8136e4" alt="在这里插入图片描述"
4. 动态样式4种
data:image/s3,"s3://crabby-images/f07f4/f07f4f719a41146a7ffa272b00c2dd06d73930c4" alt="在这里插入图片描述"
4.1 在res右键添加Android Resource Directory文件夹&#xff1a;
data:image/s3,"s3://crabby-images/cad6d/cad6d42a4f662f27cf3eab64ff82c2afe6c44b42" alt="在这里插入图片描述"
4.2 命名为anim->选择type为anim&#xff1a;
data:image/s3,"s3://crabby-images/05463/05463292dd9192e91f48753814b4579718564f4a" alt="在这里插入图片描述"
4.3新建完成如图&#xff1a;
data:image/s3,"s3://crabby-images/35489/35489afc58f15565db5e85c94994614c9f889ce1" alt="在这里插入图片描述"
4.4 选中anim文件夹->右键添加Animation resource file样式&#xff1a;
data:image/s3,"s3://crabby-images/5112e/5112e40db74346084d1647872c7970f66c1d312f" alt="在这里插入图片描述"
4.5命名为left_in:
data:image/s3,"s3://crabby-images/f9c2e/f9c2ee5dc15394ec12f7804d5efdf271d2836efb" alt="在这里插入图片描述"
4.6重复添加left_out、right_in、right_out&#xff0c;完成如图&#xff1a;
data:image/s3,"s3://crabby-images/b1791/b17918c0252d23c1197c1a32905088f0a6e2a611" alt="在这里插入图片描述"
4.7 自定义4种样式&#xff1a;
data:image/s3,"s3://crabby-images/d713c/d713cdd5d9be88a24681445d377d61984f1a2908" alt="在这里插入图片描述"
left_in&#xff1a;
<set xmlns:android&#61;"http://schemas.android.com/apk/res/android"><translateandroid:fromXDelta&#61;"-100%p"android:toXDelta&#61;"0"android:duration&#61;"600"/><alphaandroid:fromAlpha&#61;"0.1"android:toAlpha&#61;"1.0"android:duration&#61;"600"/>
set>
left_out:
<set xmlns:android&#61;"http://schemas.android.com/apk/res/android"><translateandroid:fromXDelta&#61;"0"android:toXDelta&#61;"-100%p"android:duration&#61;"600"/><alphaandroid:fromAlpha&#61;"0.1"android:toAlpha&#61;"1.0"android:duration&#61;"600"/>
set>
right_in:
<set xmlns:android&#61;"http://schemas.android.com/apk/res/android"><translateandroid:fromXDelta&#61;"100%p"android:toXDelta&#61;"0"android:duration&#61;"600"/><alphaandroid:fromAlpha&#61;"0.1"android:toAlpha&#61;"1.0"android:duration&#61;"600"/>
set>
right_out:
<set xmlns:android&#61;"http://schemas.android.com/apk/res/android"><translateandroid:fromXDelta&#61;"0"android:toXDelta&#61;"100%p"android:duration&#61;"600"/><alphaandroid:fromAlpha&#61;"0.1"android:toAlpha&#61;"1.0"android:duration&#61;"600"/>
set>
- 我的自定义colors&#xff1a;自定义应用顶部的颜色
data:image/s3,"s3://crabby-images/83cc4/83cc4d6169fc7ff7d1b5b95b73fc6a98ec52e752" alt="在这里插入图片描述"
效果图&#xff1a;
data:image/s3,"s3://crabby-images/40481/40481903379cdb5a48ece089dad2265efbc0f304" alt="在这里插入图片描述"
- 主程序入口类imageSwitcherActivity.java
package com.example.cungu.myapplication3;import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.ImageSwitcher;
import android.widget.ImageView;
import android.widget.ViewSwitcher;public class imageSwitcherActivity extends AppCompatActivity implements View.OnClickListener,ViewSwitcher.ViewFactory {private ImageSwitcher is_1;private Button btn_next;private Button btn_previous;private int image[]&#61;{R.drawable.tian1,R.drawable.tian2,R.drawable.tian3,R.drawable.movieback};private int imageIndex&#61;0;&#64;Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_image_switcher);is_1&#61;(ImageSwitcher) findViewById(R.id.is_1);btn_next&#61;(Button) findViewById(R.id.btn_next);btn_previous&#61;(Button) findViewById(R.id.btn_previous);btn_previous.setOnClickListener(this);btn_next.setOnClickListener(this);init(); }&#64;Overridepublic void onClick(View view) {if (view.getId()&#61;&#61;R.id.btn_next){imageIndex&#43;&#43;;if(imageIndex>3){imageIndex&#61;0;}is_1.setInAnimation(this,R.anim.left_in);is_1.setOutAnimation(this,R.anim.right_out);}else if(view.getId()&#61;&#61;R.id.btn_previous){imageIndex--;if(imageIndex<0){imageIndex&#61;image.length-1;}is_1.setInAnimation(this,R.anim.right_in);is_1.setOutAnimation(this,R.anim.left_out);}is_1.setImageResource(image[imageIndex]);}&#64;Overridepublic View makeView() {ImageView imageView&#61;new ImageView(this);return imageView;}private void init(){is_1.setFactory(this);is_1.setImageResource(image[imageIndex]);}
}
以上就是本文的全部内容&#xff0c;希望对大家的学习有所帮助~