android-tab-animation

Easily create TabLayout.Tab animations that sync with the scrolling progress of ViewPager.

License

License

GroupId

GroupId

jp.co.cyberagent.android
ArtifactId

ArtifactId

tab-animation
Last Version

Last Version

1.0.0
Release Date

Release Date

Type

Type

aar
Description

Description

android-tab-animation
Easily create TabLayout.Tab animations that sync with the scrolling progress of ViewPager.
Project URL

Project URL

https://github.com/cats-oss/android-tab-animation/
Source Code Management

Source Code Management

https://github.com/cats-oss/android-tab-animation/

Download tab-animation

How to add to project

<!-- https://jarcasting.com/artifacts/jp.co.cyberagent.android/tab-animation/ -->
<dependency>
    <groupId>jp.co.cyberagent.android</groupId>
    <artifactId>tab-animation</artifactId>
    <version>1.0.0</version>
    <type>aar</type>
</dependency>
// https://jarcasting.com/artifacts/jp.co.cyberagent.android/tab-animation/
implementation 'jp.co.cyberagent.android:tab-animation:1.0.0'
// https://jarcasting.com/artifacts/jp.co.cyberagent.android/tab-animation/
implementation ("jp.co.cyberagent.android:tab-animation:1.0.0")
'jp.co.cyberagent.android:tab-animation:aar:1.0.0'
<dependency org="jp.co.cyberagent.android" name="tab-animation" rev="1.0.0">
  <artifact name="tab-animation" type="aar" />
</dependency>
@Grapes(
@Grab(group='jp.co.cyberagent.android', module='tab-animation', version='1.0.0')
)
libraryDependencies += "jp.co.cyberagent.android" % "tab-animation" % "1.0.0"
[jp.co.cyberagent.android/tab-animation "1.0.0"]

Dependencies

runtime (4)

Group / Artifact Type Version
org.jetbrains.kotlin : kotlin-stdlib-jdk7 jar 1.3.61
androidx.appcompat » appcompat jar 1.2.0
androidx.core » core-ktx jar 1.1.0
com.google.android.material » material jar 1.2.1

Project Modules

There are no modules declared in this project.

Tab Animation

License Release CI

Easily create TabLayout.Tab animations that sync with the scrolling progress of ViewPager.

Features

  • Animate Tab when scrolling ViewPager
  • Animate Tab after selected/unselected
  • Support ViewPager and ViewPager2
  • Create animations with DSL

Demo

Tab Indicator Bottom Navigation

Usage

Gradle

implementation 'jp.co.cyberagent.android:tab-animation:x.y.z'

Step 1

Create animation info for Tab:

val animationInfo = viewIdAnimationInfo {
  animateText<Float> {
    property(View.SCALE_X)
    startValue(0.8f)
    endValue(1f)
  }
  animateText<Float> {
    property(View.SCALE_Y)
    startValue(0.8f)
    endValue(1f)
  }
}

Step 2

Link the TabLayout, ViewPager and animation info:

// TabLayout extension function
tabLayout.setupAnimationTabWithViewPager(
  viewPager,
  animationInfo,
  SimpleTab.TEXT
)

Advanced Usage

Custom tab view

Provide the layout file id instead of SimpleTab:

tabLayout.setupAnimationTabWithViewPager(
  viewPager,
  animationInfo,
  R.layout.my_custom_tab
) { tab, view, position ->
  // bind data here
}

Custom animate target

Specify the target id in viewIdAnimationInfo:

viewIdAnimationInfo {
  animate<MyView, Float>(R.id.my_view) {
    ...
  }
}

Custom property

// Create tint property
animateIcon<ColorStateList> {
  property(
    getter = { ImageViewCompat.getImageTintList(this)!! },
    setter = { ImageViewCompat.setImageTintList(this, it) }
  )
  ...
}

Custom evaluator

Current support property types:

  • Int (ARGB)
  • Float
  • IntArray
  • FloatArray
  • PointF
  • Rect
  • ColorStateList

You must specify the evaluator if the property type you want to animate is not listed:

animate<MyView, MyType> {
  evaluator(MyEvaluator)
  ...
}

Specify KeyFrames

animateText<Float> {
  property(View.ALPHA)
  startValue(0f)
  endValue(1f)
  keyFrame(0.8f, 0.2f)
}

Lazy value

Animation info will be evaluated after the layout of Tab. You can calculate the value based on the view:

animateIcon<Float> {
  property(View.TRANSLATION_X)
  startValue { view ->
    view.width / 2f
  }
  endValue { 0f }
}

License

Copyright 2019 CyberAgent, Inc.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
jp.co.cyberagent.android

CATS Open Source Softwares

OSS from CATS ( CyberAgent Advanced Technology Studio ).

Versions

Version
1.0.0