API Demos 2.3 学习笔记 (19)-- Views-> TextSwitcher

简介:

更多精彩内容,请点击阅读:《API Demos 2.3 学习笔记》


TextSwitcher即文字交换器,是只能包含TextView作为唯一子类型的控件,常用于屏幕上文字标签的动画切换。每次调用setText(CharSequence),TextSwitcher会将当前文字用预定淡出动画隐藏,而将最新文字用预订淡入动画显示出来。
下面简单介绍怎么创建和使用TextSwitcher控件。

1、首先,在布局文件中定义一个TextSwitcher控件

<TextSwitcher
android:id="@+id/switcher"
android:layout_width="match_parent"
 android:layout_height="wrap_content" />

2、创建 Activity时,同时继承ViewSwitcher.ViewFactory接口。

public class TextSwitcher1 extends Activity implements ViewSwitcher.ViewFactory,

3、通过findViewById 实例化TextSwitcher对象 

TextSwitcher mSwitcher = (TextSwitcher) findViewById(R.id.switcher);

4、通过如下设置。每次TextSwitcher的setText(CharSequence)方法 ,都会刷新页面,并调用 makeView来生成一个TextView对象,用于显示文字。

  mSwitcher.setFactory(this);

    //每次调用TextSwitcher的setText方法,UI主线程会调用该函数来生成一个TextView,用于显示文字。
    //这里可以加上自定义属性来自定义TextView。例如,我设置了文字的颜色为蓝色。
    public View makeView() {
        TextView t = new TextView(this);
        t.setGravity(Gravity.TOP | Gravity.CENTER_HORIZONTAL);
        t.setTextColor(Color.BLUE);
        t.setTextSize(36);
        return t;
    }


5、加载并设置TextSwitcher的淡入淡出动画。这里采用了android系统默认的淡如淡出动画,你也可以自定义动画。

        //加载并设置TextSwitcher的淡入淡出动画
        Animation in = AnimationUtils.loadAnimation(this,
                android.R.anim.fade_in);
        Animation out = AnimationUtils.loadAnimation(this,
                android.R.anim.fade_out);
        mSwitcher.setInAnimation(in);
        mSwitcher.setOutAnimation(out);

6、最后,调用setText(CharSequence)方法 刷新界面。刷新流程参考第4条。
mSwitcher.setText(String.valueOf(mCounter));

下面我们进行实例代码解析:
res-layout-text_switcher_1.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" >

    <!-- 一个Button对象 -->
    <Button
        android:id="@+id/next"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/text_switcher_1_next_text" />

    <!-- 一个TextSwitcher对象 -->
    <TextSwitcher
        android:id="@+id/switcher"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />

</LinearLayout>

src-com.example.android.apis.view-TextSwitcher1.java

package com.example.android.apis.view;

import com.example.android.apis.R;

import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.view.Gravity;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.Button;
import android.widget.TextSwitcher;
import android.widget.TextView;
import android.widget.ViewSwitcher;

/**
 * 演示如何使用 TextSwitcher 控件
 */
public class TextSwitcher1 extends Activity implements ViewSwitcher.ViewFactory,
        View.OnClickListener {

    private TextSwitcher mSwitcher;

    private int mCounter = 0;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.text_switcher_1);
        
        // 通过findViewById获得一个TextSwitcher对象
        mSwitcher = (TextSwitcher) findViewById(R.id.switcher);
        mSwitcher.setFactory(this);

        //加载并设置TextSwitcher的淡入淡出动画
        Animation in = AnimationUtils.loadAnimation(this,
                android.R.anim.fade_in);
        Animation out = AnimationUtils.loadAnimation(this,
                android.R.anim.fade_out);
        mSwitcher.setInAnimation(in);
        mSwitcher.setOutAnimation(out);

        // 通过findViewById获得一个Button对象,并设置监听器
        Button nextButton = (Button) findViewById(R.id.next);
        nextButton.setOnClickListener(this);

        updateCounter();
    }

    //Button的监听器实现代码。
    //每次点击按钮,mCounter就会加上1,并且刷新界面
    public void onClick(View v) {
        mCounter++;
        updateCounter();
    }

    //每次调用TextSwitcher的setText方法,都会刷新界面。
    //用淡出动画效果隐藏旧的TextView,接着用淡入效果加载新的TextView
    private void updateCounter() {
        mSwitcher.setText(String.valueOf(mCounter));
    }

    //每次调用TextSwitcher的setText方法,UI主线程会调用该函数来生成一个TextView,用于显示文字。
    //这里可以加上自定义属性来自定义TextView。例如,我设置了文字的颜色为蓝色。
    public View makeView() {
        TextView t = new TextView(this);
        t.setGravity(Gravity.TOP | Gravity.CENTER_HORIZONTAL);
        t.setTextColor(Color.BLUE);
        t.setTextSize(36);
        return t;
    }
}


预览效果:



相关文章
|
人工智能 监控 安全
F5社区学习笔记:API和AI如何改变应用安全?
F5社区学习笔记:API和AI如何改变应用安全?
137 1
|
jenkins API 持续交付
jenkins学习笔记之十五:SonarSQube API使用
jenkins学习笔记之十五:SonarSQube API使用
|
XML API 数据格式
【Qt 学习笔记】QWidget的enable属性 | API的介绍
【Qt 学习笔记】QWidget的enable属性 | API的介绍
441 0
|
前端开发 API
前端学习笔记202305学习笔记第三十天-什么是mvc-c层api 前后端联动1
前端学习笔记202305学习笔记第三十天-什么是mvc-c层api 前后端联动1
218 0
|
前端开发 API
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 前后端联动3
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 前后端联动3
107 0
|
前端开发 API
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 和mvc总结3
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 和mvc总结3
175 0
|
前端开发 API
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 和mvc总结4
前端学习笔记202305学习笔记第三十一天-什么是mvc-c层api 和mvc总结
183 0
|
2月前
|
缓存 监控 前端开发
顺企网 API 开发实战:搜索 / 详情接口从 0 到 1 落地(附 Elasticsearch 优化 + 错误速查)
企业API开发常陷参数、缓存、错误处理三大坑?本指南拆解顺企网双接口全流程,涵盖搜索优化、签名验证、限流应对,附可复用代码与错误速查表,助你2小时高效搞定开发,提升响应速度与稳定性。
|
2月前
|
JSON 算法 API
Python采集淘宝商品评论API接口及JSON数据返回全程指南
Python采集淘宝商品评论API接口及JSON数据返回全程指南
|
3月前
|
数据可视化 测试技术 API
从接口性能到稳定性:这些API调试工具,让你的开发过程事半功倍
在软件开发中,接口调试与测试对接口性能、稳定性、准确性及团队协作至关重要。随着开发节奏加快,传统方式已难满足需求,专业API工具成为首选。本文介绍了Apifox、Postman、YApi、SoapUI、JMeter、Swagger等主流工具,对比其功能与适用场景,并推荐Apifox作为集成度高、支持中文、可视化强的一体化解决方案,助力提升API开发与测试效率。