A library to make animated CardView elevation

CardViewPlus

A library to make animated CardView elevation

Download sample app from here

Usage

Add it in your root build.gradle at the end of repositories:

allprojects {
	repositories {
		...
		maven { url 'https://jitpack.io' }
	}
}

Add the dependency

dependencies {
		implementation 'androidx.cardview:cardview:1.0.0'
        implementation 'com.github.alibardide5124:CardViewPlus:1.0.6'
}

Now you’re ready to use CardViewPlus

You can use CardViewPlus just like a normal CardView

<com.alibardide5124.cardviewplus.CardViewPlus
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
	... >	
	
</com.alibardide5124.cardviewplus.CardViewPlus>

But it gives you some more attributes

Properties Type Default
normalCardElevation Dimension – Float (in code) 2dp
pressedCardElevation Dimension – Float (in code) 5dp
cardPressedColor Color cardBackgroundColor
animationEnabled Boolean true
clickDelay Int (milli second) 150

normalCardElevation : set CardViewPlus elevation in noraml state. Default: 2dp.

pressedCardElevation: set CardViewPlus elevation in pressed state. Default: 5dp.

If you want to disable elevation animation, set the same value for normalElevation and maxElevation.

cardPressedColor: set color for onTouch color animation. Default: #e0e0e0.

If you want to disable color animation, set the same value for pressedColor and cardBackgroundColor.

animationEnabled: enable or Disable CardViewPlus shadow and color animations. Default: true.

clickDelay: set a delay for click after release the CardViewPlus. Default: 150ms.

Suggest setting click delay more than 150ms.

Please use normalCardElevation and pressedCardElevation instead of cardElevation and maxCardElevation.

XML

<com.alibardide5124.cardviewplus.CardViewPlus
	android:layout_width="wrap_content"
	android:layout_height="wrap_content"
	app:normalCardElevation="2dp"
	app:pressedCardElevation="5dp"
	app:cardPressedColor="#ffe0e0e0"
	app:animationEnabled="true"
	app:clickDelay="150">


</com.alibardide5124.cardviewplus.CardViewPlus>

Kotlin

cardViewPlus.apply {
	normalCardElevation = 4
	pessedCardElevation = 10
	cardPressedColor = Color.parseColor("#e0e0e0")
	isAnimationEnabled = true
	clickDelay = 150
}

Java

CardViewPlus cardViewPlus = findViewById(R.id.cardViewPlus);
cardViewPlus.setNormalCardElevation(4);
cardViewPlus.setPressedCardElevation(10);
cardViewPlus.setCardPressedColor(Color.parseColor("#e0e0e0"));
cardViewPlus.setAnimationEnabled(true);
cardViewPlus.setClickDelay(150);

Support

Find this library useful? Support it by joining stargazers for this repository

And follow me for my next creations

License

CardViewPlus by Ali Bardide is licensed under a Apache License 2.0.

GitHub

View Github