Android TextSwitcher文本切换器和ViewFlipper使用详解

作者:ganchuanpu 时间:2023-09-20 01:01:50 

本文为大家分享了Android TextSwitcher文本切换器的使用,供大家参考,具体内容如下

Android TextSwitcher文本切换器和ViewFlipper使用详解

1.TextSwitcher

 使用:

应用分为三步:

1.得到 TextSwitcher 实例对象
  TextSwitcher switcher = (TextSwitcher) findViewById(R.id.textSwitcher);
2.为switcher指定ViewSwitcher.ViewFactory工厂,该工厂会产生出转换时需要的View
  switcher.setFactory(this);
3.为switcher设定显示的内容,该方法执行,就会切换到下个View
  switcher.setText(String.valueOf(new Random().nextInt()));

Android TextSwitcher文本切换器和ViewFlipper使用详解

2.ViewFlipper

Android TextSwitcher文本切换器和ViewFlipper使用详解

实现:

①创建主布局文件,包含ViewFlipper控件(从源码来看,ViewFlipper控件是集成FrameLayout,也是相当于一个帧布局,只是包含了一些特殊的属性)

②创建ViewFlipper的子View,就是两个LinearLayout(里面包含两个TextView)

③创建ViewFlipper中子view的进入和退出动画anim_in和anim_out两个动画文件

④在Activity中将两个子View添加到ViewFlipper中去,调动的是ViewFlipper的addView方法

具体代码:

①创建主布局文件

 activity_main.xml


<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
 xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:app="http://schemas.android.com/apk/res-auto"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:fitsSystemWindows="true"
 tools:context="com.qianmo.rollads.MainActivity">

<android.support.design.widget.AppBarLayout
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:theme="@style/AppTheme.AppBarOverlay">

<android.support.v7.widget.Toolbar
     android:id="@+id/toolbar"
     android:layout_width="match_parent"
     android:layout_height="?attr/actionBarSize"
     android:background="?attr/colorPrimary"
     app:popupTheme="@style/AppTheme.PopupOverlay"/>

</android.support.design.widget.AppBarLayout>

<RelativeLayout
   android:id="@+id/content_main"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   app:layout_behavior="@string/appbar_scrolling_view_behavior"
   tools:context="com.qianmo.rollads.MainActivity"
   tools:showIn="@layout/activity_main">

<ViewFlipper
     android:id="@+id/viewFlipper"
     android:layout_width="match_parent"
     android:layout_height="wrap_content"
     android:autoStart="true"
     android:background="#fff"
     android:flipInterval="3000"
     android:inAnimation="@anim/anim_in"
     android:outAnimation="@anim/anim_out"
     android:paddingLeft="30dp"
     >
   </ViewFlipper>
 </RelativeLayout>
 <android.support.design.widget.FloatingActionButton
   android:id="@+id/fab"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:layout_gravity="bottom|end"
   android:layout_margin="@dimen/fab_margin"
   app:srcCompat="@android:drawable/ic_dialog_email"/>

</android.support.design.widget.CoordinatorLayout>

②创建ViewFlipper的子View,这里有两个,我就只给出一个来了,另一个是一样的

one_ads.xml


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
      android:layout_width="match_parent"
      android:layout_height="match_parent"
      android:orientation="vertical"
      android:padding="8dp"
 >

<LinearLayout
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:gravity="center_vertical"
   android:orientation="horizontal"
   >

<TextView
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="热议"
     android:textColor="#F14C00"
     android:textSize="12sp"
     android:background="@drawable/bg"
     />

<TextView
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:ellipsize="end"
     android:padding="3dp"
     android:singleLine="true"
     android:text="小米8问世,雷胖子现在笑的开心了啦!"
     android:textColor="#333"
     android:textSize="16sp"
     />

</LinearLayout>

<LinearLayout
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:gravity="center_vertical"
   android:orientation="horizontal"
   >

<TextView
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:text="热议"
     android:textColor="#F14C00"
     android:textSize="12sp"
     android:background="@drawable/bg"
     />

<TextView
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:ellipsize="end"
     android:padding="3dp"
     android:singleLine="true"
     android:text="取了个漂亮的媳妇,整的是好开心!"
     android:textColor="#333"
     android:textSize="16sp"
     />

</LinearLayout>

</LinearLayout>

③创建ViewFlipper中子view的进入和退出动画anim_in和anim_out两个动画文件,这里也只给出anim_in的代码,anim_out代码是类似的

anim_in.xml


<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
 <translate
   android:duration="1500"
   android:fromYDelta="100%p"
   android:toYDelta="0"
   />
</set>

④在Activity中将两个子View添加到ViewFlipper中去,调动的是ViewFlipper的addView方法

MainActivity.java


package com.qianmo.rollads;

import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.ViewFlipper;

public class MainActivity extends AppCompatActivity {

private ViewFlipper viewFlipper;

@Override
 protected void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
   setContentView(R.layout.activity_main);
   Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
   viewFlipper = (ViewFlipper) findViewById(R.id.viewFlipper);
   setSupportActionBar(toolbar);

FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
   fab.setOnClickListener(new View.OnClickListener() {
     @Override
     public void onClick(View view) {
       Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
           .setAction("Action", null).show();
     }
   });

viewFlipper.addView(View.inflate(this, R.layout.one_ads, null));
   viewFlipper.addView(View.inflate(this, R.layout.two_ads, null));
 }

}

ok,来看一下我们的效果

Android TextSwitcher文本切换器和ViewFlipper使用详解

标签:Android,TextSwitcher,ViewFlipper
0
投稿

猜你喜欢

  • 编写android拨打电话apk应用实例代码

    2021-08-25 11:09:12
  • Android Studio 1.2版安装设置图文教程

    2023-01-05 02:49:10
  • Java使用DateTimeFormatter格式化输入的日期时间

    2023-03-09 04:52:38
  • Android编程实现XML解析与保存的三种方法详解

    2022-04-15 00:39:01
  • Java实现读取163邮箱,qq邮箱的邮件内容

    2021-09-27 14:26:31
  • C# 6.0 的知识梳理

    2021-07-21 22:08:17
  • C#如何通过匿名类直接使用访问JSON数据详解

    2023-07-20 12:31:53
  • C#中的自动类型转换和强制类型转换

    2023-08-10 07:11:14
  • Android编程基于重力传感器实现横竖屏放向切换功能

    2022-11-30 00:38:54
  • java判断字符串String是否为空问题浅析

    2023-08-25 07:06:06
  • Android缓存机制——LruCache的详解

    2023-07-30 07:26:34
  • Entity Framework使用ObjectContext类

    2023-01-25 16:40:04
  • 使用C#实现在屏幕上画图效果的代码实例

    2022-09-11 05:12:32
  • Android自定义控制条效果

    2023-01-23 23:59:12
  • C#实现协同过滤算法的实例代码

    2023-03-11 12:26:27
  • Java代码块与代码加载顺序原理详解

    2023-06-03 12:56:42
  • Java使用easyExcel导出excel数据案例

    2022-02-21 19:39:27
  • Java DOM4J方式生成XML的方法

    2022-07-19 02:32:42
  • SQL语句删除和添加外键、主键的方法

    2023-04-16 22:18:35
  • Android Selector和Shape的使用方法

    2022-08-05 23:48:38
  • asp之家 软件编程 m.aspxhome.com