Android UI Libs之Titanic

Android UI Libs之Titanic


1. 说明


Titanic是一个可以展示下沉的TextView的库。

2. 配置


该库的作者没有上传该库到任何仓库上,也没有提供库文件,我们需要要源代码下载下来,自己编译库文件。
我编译好的库文件命名为:titanic1.0.0.aar

将titanic1.0.0.aar文件复制到我们模块的libs目录下面,然后在模块的build.gradle上面添加依赖:

dependencies {
    compile(name:'titanic1.0.0', ext:'aar')
}  

3. 基本使用


在xml中定义TitanicTextView

    <com.romainpiel.titanic.library.TitanicTextView
        android:id="@+id/my_text_view"
        android:text="Android技术漫谈"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:gravity="center"
        android:textColor="#212121"
        android:textSize="70sp"
        android:paddingLeft="5dp"
        android:paddingRight="5dp"/>  

在java文件中进行相关操作:

 TitanicTextView tv = (TitanicTextView) findViewById(R.id.my_text_view);
        // 开启下沉动画
        new Titanic().start(tv);  

程序运行界面如下:

我们感觉这个字体不漂亮,想换一种字体怎么办。
为了方便,我直接使用使用该库样例中的字体库:Satisfy-Regular.ttf,并使用该库样例中的Typefaces类。将字体库复制到自己的assets目录下面。
现在,我们在前面代码的基础上修改部分代码,使TitanicTextView可以用一种新的字体。
xml布局文件中的代码不需要改变,仅仅只需要改变java文件中的代码。

TitanicTextView tv = (TitanicTextView) findViewById(R.id.my_text_view);
        // 设置我们想要的字体
        tv.setTypeface(Typefaces.get(this, "Satisfy-Regular.ttf"));
        // 开启下沉动画
        new Titanic().start(tv);

程序运行界面如下:


我们发现英文字体变了,但是中文字体没有变,这是因为该字体库只包含因为不包含中文,如果想要中文字体也变化,就去找一个包含中文的字体库。

如果我们需要停止下沉动画,只需要调用Titaniccancel()方法即可。

程序源代码下载,我的github仓库:https://github.com/lavor-zl/UILibs

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,641评论 25 709
  • 每次吃奶时我一边用手指让宝宝抓握,并用一定的力量练习他手臂的力量,一边吟诵诗经。 昨天闪字卡28盒,今天闪字卡13...
    miaoyin阅读 1,306评论 0 0
  • 不知为何,我比较喜欢游记的书,也许是因为我渴望外面的世界,我喜欢人文地理,或许是文字容易理解吧?这次来写写最近看...
    不与世俗阅读 3,526评论 0 0
  • 作者:婷婷的都城 流转的光阴荏苒,找不到起步的点。只能看时间点滴坠...
    一曲妖娆谢蔷薇阅读 2,701评论 0 0
  • 1 在我的后园,可以看见墙外有两株树,一株是枣树,还有一株也是枣树。 分析:这句话看似重复,但正是这种独特的写法让...
    遇见沐尔阅读 1,280评论 1 1