├── .gitignore
├── .idea
├── assetWizardSettings.xml
├── codeStyles
│ └── Project.xml
├── gradle.xml
├── misc.xml
├── modules.xml
├── runConfigurations.xml
└── vcs.xml
├── CONTRIBUTING.md
├── LICENSE
├── README.md
├── app
├── .gitignore
├── build.gradle
├── proguard-rules.pro
└── src
│ ├── androidTest
│ └── java
│ │ └── com
│ │ └── keyframeanimationdemo
│ │ └── ExampleInstrumentedTest.kt
│ ├── main
│ ├── AndroidManifest.xml
│ ├── java
│ │ └── com
│ │ │ └── keyframeanimationdemo
│ │ │ ├── activity
│ │ │ ├── MainActivity.kt
│ │ │ ├── circularpositioning
│ │ │ │ └── CircularPositioning.kt
│ │ │ ├── collpasingtoolbar
│ │ │ │ └── CollapsingToolbarActivity.kt
│ │ │ ├── keyframeanimation
│ │ │ │ ├── KeyFrameAnimationActivity.kt
│ │ │ │ └── ShoppingKeyFrameAnimation.kt
│ │ │ └── parallax
│ │ │ │ └── ParallaxEffectActivity.kt
│ │ │ ├── adapter
│ │ │ └── Adapter.kt
│ │ │ └── utils
│ │ │ ├── AnimationHelper.kt
│ │ │ ├── CollapsibleConstraintLayout.kt
│ │ │ └── NestedConstraintLayout.kt
│ └── res
│ │ ├── drawable-v24
│ │ └── ic_launcher_foreground.xml
│ │ ├── drawable
│ │ ├── background.webp
│ │ ├── background_image.jpg
│ │ ├── blue_button.xml
│ │ ├── broken_glass.png
│ │ ├── button_background.xml
│ │ ├── button_bg.xml
│ │ ├── chip_background.png
│ │ ├── earth.png
│ │ ├── edit_text_background.xml
│ │ ├── fifth_bg.jpg
│ │ ├── fourth_bg.jpg
│ │ ├── gradient.xml
│ │ ├── ic_add_24dp.xml
│ │ ├── ic_close_24dp.xml
│ │ ├── ic_format_align_right_white_24dp.xml
│ │ ├── ic_launcher_background.xml
│ │ ├── ic_notifications_black_24dp.xml
│ │ ├── ic_remove_24dp.xml
│ │ ├── ic_search_black_24dp.xml
│ │ ├── ic_shopping_cart_black_24dp.xml
│ │ ├── image_top_round_corner.xml
│ │ ├── jordan_ultra.jpg
│ │ ├── layout_bg.xml
│ │ ├── mars.png
│ │ ├── one_bg.jpg
│ │ ├── profile_avatar.png
│ │ ├── profile_image.jpg
│ │ ├── saturn.png
│ │ ├── selected_button_bg.xml
│ │ ├── sun.png
│ │ ├── three_bg.jpg
│ │ └── two_bg.jpg
│ │ ├── font
│ │ └── poppins.xml
│ │ ├── layout
│ │ ├── activity_collapsing_toolbar.xml
│ │ ├── activity_key_frame_animation.xml
│ │ ├── activity_main.xml
│ │ ├── activity_orbits.xml
│ │ ├── activity_parallax_effect.xml
│ │ ├── activity_shopping_key_frame_animation.xml
│ │ ├── detail.xml
│ │ ├── item_parallax_layout.xml
│ │ ├── layout_closed_toolbar.xml
│ │ ├── layout_orbits_details.xml
│ │ ├── layout_shopping_activity_invisble_size.xml
│ │ ├── layout_shopping_activity_select_size.xml
│ │ ├── second_activity_layout_swipe_up.xml
│ │ └── toolbar_layout.xml
│ │ ├── mipmap-anydpi-v26
│ │ ├── ic_launcher.xml
│ │ └── ic_launcher_round.xml
│ │ ├── mipmap-hdpi
│ │ ├── ic_launcher.png
│ │ └── ic_launcher_round.png
│ │ ├── mipmap-mdpi
│ │ ├── ic_launcher.png
│ │ └── ic_launcher_round.png
│ │ ├── mipmap-xhdpi
│ │ ├── ic_launcher.png
│ │ └── ic_launcher_round.png
│ │ ├── mipmap-xxhdpi
│ │ ├── ic_launcher.png
│ │ └── ic_launcher_round.png
│ │ ├── mipmap-xxxhdpi
│ │ ├── ic_launcher.png
│ │ └── ic_launcher_round.png
│ │ └── values
│ │ ├── colors.xml
│ │ ├── dimens.xml
│ │ ├── font_certs.xml
│ │ ├── preloaded_fonts.xml
│ │ ├── strings.xml
│ │ └── styles.xml
│ └── test
│ └── java
│ └── com
│ └── keyframeanimationdemo
│ └── ExampleUnitTest.kt
├── build.gradle
├── gif
├── Circular_Positioning.gif
├── ShoppingKeyframeAnimation.gif
├── collapsing toolbar.gif
├── parallax_effect.gif
└── shoopin_key_frame_animation.gif
├── gradle.properties
├── gradle
└── wrapper
│ ├── gradle-wrapper.jar
│ └── gradle-wrapper.properties
├── gradlew
├── gradlew.bat
├── keyframeanimation.gif
└── settings.gradle
/.gitignore:
--------------------------------------------------------------------------------
1 | # Built application files
2 | *.apk
3 | *.ap_
4 |
5 | # Files for the ART/Dalvik VM
6 | *.dex
7 |
8 | # Java class files
9 | *.class
10 |
11 | # Generated files
12 | bin/
13 | gen/
14 | out/
15 |
16 | # Gradle files
17 | .gradle/
18 | build/
19 |
20 | # Local configuration file (sdk path, etc)
21 | local.properties
22 |
23 | # Proguard folder generated by Eclipse
24 | proguard/
25 |
26 | # Log Files
27 | *.log
28 |
29 | # Android Studio Navigation editor temp files
30 | .navigation/
31 |
32 | # Android Studio captures folder
33 | captures/
34 |
35 | # IntelliJ
36 | *.iml
37 | .idea/workspace.xml
38 | .idea/tasks.xml
39 | .idea/gradle.xml
40 | .idea/assetWizardSettings.xml
41 | .idea/dictionaries
42 | .idea/libraries
43 | .idea/caches
44 | .idea/vcs.xml
45 | .idea/jsLibraryMappings.xml
46 |
47 | # Keystore files
48 | # Uncomment the following line if you do not want to check your keystore files in.
49 | #*.jks
50 |
51 | # External native build folder generated in Android Studio 2.2 and later
52 | .externalNativeBuild
53 |
54 | # Google Services (e.g. APIs or Firebase)
55 | google-services.json
56 |
57 | # Crashlytics plugin (for Android Studio and IntelliJ)
58 | com_crashlytics_export_strings.xml
59 | crashlytics.properties
60 | crashlytics-build.properties
61 | fabric.properties
--------------------------------------------------------------------------------
/.idea/assetWizardSettings.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
51 |
52 |
--------------------------------------------------------------------------------
/.idea/codeStyles/Project.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
--------------------------------------------------------------------------------
/.idea/gradle.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
17 |
18 |
--------------------------------------------------------------------------------
/.idea/misc.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 |
33 |
34 |
--------------------------------------------------------------------------------
/.idea/modules.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
--------------------------------------------------------------------------------
/.idea/runConfigurations.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
--------------------------------------------------------------------------------
/.idea/vcs.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
--------------------------------------------------------------------------------
/CONTRIBUTING.md:
--------------------------------------------------------------------------------
1 | # How to contribute?
2 |
3 | 1. Fork the project.
4 | 2. Make required changes and commit.
5 | 3. Generate pull request. Mention all the required description regarding changes you made.
6 |
7 | Happy coding.:-)
8 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | Apache License
2 | Version 2.0, January 2004
3 | http://www.apache.org/licenses/
4 |
5 | TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
6 |
7 | 1. Definitions.
8 |
9 | "License" shall mean the terms and conditions for use, reproduction,
10 | and distribution as defined by Sections 1 through 9 of this document.
11 |
12 | "Licensor" shall mean the copyright owner or entity authorized by
13 | the copyright owner that is granting the License.
14 |
15 | "Legal Entity" shall mean the union of the acting entity and all
16 | other entities that control, are controlled by, or are under common
17 | control with that entity. For the purposes of this definition,
18 | "control" means (i) the power, direct or indirect, to cause the
19 | direction or management of such entity, whether by contract or
20 | otherwise, or (ii) ownership of fifty percent (50%) or more of the
21 | outstanding shares, or (iii) beneficial ownership of such entity.
22 |
23 | "You" (or "Your") shall mean an individual or Legal Entity
24 | exercising permissions granted by this License.
25 |
26 | "Source" form shall mean the preferred form for making modifications,
27 | including but not limited to software source code, documentation
28 | source, and configuration files.
29 |
30 | "Object" form shall mean any form resulting from mechanical
31 | transformation or translation of a Source form, including but
32 | not limited to compiled object code, generated documentation,
33 | and conversions to other media types.
34 |
35 | "Work" shall mean the work of authorship, whether in Source or
36 | Object form, made available under the License, as indicated by a
37 | copyright notice that is included in or attached to the work
38 | (an example is provided in the Appendix below).
39 |
40 | "Derivative Works" shall mean any work, whether in Source or Object
41 | form, that is based on (or derived from) the Work and for which the
42 | editorial revisions, annotations, elaborations, or other modifications
43 | represent, as a whole, an original work of authorship. For the purposes
44 | of this License, Derivative Works shall not include works that remain
45 | separable from, or merely link (or bind by name) to the interfaces of,
46 | the Work and Derivative Works thereof.
47 |
48 | "Contribution" shall mean any work of authorship, including
49 | the original version of the Work and any modifications or additions
50 | to that Work or Derivative Works thereof, that is intentionally
51 | submitted to Licensor for inclusion in the Work by the copyright owner
52 | or by an individual or Legal Entity authorized to submit on behalf of
53 | the copyright owner. For the purposes of this definition, "submitted"
54 | means any form of electronic, verbal, or written communication sent
55 | to the Licensor or its representatives, including but not limited to
56 | communication on electronic mailing lists, source code control systems,
57 | and issue tracking systems that are managed by, or on behalf of, the
58 | Licensor for the purpose of discussing and improving the Work, but
59 | excluding communication that is conspicuously marked or otherwise
60 | designated in writing by the copyright owner as "Not a Contribution."
61 |
62 | "Contributor" shall mean Licensor and any individual or Legal Entity
63 | on behalf of whom a Contribution has been received by Licensor and
64 | subsequently incorporated within the Work.
65 |
66 | 2. Grant of Copyright License. Subject to the terms and conditions of
67 | this License, each Contributor hereby grants to You a perpetual,
68 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable
69 | copyright license to reproduce, prepare Derivative Works of,
70 | publicly display, publicly perform, sublicense, and distribute the
71 | Work and such Derivative Works in Source or Object form.
72 |
73 | 3. Grant of Patent License. Subject to the terms and conditions of
74 | this License, each Contributor hereby grants to You a perpetual,
75 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable
76 | (except as stated in this section) patent license to make, have made,
77 | use, offer to sell, sell, import, and otherwise transfer the Work,
78 | where such license applies only to those patent claims licensable
79 | by such Contributor that are necessarily infringed by their
80 | Contribution(s) alone or by combination of their Contribution(s)
81 | with the Work to which such Contribution(s) was submitted. If You
82 | institute patent litigation against any entity (including a
83 | cross-claim or counterclaim in a lawsuit) alleging that the Work
84 | or a Contribution incorporated within the Work constitutes direct
85 | or contributory patent infringement, then any patent licenses
86 | granted to You under this License for that Work shall terminate
87 | as of the date such litigation is filed.
88 |
89 | 4. Redistribution. You may reproduce and distribute copies of the
90 | Work or Derivative Works thereof in any medium, with or without
91 | modifications, and in Source or Object form, provided that You
92 | meet the following conditions:
93 |
94 | (a) You must give any other recipients of the Work or
95 | Derivative Works a copy of this License; and
96 |
97 | (b) You must cause any modified files to carry prominent notices
98 | stating that You changed the files; and
99 |
100 | (c) You must retain, in the Source form of any Derivative Works
101 | that You distribute, all copyright, patent, trademark, and
102 | attribution notices from the Source form of the Work,
103 | excluding those notices that do not pertain to any part of
104 | the Derivative Works; and
105 |
106 | (d) If the Work includes a "NOTICE" text file as part of its
107 | distribution, then any Derivative Works that You distribute must
108 | include a readable copy of the attribution notices contained
109 | within such NOTICE file, excluding those notices that do not
110 | pertain to any part of the Derivative Works, in at least one
111 | of the following places: within a NOTICE text file distributed
112 | as part of the Derivative Works; within the Source form or
113 | documentation, if provided along with the Derivative Works; or,
114 | within a display generated by the Derivative Works, if and
115 | wherever such third-party notices normally appear. The contents
116 | of the NOTICE file are for informational purposes only and
117 | do not modify the License. You may add Your own attribution
118 | notices within Derivative Works that You distribute, alongside
119 | or as an addendum to the NOTICE text from the Work, provided
120 | that such additional attribution notices cannot be construed
121 | as modifying the License.
122 |
123 | You may add Your own copyright statement to Your modifications and
124 | may provide additional or different license terms and conditions
125 | for use, reproduction, or distribution of Your modifications, or
126 | for any such Derivative Works as a whole, provided Your use,
127 | reproduction, and distribution of the Work otherwise complies with
128 | the conditions stated in this License.
129 |
130 | 5. Submission of Contributions. Unless You explicitly state otherwise,
131 | any Contribution intentionally submitted for inclusion in the Work
132 | by You to the Licensor shall be under the terms and conditions of
133 | this License, without any additional terms or conditions.
134 | Notwithstanding the above, nothing herein shall supersede or modify
135 | the terms of any separate license agreement you may have executed
136 | with Licensor regarding such Contributions.
137 |
138 | 6. Trademarks. This License does not grant permission to use the trade
139 | names, trademarks, service marks, or product names of the Licensor,
140 | except as required for reasonable and customary use in describing the
141 | origin of the Work and reproducing the content of the NOTICE file.
142 |
143 | 7. Disclaimer of Warranty. Unless required by applicable law or
144 | agreed to in writing, Licensor provides the Work (and each
145 | Contributor provides its Contributions) on an "AS IS" BASIS,
146 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
147 | implied, including, without limitation, any warranties or conditions
148 | of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
149 | PARTICULAR PURPOSE. You are solely responsible for determining the
150 | appropriateness of using or redistributing the Work and assume any
151 | risks associated with Your exercise of permissions under this License.
152 |
153 | 8. Limitation of Liability. In no event and under no legal theory,
154 | whether in tort (including negligence), contract, or otherwise,
155 | unless required by applicable law (such as deliberate and grossly
156 | negligent acts) or agreed to in writing, shall any Contributor be
157 | liable to You for damages, including any direct, indirect, special,
158 | incidental, or consequential damages of any character arising as a
159 | result of this License or out of the use or inability to use the
160 | Work (including but not limited to damages for loss of goodwill,
161 | work stoppage, computer failure or malfunction, or any and all
162 | other commercial damages or losses), even if such Contributor
163 | has been advised of the possibility of such damages.
164 |
165 | 9. Accepting Warranty or Additional Liability. While redistributing
166 | the Work or Derivative Works thereof, You may choose to offer,
167 | and charge a fee for, acceptance of support, warranty, indemnity,
168 | or other liability obligations and/or rights consistent with this
169 | License. However, in accepting such obligations, You may act only
170 | on Your own behalf and on Your sole responsibility, not on behalf
171 | of any other Contributor, and only if You agree to indemnify,
172 | defend, and hold each Contributor harmless for any liability
173 | incurred by, or claims asserted against, such Contributor by reason
174 | of your accepting any such warranty or additional liability.
175 |
176 | END OF TERMS AND CONDITIONS
177 |
178 | APPENDIX: How to apply the Apache License to your work.
179 |
180 | To apply the Apache License to your work, attach the following
181 | boilerplate notice, with the fields enclosed by brackets "[]"
182 | replaced with your own identifying information. (Don't include
183 | the brackets!) The text should be enclosed in the appropriate
184 | comment syntax for the file format. We also recommend that a
185 | file or class name and description of purpose be included on the
186 | same "printed page" as the copyright notice for easier
187 | identification within third-party archives.
188 |
189 | Copyright [yyyy] [name of copyright owner]
190 |
191 | Licensed under the Apache License, Version 2.0 (the "License");
192 | you may not use this file except in compliance with the License.
193 | You may obtain a copy of the License at
194 |
195 | http://www.apache.org/licenses/LICENSE-2.0
196 |
197 | Unless required by applicable law or agreed to in writing, software
198 | distributed under the License is distributed on an "AS IS" BASIS,
199 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
200 | See the License for the specific language governing permissions and
201 | limitations under the License.
202 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # Animations Using ConstraintLayout
2 | Simple and Complex animation that can be implemented easily using the Constraint layout.
3 |
4 | Developed with ❤️ using [**Kotlin**](https://kotlinlang.org/) :muscle: and [**ConstraintLayout**](https://constraintlayout.com/)
5 |
6 | # Preview
7 |
8 | | Keyframe animation | Shopping Keyframe animation | Collapsing toolbar |
9 | | ------------------ | --------------------------- | ------------------ |
10 | |
|
|
|
11 |
12 | | Parallax Effect |
13 | | --------------- |
14 | |
|
15 |
16 | | Circular Positioning |
17 | | -------------------- |
18 | |
|
19 |
20 | # Resources
21 |
22 | [Keyframe animations with ConstraintLayout and ConstraintSet](https://www.youtube.com/watch?v=OHcfs6rStRo)
23 |
24 | [ConstraintLayout: Circular Positioning](https://medium.com/devnibbles/constraintlayout-circular-positioning-9489b11cb0e5)
25 |
26 | # How to contribute?
27 |
28 | Check out contribution guidelines 👉[CONTRIBUTING.md](https://github.com/ibhavikmakwana/Constraint-Layout-Animations/blob/master/CONTRIBUTING.md)
29 |
30 | # Developed by
31 |
32 | Bhavik Makwana [linkedin](https://www.linkedin.com/in/ibhavikmakwana/) [Twitter](https://twitter.com/ibhavikmakwana)
33 |
34 | # Credits
35 |
36 | I have used [Ramotion's design](https://www.uplabs.com/posts/shopping-app-interactions) concept for the animation of shopping layout
37 |
38 | # License
39 |
40 | The contents of this repository are covered under the [Apache License 2.0](https://github.com/ibhavikmakwana/KeyFrameAnimationDemo/blob/master/LICENSE).
41 |
--------------------------------------------------------------------------------
/app/.gitignore:
--------------------------------------------------------------------------------
1 | /build
2 |
--------------------------------------------------------------------------------
/app/build.gradle:
--------------------------------------------------------------------------------
1 | apply plugin: 'com.android.application'
2 |
3 | apply plugin: 'kotlin-android'
4 |
5 | apply plugin: 'kotlin-android-extensions'
6 |
7 | android {
8 | compileSdkVersion 27
9 | defaultConfig {
10 | applicationId "com.constraintanimationdemo"
11 | minSdkVersion 19
12 | targetSdkVersion 27
13 | versionCode 1
14 | versionName "1.0"
15 | testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
16 | }
17 | buildTypes {
18 | release {
19 | minifyEnabled false
20 | proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
21 | }
22 | }
23 | }
24 |
25 | ext {
26 | supportLibraryVersion = '27.1.1'
27 | }
28 |
29 | dependencies {
30 | implementation fileTree(include: ['*.jar'], dir: 'libs')
31 | implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
32 | testImplementation 'junit:junit:4.12'
33 | androidTestImplementation 'com.android.support.test:runner:1.0.1'
34 | androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1'
35 | implementation "com.android.support:appcompat-v7:$supportLibraryVersion"
36 | implementation "com.android.support:cardview-v7:$supportLibraryVersion"
37 | implementation "com.android.support:design:$supportLibraryVersion"
38 | implementation "com.android.support.constraint:constraint-layout:1.1.0"
39 | }
40 |
--------------------------------------------------------------------------------
/app/proguard-rules.pro:
--------------------------------------------------------------------------------
1 | # Add project specific ProGuard rules here.
2 | # You can control the set of applied configuration files using the
3 | # proguardFiles setting in build.gradle.
4 | #
5 | # For more details, see
6 | # http://developer.android.com/guide/developing/tools/proguard.html
7 |
8 | # If your project uses WebView with JS, uncomment the following
9 | # and specify the fully qualified class name to the JavaScript interface
10 | # class:
11 | #-keepclassmembers class fqcn.of.javascript.interface.for.webview {
12 | # public *;
13 | #}
14 |
15 | # Uncomment this to preserve the line number information for
16 | # debugging stack traces.
17 | #-keepattributes SourceFile,LineNumberTable
18 |
19 | # If you keep the line number information, uncomment this to
20 | # hide the original source file name.
21 | #-renamesourcefileattribute SourceFile
22 |
--------------------------------------------------------------------------------
/app/src/androidTest/java/com/keyframeanimationdemo/ExampleInstrumentedTest.kt:
--------------------------------------------------------------------------------
1 | package com.keyframeanimationdemo
2 |
3 | import android.support.test.InstrumentationRegistry
4 | import android.support.test.runner.AndroidJUnit4
5 |
6 | import org.junit.Test
7 | import org.junit.runner.RunWith
8 |
9 | import org.junit.Assert.*
10 |
11 | /**
12 | * Instrumented test, which will execute on an Android device.
13 | *
14 | * See [testing documentation](http://d.android.com/tools/testing).
15 | */
16 | @RunWith(AndroidJUnit4::class)
17 | class ExampleInstrumentedTest {
18 | @Test
19 | fun useAppContext() {
20 | // Context of the app under test.
21 | val appContext = InstrumentationRegistry.getTargetContext()
22 | assertEquals("com.constraintanimationdemo", appContext.packageName)
23 | }
24 | }
25 |
--------------------------------------------------------------------------------
/app/src/main/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
22 |
23 |
26 |
27 |
30 |
33 |
36 |
39 |
40 |
41 |
42 |
--------------------------------------------------------------------------------
/app/src/main/java/com/keyframeanimationdemo/activity/MainActivity.kt:
--------------------------------------------------------------------------------
1 | package com.keyframeanimationdemo.activity
2 |
3 | import android.os.Bundle
4 | import android.support.v7.app.AppCompatActivity
5 | import android.view.View
6 | import com.keyframeanimationdemo.R
7 | import com.keyframeanimationdemo.activity.circularpositioning.CircularPositioning
8 | import com.keyframeanimationdemo.activity.collpasingtoolbar.CollapsingToolbarActivity
9 | import com.keyframeanimationdemo.activity.keyframeanimation.KeyFrameAnimationActivity
10 | import com.keyframeanimationdemo.activity.keyframeanimation.ShoppingKeyFrameAnimation
11 | import com.keyframeanimationdemo.activity.parallax.ParallaxEffectActivity
12 | import kotlinx.android.synthetic.main.activity_main.*
13 |
14 | class MainActivity : AppCompatActivity(), View.OnClickListener {
15 |
16 | override fun onCreate(savedInstanceState: Bundle?) {
17 | super.onCreate(savedInstanceState)
18 | setContentView(R.layout.activity_main)
19 | tv_one.setOnClickListener(this)
20 | tv_two.setOnClickListener(this)
21 | tv_collapsing_toolbar.setOnClickListener(this)
22 | tv_parallax_effect.setOnClickListener(this)
23 | tv_circular_positioning.setOnClickListener(this)
24 | }
25 |
26 | override fun onClick(view: View?) {
27 | when (view?.id) {
28 | R.id.tv_one -> {
29 | KeyFrameAnimationActivity.launchActivity(this)
30 | }
31 | R.id.tv_two -> {
32 | ShoppingKeyFrameAnimation.launchActivity(this)
33 | }
34 | R.id.tv_collapsing_toolbar -> {
35 | CollapsingToolbarActivity.launchActivity(this)
36 | }
37 | R.id.tv_parallax_effect -> {
38 | ParallaxEffectActivity.launchActivity(this)
39 | }
40 | R.id.tv_circular_positioning -> {
41 | CircularPositioning.launchActivity(this)
42 | }
43 | }
44 | }
45 | }
--------------------------------------------------------------------------------
/app/src/main/java/com/keyframeanimationdemo/activity/circularpositioning/CircularPositioning.kt:
--------------------------------------------------------------------------------
1 | package com.keyframeanimationdemo.activity.circularpositioning
2 |
3 | import android.animation.ValueAnimator
4 | import android.content.Context
5 | import android.content.Intent
6 | import android.os.Bundle
7 | import android.support.annotation.LayoutRes
8 | import android.support.constraint.ConstraintLayout
9 | import android.support.constraint.ConstraintSet
10 | import android.support.transition.TransitionManager
11 | import android.support.v7.app.AppCompatActivity
12 | import android.view.animation.LinearInterpolator
13 | import android.widget.ImageView
14 | import com.keyframeanimationdemo.R
15 | import kotlinx.android.synthetic.main.activity_orbits.*
16 | import java.util.concurrent.TimeUnit
17 |
18 |
19 | class CircularPositioning : AppCompatActivity() {
20 |
21 | /**
22 | * Call this method to launch the activity.
23 | */
24 | companion object {
25 | fun launchActivity(context: Context) {
26 | val intent = Intent(context, CircularPositioning::class.java)
27 | context.startActivity(intent)
28 | }
29 | }
30 |
31 | override fun onCreate(savedInstanceState: Bundle?) {
32 | super.onCreate(savedInstanceState)
33 | setContentView(R.layout.activity_orbits)
34 |
35 |
36 | val earthAnimator = animatePlanet(earth_image, TimeUnit.SECONDS.toMillis(2))
37 | val marsAnimator = animatePlanet(mars_image, TimeUnit.SECONDS.toMillis(6))
38 | val saturnAnimator = animatePlanet(saturn_image, TimeUnit.SECONDS.toMillis(12))
39 |
40 | updateConstraints(R.layout.activity_orbits)
41 | startAnimation(earthAnimator, marsAnimator, saturnAnimator)
42 |
43 | var show = true
44 | sun_image.setOnClickListener({
45 | show = if (show) {
46 | cancelAnim(earthAnimator, marsAnimator, saturnAnimator)
47 | updateConstraints(R.layout.layout_orbits_details)
48 | false
49 | } else {
50 | startAnimation(earthAnimator, marsAnimator, saturnAnimator)
51 | updateConstraints(R.layout.activity_orbits)
52 | true
53 | }
54 | })
55 | }
56 |
57 | private fun updateConstraints(@LayoutRes id: Int) {
58 | val newConstraintSet = ConstraintSet()
59 | newConstraintSet.clone(this, id)
60 | newConstraintSet.applyTo(root)
61 | TransitionManager.beginDelayedTransition(root)
62 | }
63 |
64 | private fun cancelAnim(earthAnimator: ValueAnimator, marsAnimator: ValueAnimator, saturnAnimator: ValueAnimator) {
65 | earthAnimator.cancel()
66 | marsAnimator.cancel()
67 | saturnAnimator.cancel()
68 | }
69 |
70 | private fun startAnimation(earthAnimator: ValueAnimator, marsAnimator: ValueAnimator, saturnAnimator: ValueAnimator) {
71 | earthAnimator.start()
72 | marsAnimator.start()
73 | saturnAnimator.start()
74 | }
75 |
76 | private fun animatePlanet(planet: ImageView?, orbitDuration: Long): ValueAnimator {
77 | val anim = ValueAnimator.ofInt(0, 359)
78 | anim.addUpdateListener { valueAnimator ->
79 | val value = valueAnimator.animatedValue as Int
80 | val layoutParams = planet?.layoutParams as ConstraintLayout.LayoutParams
81 | layoutParams.circleAngle = value.toFloat()
82 | planet.layoutParams = layoutParams
83 | anim.duration = orbitDuration
84 | anim.interpolator = LinearInterpolator()
85 | anim.repeatMode = ValueAnimator.RESTART
86 | anim.repeatCount = ValueAnimator.INFINITE
87 | }
88 | return anim
89 | }
90 | }
91 |
--------------------------------------------------------------------------------
/app/src/main/java/com/keyframeanimationdemo/activity/collpasingtoolbar/CollapsingToolbarActivity.kt:
--------------------------------------------------------------------------------
1 | package com.keyframeanimationdemo.activity.collpasingtoolbar
2 |
3 | import android.content.Context
4 | import android.content.Intent
5 | import android.os.Bundle
6 | import android.support.v7.app.AppCompatActivity
7 | import com.keyframeanimationdemo.R
8 |
9 | class CollapsingToolbarActivity : AppCompatActivity() {
10 |
11 | /**
12 | * Call this method to launch the activity.
13 | */
14 | companion object {
15 | fun launchActivity(context: Context) {
16 | val intent = Intent(context, CollapsingToolbarActivity::class.java)
17 | context.startActivity(intent)
18 | }
19 | }
20 |
21 | override fun onCreate(savedInstanceState: Bundle?) {
22 | super.onCreate(savedInstanceState)
23 | setContentView(R.layout.activity_collapsing_toolbar)
24 | }
25 | }
26 |
--------------------------------------------------------------------------------
/app/src/main/java/com/keyframeanimationdemo/activity/keyframeanimation/KeyFrameAnimationActivity.kt:
--------------------------------------------------------------------------------
1 | package com.keyframeanimationdemo.activity.keyframeanimation
2 |
3 | import android.content.Context
4 | import android.content.Intent
5 | import android.os.Bundle
6 | import android.support.constraint.ConstraintSet
7 | import android.support.v7.app.AppCompatActivity
8 | import android.transition.ChangeBounds
9 | import android.transition.TransitionManager
10 | import android.view.animation.AnticipateOvershootInterpolator
11 | import com.keyframeanimationdemo.R
12 | import kotlinx.android.synthetic.main.activity_key_frame_animation.*
13 |
14 | class KeyFrameAnimationActivity : AppCompatActivity() {
15 |
16 |
17 | /**
18 | * Call this method to launch the activity.
19 | */
20 | companion object {
21 | fun launchActivity(context: Context) {
22 | val intent = Intent(context, KeyFrameAnimationActivity::class.java)
23 | context.startActivity(intent)
24 | }
25 | }
26 |
27 | override fun onCreate(savedInstanceState: Bundle?) {
28 | super.onCreate(savedInstanceState)
29 | setContentView(R.layout.activity_key_frame_animation)
30 |
31 | var show = false
32 | iv_background_image.setOnClickListener {
33 | show = if (show) {
34 | hideComponents()
35 | false
36 | } else {
37 | showComponents()
38 | true
39 | }
40 | }
41 | }
42 |
43 | private fun showComponents() {
44 | val constraintSet = ConstraintSet()
45 | constraintSet.clone(this, R.layout.detail)
46 | val transition = ChangeBounds()
47 | transition.interpolator = AnticipateOvershootInterpolator(1.0f)
48 | transition.duration = 1200
49 |
50 | TransitionManager.beginDelayedTransition(constraint, transition)
51 |
52 | constraintSet.applyTo(constraint)
53 | }
54 |
55 | private fun hideComponents() {
56 | val constraintSet = ConstraintSet()
57 | constraintSet.clone(this, R.layout.activity_key_frame_animation)
58 |
59 | val transition = ChangeBounds()
60 | transition.interpolator = AnticipateOvershootInterpolator(1.0f)
61 | transition.duration = 1200
62 |
63 | TransitionManager.beginDelayedTransition(constraint, transition)
64 |
65 | constraintSet.applyTo(constraint)
66 | }
67 | }
--------------------------------------------------------------------------------
/app/src/main/java/com/keyframeanimationdemo/activity/keyframeanimation/ShoppingKeyFrameAnimation.kt:
--------------------------------------------------------------------------------
1 | package com.keyframeanimationdemo.activity.keyframeanimation
2 |
3 | import android.annotation.SuppressLint
4 | import android.content.Context
5 | import android.content.Intent
6 | import android.os.Bundle
7 | import android.support.annotation.LayoutRes
8 | import android.support.constraint.ConstraintSet
9 | import android.support.transition.ChangeBounds
10 | import android.support.transition.TransitionManager
11 | import android.support.v7.app.AppCompatActivity
12 | import android.view.animation.OvershootInterpolator
13 | import com.keyframeanimationdemo.R
14 | import kotlinx.android.synthetic.main.layout_shopping_activity_select_size.*
15 |
16 |
17 | class ShoppingKeyFrameAnimation : AppCompatActivity() {
18 |
19 | /**
20 | * Call this method to launch the activity.
21 | */
22 | companion object {
23 | fun launchActivity(context: Context) {
24 | val intent = Intent(context, ShoppingKeyFrameAnimation::class.java)
25 | context.startActivity(intent)
26 | }
27 | }
28 |
29 | override fun onCreate(savedInstanceState: Bundle?) {
30 | super.onCreate(savedInstanceState)
31 | setContentView(R.layout.activity_shopping_key_frame_animation)
32 | setupAnimations()
33 | }
34 |
35 | @SuppressLint("SetTextI18n")
36 | private fun setupAnimations() {
37 | var show = false
38 | btn_add_to_bag.setOnClickListener {
39 | show = if (show) {
40 | updateConstraints(R.layout.layout_shopping_activity_invisble_size)
41 | btn_add_to_bag.text = resources.getString(R.string.add_to_bag) + " $125"
42 | false
43 | } else {
44 | updateConstraints(R.layout.layout_shopping_activity_select_size)
45 | btn_add_to_bag.text = "SELECT SIZE"
46 | true
47 | }
48 | }
49 | }
50 |
51 | private fun updateConstraints(@LayoutRes id: Int) {
52 | val newConstraintSet = ConstraintSet()
53 | newConstraintSet.clone(this, id)
54 | newConstraintSet.applyTo(shopping_cc)
55 | val transition = ChangeBounds()
56 | transition.interpolator = OvershootInterpolator()
57 | transition.duration = 1200
58 | TransitionManager.beginDelayedTransition(shopping_cc, transition)
59 | }
60 | }
61 |
62 | //inline fun ConstraintLayout.updateParams(constraintSet: ConstraintSet = ConstraintSet(), updates: ConstraintSet.() -> Unit) {
63 | // constraintSet.clone(this)
64 | // constraintSet.updates()
65 | // constraintSet.applyTo(this)
66 | //}
--------------------------------------------------------------------------------
/app/src/main/java/com/keyframeanimationdemo/activity/parallax/ParallaxEffectActivity.kt:
--------------------------------------------------------------------------------
1 | package com.keyframeanimationdemo.activity.parallax
2 |
3 | import android.content.Context
4 | import android.content.Intent
5 | import android.os.Bundle
6 | import android.support.constraint.ConstraintLayout
7 | import android.support.constraint.Guideline
8 | import android.support.v7.app.AppCompatActivity
9 | import android.support.v7.widget.LinearLayoutManager
10 | import android.support.v7.widget.PagerSnapHelper
11 | import android.support.v7.widget.RecyclerView
12 | import android.view.WindowManager
13 | import com.keyframeanimationdemo.R
14 | import com.keyframeanimationdemo.adapter.Adapter
15 | import kotlinx.android.synthetic.main.activity_parallax_effect.*
16 |
17 |
18 | class ParallaxEffectActivity : AppCompatActivity() {
19 |
20 | /**
21 | * Call this method to launch the activity.
22 | */
23 | companion object {
24 | fun launchActivity(context: Context) {
25 | val intent = Intent(context, ParallaxEffectActivity::class.java)
26 | context.startActivity(intent)
27 | }
28 | }
29 |
30 | override fun onCreate(savedInstanceState: Bundle?) {
31 | super.onCreate(savedInstanceState)
32 | setContentView(R.layout.activity_parallax_effect)
33 | setFullScreen()
34 |
35 | val images = arrayOf(R.drawable.one_bg, R.drawable.two_bg, R.drawable.three_bg, R.drawable.fourth_bg, R.drawable.fifth_bg)
36 |
37 | val layoutManager = LinearLayoutManager(this, LinearLayoutManager.HORIZONTAL, false)
38 |
39 | val snapHelper = PagerSnapHelper()
40 | snapHelper.attachToRecyclerView(recycler_view)
41 |
42 | recycler_view.layoutManager = layoutManager
43 | recycler_view.adapter = Adapter(this, images)
44 |
45 | recycler_view.addOnScrollListener(object : RecyclerView.OnScrollListener() {
46 | override fun onScrolled(recyclerView: RecyclerView?, dx: Int, dy: Int) {
47 | super.onScrolled(recyclerView, dx, dy)
48 | val manager = recyclerView!!.layoutManager as LinearLayoutManager
49 | val position = manager.findFirstVisibleItemPosition()
50 | val lastPosition = manager.findLastVisibleItemPosition()
51 | val offSet = recyclerView.computeHorizontalScrollOffset()
52 | for (i in 0..lastPosition - position) {
53 | val layout = manager.findViewByPosition(position + i) as ConstraintLayout
54 | val guideline = layout.findViewById(R.id.guideline2)
55 | val params = guideline.layoutParams as ConstraintLayout.LayoutParams
56 | val w = recyclerView.width
57 | val deltaPos = offSet - (position + i) * w
58 | val percent = deltaPos / w.toFloat()
59 | params.guidePercent = Math.max(0.3f, Math.min(0.7f, 0.5f - percent))
60 | guideline.layoutParams = params
61 | }
62 | }
63 | })
64 | }
65 |
66 | private fun setFullScreen() {
67 | window.setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN)
68 | }
69 | }
--------------------------------------------------------------------------------
/app/src/main/java/com/keyframeanimationdemo/adapter/Adapter.kt:
--------------------------------------------------------------------------------
1 | package com.keyframeanimationdemo.adapter
2 |
3 | import android.content.Context
4 | import android.support.v4.content.ContextCompat
5 | import android.support.v7.widget.RecyclerView
6 | import android.view.LayoutInflater
7 | import android.view.View
8 | import android.view.ViewGroup
9 | import com.keyframeanimationdemo.R
10 | import kotlinx.android.synthetic.main.item_parallax_layout.view.*
11 |
12 | /**
13 | * Created by Bhavik Makwana on 30-03-2018.
14 | */
15 | class Adapter(context: Context, images: Array) : RecyclerView.Adapter() {
16 |
17 | private var mImages: Array
18 | private var mContext: Context? = null
19 |
20 | init {
21 | mContext = context
22 | mImages = images
23 |
24 | }
25 |
26 | override fun getItemCount(): Int {
27 | return 5
28 | }
29 |
30 | override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
31 | return ViewHolder(LayoutInflater.from(parent.context).inflate(R.layout.item_parallax_layout, parent, false))
32 | }
33 |
34 | override fun onBindViewHolder(holder: ViewHolder, position: Int) {
35 | val image = mImages[position]
36 | holder.imageView.setImageDrawable(ContextCompat.getDrawable(this.mContext!!, image))
37 | }
38 |
39 | inner class ViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
40 | var imageView = itemView.iv_background_chip!!
41 | }
42 | }
--------------------------------------------------------------------------------
/app/src/main/java/com/keyframeanimationdemo/utils/AnimationHelper.kt:
--------------------------------------------------------------------------------
1 | package com.keyframeanimationdemo.utils
2 |
3 | import android.animation.ObjectAnimator
4 | import android.view.View
5 |
6 | class AnimationHelper(view: View) {
7 | private var initialValue = 0
8 | private var target = view
9 |
10 | init {
11 | initialValue = target.top
12 | }
13 |
14 | fun evaluate() {
15 | if (initialValue != target.top) {
16 | val delta = (initialValue - target.top).toFloat()
17 | val anim = ObjectAnimator.ofFloat(target, "translationX", delta, 0f)
18 | anim.duration = 400
19 | anim.start()
20 | initialValue = target.top
21 | }
22 | }
23 | }
--------------------------------------------------------------------------------
/app/src/main/java/com/keyframeanimationdemo/utils/CollapsibleConstraintLayout.kt:
--------------------------------------------------------------------------------
1 | package com.keyframeanimationdemo.utils
2 |
3 | import android.animation.Animator
4 | import android.animation.ObjectAnimator
5 | import android.content.Context
6 | import android.support.constraint.ConstraintLayout
7 | import android.support.constraint.ConstraintSet
8 | import android.support.design.widget.AppBarLayout
9 | import android.util.AttributeSet
10 | import android.view.View
11 | import android.widget.ImageView
12 | import android.widget.TextView
13 | import com.keyframeanimationdemo.R
14 |
15 | /**
16 | * Created by Bhavik Makwana on 13-03-2018.
17 | */
18 |
19 | class CollapsibleConstraintLayout : ConstraintLayout, AppBarLayout.OnOffsetChangedListener {
20 |
21 | constructor(context: Context) : this(context, null)
22 | constructor(context: Context, attrs: AttributeSet?) : this(context, attrs, 0)
23 | constructor(context: Context, attrs: AttributeSet?, defStyleAttribute: Int) : super(context, attrs, defStyleAttribute)
24 |
25 |
26 | private var mTransitionThreshold = 0.35f
27 | private var mLastPosition: Int = 0
28 | private var mToolBarOpen = true
29 |
30 | private val mOpenToolBarSet: ConstraintSet = ConstraintSet()
31 | private val mCloseToolBarSet: ConstraintSet = ConstraintSet()
32 | private var mBackground: ImageView? = null
33 | private var mTitle: TextView? = null
34 | private var mIcon: ImageView? = null
35 | private var mTranslationTitle: AnimationHelper? = null
36 | private var mTranslationIcon: AnimationHelper? = null
37 | private var showImageAnimator: Animator? = null
38 | private var hideImageAnimator: Animator? = null
39 |
40 | override fun onAttachedToWindow() {
41 | super.onAttachedToWindow()
42 | if (parent is AppBarLayout) {
43 | val appBarLayout = parent as AppBarLayout
44 | appBarLayout.addOnOffsetChangedListener(this)
45 | mOpenToolBarSet.clone(context, R.layout.toolbar_layout)
46 | mCloseToolBarSet.clone(context, R.layout.layout_closed_toolbar)
47 |
48 | mBackground = findViewById(R.id.iv_product_image)
49 | mTitle = findViewById(R.id.tv_title)
50 | mIcon = findViewById(R.id.iv_icon)
51 | showImageAnimator = ObjectAnimator.ofFloat(mBackground, "alpha", 0f, 1f)
52 | showImageAnimator?.duration = 600
53 | hideImageAnimator = ObjectAnimator.ofFloat(mBackground, "alpha", 1f, 0f)
54 | hideImageAnimator?.duration = 600
55 | }
56 | }
57 |
58 | override fun onOffsetChanged(appBarLayout: AppBarLayout?, verticalOffset: Int) {
59 | if (mLastPosition == verticalOffset) {
60 | return
61 | }
62 | mLastPosition = verticalOffset
63 | val progress = Math.abs(verticalOffset / appBarLayout?.height?.toFloat()!!)
64 |
65 | val params = layoutParams as AppBarLayout.LayoutParams
66 | params.topMargin = -verticalOffset
67 | layoutParams = params
68 |
69 | if (mToolBarOpen && progress > mTransitionThreshold) {
70 | mCloseToolBarSet.applyTo(this)
71 | hideImageAnimator?.start()
72 | mToolBarOpen = false
73 | } else if (!mToolBarOpen && progress < mTransitionThreshold) {
74 | mOpenToolBarSet.applyTo(this)
75 | showImageAnimator?.start()
76 | mToolBarOpen = true
77 | }
78 | }
79 |
80 | override fun onLayout(changed: Boolean, left: Int, top: Int, right: Int, bottom: Int) {
81 | super.onLayout(changed, left, top, right, bottom)
82 | if (mTitle != null && mTranslationTitle == null) {
83 | mTranslationTitle = AnimationHelper(mTitle!!)
84 | }
85 | if (mIcon != null && mTranslationIcon == null) {
86 | mTranslationIcon = AnimationHelper(mIcon!!)
87 | }
88 | mTranslationTitle?.evaluate()
89 | mTranslationIcon?.evaluate()
90 | }
91 |
92 | class AnimationHelper(view: View) {
93 | private var initialValue = 0
94 | private var target = view
95 |
96 | init {
97 | initialValue = target.left
98 | }
99 |
100 | fun evaluate() {
101 | if (initialValue != target.left) {
102 | val delta = (initialValue - target.left).toFloat()
103 | val anim = ObjectAnimator.ofFloat(target, "translationX", delta, 0f)
104 | anim.duration = 400
105 | anim.start()
106 | initialValue = target.left
107 | }
108 | }
109 | }
110 | }
--------------------------------------------------------------------------------
/app/src/main/java/com/keyframeanimationdemo/utils/NestedConstraintLayout.kt:
--------------------------------------------------------------------------------
1 | package com.keyframeanimationdemo.utils
2 |
3 | import android.annotation.SuppressLint
4 | import android.content.Context
5 | import android.support.annotation.LayoutRes
6 | import android.support.constraint.ConstraintLayout
7 | import android.support.constraint.ConstraintSet
8 | import android.util.AttributeSet
9 | import android.widget.Button
10 | import android.widget.ImageView
11 | import android.widget.TextView
12 | import com.keyframeanimationdemo.R
13 |
14 | /**
15 | * Created by Bhavik Makwana on 19-04-2018.
16 | */
17 | class NestedConstraintLayout : ConstraintLayout {
18 | constructor(context: Context) : this(context, null)
19 | constructor(context: Context, attrs: AttributeSet?) : this(context, attrs, 0)
20 | constructor(context: Context, attrs: AttributeSet?, defStyleAttribute: Int) : super(context, attrs, defStyleAttribute)
21 |
22 | private val mHideSet: ConstraintSet = ConstraintSet()
23 | private val mShowSet: ConstraintSet = ConstraintSet()
24 | private var mBtnAddToBag: Button? = null
25 |
26 |
27 | private var mProductImage: ImageView? = null
28 | private var mProductName: TextView? = null
29 | private var mProductDesc: TextView? = null
30 | private var mSelectSize: TextView? = null
31 | private var mSize: Button? = null
32 |
33 | private var mTranslationProductImage: AnimationHelper? = null
34 | private var mTranslationProductName: AnimationHelper? = null
35 | private var mTranslationProductDesc: AnimationHelper? = null
36 | private var mTranslationSelecteSize: AnimationHelper? = null
37 | private var mTranslationSize: AnimationHelper? = null
38 |
39 |
40 | override fun onAttachedToWindow() {
41 | super.onAttachedToWindow()
42 | mHideSet.clone(context, R.layout.layout_shopping_activity_invisble_size)
43 | mShowSet.clone(context, R.layout.layout_shopping_activity_select_size)
44 | mBtnAddToBag = findViewById(R.id.btn_add_to_bag)
45 | mProductImage = findViewById(R.id.iv_product_image)
46 | mProductName = findViewById(R.id.tv_product_name)
47 | mProductDesc = findViewById(R.id.tv_product_desc)
48 | mSelectSize = findViewById(R.id.tv_select_size)
49 | mSize = findViewById(R.id.size)
50 |
51 | setupAnimations()
52 | }
53 |
54 |
55 | @SuppressLint("SetTextI18n")
56 | private fun setupAnimations() {
57 | var show = false
58 | mBtnAddToBag?.setOnClickListener {
59 | show = if (show) {
60 | updateConstraints(R.layout.activity_shopping_key_frame_animation)
61 | mBtnAddToBag?.text = resources.getString(R.string.add_to_bag) + " $125"
62 | false
63 | } else {
64 | updateConstraints(R.layout.layout_shopping_activity_select_size)
65 | mBtnAddToBag?.text = "SELECT SIZE"
66 | true
67 | }
68 | }
69 | }
70 |
71 | private fun updateConstraints(@LayoutRes id: Int) {
72 | // val newConstraintSet = ConstraintSet()
73 | // newConstraintSet.clone(context, id)
74 | // newConstraintSet.applyTo(shopping_cc)
75 | // val transition = ChangeBounds()
76 | // transition.interpolator = OvershootInterpolator()
77 | // transition.duration = 1200
78 | // TransitionManager.beginDelayedTransition(shopping_cc, transition)
79 |
80 | if (mProductImage != null && mTranslationProductImage == null) {
81 | mTranslationProductImage = AnimationHelper(mProductImage!!)
82 | }
83 | if (mProductName != null && mTranslationProductName == null) {
84 | mTranslationProductName = AnimationHelper(mProductName!!)
85 | }
86 | if (mProductDesc != null && mTranslationProductDesc == null) {
87 | mTranslationProductDesc = AnimationHelper(mProductDesc!!)
88 | }
89 | if (mSelectSize != null && mTranslationSelecteSize == null) {
90 | mTranslationSelecteSize = AnimationHelper(mSelectSize!!)
91 | }
92 | if (mSize != null && mTranslationSize == null) {
93 | mTranslationSize = AnimationHelper(mSize!!)
94 | }
95 |
96 | mTranslationProductImage?.evaluate()
97 | mTranslationProductName?.evaluate()
98 | mTranslationProductDesc?.evaluate()
99 | mTranslationSelecteSize?.evaluate()
100 | mTranslationSize?.evaluate()
101 | }
102 | }
--------------------------------------------------------------------------------
/app/src/main/res/drawable-v24/ic_launcher_foreground.xml:
--------------------------------------------------------------------------------
1 |
7 |
12 |
13 |
19 |
22 |
25 |
26 |
27 |
28 |
34 |
35 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/background.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/background.webp
--------------------------------------------------------------------------------
/app/src/main/res/drawable/background_image.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/background_image.jpg
--------------------------------------------------------------------------------
/app/src/main/res/drawable/blue_button.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 | -
4 |
5 |
6 |
7 |
8 |
9 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/broken_glass.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/broken_glass.png
--------------------------------------------------------------------------------
/app/src/main/res/drawable/button_background.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
7 |
8 |
11 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/button_bg.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 | -
4 |
5 |
7 |
8 |
9 |
10 |
11 | -
12 |
13 |
15 |
16 |
17 |
18 |
19 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/chip_background.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/chip_background.png
--------------------------------------------------------------------------------
/app/src/main/res/drawable/earth.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/earth.png
--------------------------------------------------------------------------------
/app/src/main/res/drawable/edit_text_background.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
7 |
8 |
13 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/fifth_bg.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/fifth_bg.jpg
--------------------------------------------------------------------------------
/app/src/main/res/drawable/fourth_bg.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/fourth_bg.jpg
--------------------------------------------------------------------------------
/app/src/main/res/drawable/gradient.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
10 |
11 |
12 |
13 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/ic_add_24dp.xml:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/ic_close_24dp.xml:
--------------------------------------------------------------------------------
1 |
7 |
10 |
11 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/ic_format_align_right_white_24dp.xml:
--------------------------------------------------------------------------------
1 |
7 |
10 |
11 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/ic_launcher_background.xml:
--------------------------------------------------------------------------------
1 |
2 |
8 |
11 |
16 |
21 |
26 |
31 |
36 |
41 |
46 |
51 |
56 |
61 |
66 |
71 |
76 |
81 |
86 |
91 |
96 |
101 |
106 |
111 |
116 |
121 |
126 |
131 |
136 |
141 |
146 |
151 |
156 |
161 |
166 |
171 |
172 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/ic_notifications_black_24dp.xml:
--------------------------------------------------------------------------------
1 |
6 |
9 |
10 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/ic_remove_24dp.xml:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/ic_search_black_24dp.xml:
--------------------------------------------------------------------------------
1 |
6 |
9 |
10 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/ic_shopping_cart_black_24dp.xml:
--------------------------------------------------------------------------------
1 |
6 |
9 |
10 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/image_top_round_corner.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
7 |
8 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/jordan_ultra.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/jordan_ultra.jpg
--------------------------------------------------------------------------------
/app/src/main/res/drawable/layout_bg.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
7 |
8 |
13 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/mars.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/mars.png
--------------------------------------------------------------------------------
/app/src/main/res/drawable/one_bg.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/one_bg.jpg
--------------------------------------------------------------------------------
/app/src/main/res/drawable/profile_avatar.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/profile_avatar.png
--------------------------------------------------------------------------------
/app/src/main/res/drawable/profile_image.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/profile_image.jpg
--------------------------------------------------------------------------------
/app/src/main/res/drawable/saturn.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/saturn.png
--------------------------------------------------------------------------------
/app/src/main/res/drawable/selected_button_bg.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 | -
4 |
5 |
6 |
7 |
8 |
9 | -
10 |
11 |
12 |
13 |
14 |
15 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable/sun.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/sun.png
--------------------------------------------------------------------------------
/app/src/main/res/drawable/three_bg.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/three_bg.jpg
--------------------------------------------------------------------------------
/app/src/main/res/drawable/two_bg.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/drawable/two_bg.jpg
--------------------------------------------------------------------------------
/app/src/main/res/font/poppins.xml:
--------------------------------------------------------------------------------
1 |
2 |
7 |
8 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/activity_collapsing_toolbar.xml:
--------------------------------------------------------------------------------
1 |
2 |
9 |
10 |
17 |
18 |
19 |
20 |
21 |
22 |
26 |
27 |
33 |
34 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/activity_key_frame_animation.xml:
--------------------------------------------------------------------------------
1 |
2 |
11 |
12 |
22 |
23 |
36 |
37 |
50 |
51 |
57 |
58 |
72 |
73 |
74 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/activity_main.xml:
--------------------------------------------------------------------------------
1 |
2 |
10 |
11 |
15 |
16 |
23 |
24 |
32 |
33 |
41 |
42 |
50 |
51 |
59 |
60 |
68 |
69 |
77 |
78 |
86 |
87 |
95 |
96 |
104 |
105 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/activity_orbits.xml:
--------------------------------------------------------------------------------
1 |
2 |
11 |
12 |
21 |
22 |
30 |
31 |
39 |
40 |
48 |
49 |
55 |
56 |
62 |
63 |
69 |
70 |
76 |
77 |
83 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/activity_parallax_effect.xml:
--------------------------------------------------------------------------------
1 |
2 |
10 |
11 |
19 |
20 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/activity_shopping_key_frame_animation.xml:
--------------------------------------------------------------------------------
1 |
2 |
10 |
11 |
22 |
23 |
24 |
25 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/detail.xml:
--------------------------------------------------------------------------------
1 |
2 |
10 |
11 |
21 |
22 |
35 |
36 |
49 |
50 |
56 |
57 |
71 |
72 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/item_parallax_layout.xml:
--------------------------------------------------------------------------------
1 |
2 |
7 |
8 |
21 |
22 |
25 |
26 |
32 |
33 |
42 |
43 |
53 |
54 |
63 |
64 |
65 |
66 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/layout_closed_toolbar.xml:
--------------------------------------------------------------------------------
1 |
2 |
9 |
10 |
21 |
22 |
39 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/layout_orbits_details.xml:
--------------------------------------------------------------------------------
1 |
2 |
11 |
12 |
18 |
19 |
27 |
28 |
37 |
38 |
47 |
48 |
57 |
58 |
67 |
68 |
77 |
78 |
87 |
88 |
97 |
98 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/layout_shopping_activity_invisble_size.xml:
--------------------------------------------------------------------------------
1 |
2 |
8 |
9 |
19 |
20 |
33 |
34 |
46 |
47 |
57 |
58 |
69 |
70 |
82 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/layout_shopping_activity_select_size.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
9 |
10 |
19 |
20 |
33 |
34 |
46 |
47 |
58 |
59 |
70 |
71 |
83 |
84 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/second_activity_layout_swipe_up.xml:
--------------------------------------------------------------------------------
1 |
2 |
8 |
9 |
15 |
16 |
24 |
25 |
33 |
34 |
43 |
44 |
52 |
53 |
62 |
63 |
71 |
72 |
81 |
82 |
90 |
91 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/toolbar_layout.xml:
--------------------------------------------------------------------------------
1 |
2 |
13 |
14 |
26 |
27 |
37 |
38 |
52 |
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-hdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/mipmap-hdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-hdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/mipmap-hdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-mdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/mipmap-mdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-mdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/mipmap-mdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/mipmap-xhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/values/colors.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 | #3F51B5
4 | #303F9F
5 | #FF4081
6 |
7 |
--------------------------------------------------------------------------------
/app/src/main/res/values/dimens.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 | 4dp
4 | 16dp
5 | 12sp
6 | 24dp
7 | 48sp
8 | 24sp
9 | 8dp
10 | 30dp
11 |
--------------------------------------------------------------------------------
/app/src/main/res/values/font_certs.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | - @array/com_google_android_gms_fonts_certs_dev
5 | - @array/com_google_android_gms_fonts_certs_prod
6 |
7 |
8 | -
9 | MIIEqDCCA5CgAwIBAgIJANWFuGx90071MA0GCSqGSIb3DQEBBAUAMIGUMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEWMBQGA1UEBxMNTW91bnRhaW4gVmlldzEQMA4GA1UEChMHQW5kcm9pZDEQMA4GA1UECxMHQW5kcm9pZDEQMA4GA1UEAxMHQW5kcm9pZDEiMCAGCSqGSIb3DQEJARYTYW5kcm9pZEBhbmRyb2lkLmNvbTAeFw0wODA0MTUyMzM2NTZaFw0zNTA5MDEyMzM2NTZaMIGUMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEWMBQGA1UEBxMNTW91bnRhaW4gVmlldzEQMA4GA1UEChMHQW5kcm9pZDEQMA4GA1UECxMHQW5kcm9pZDEQMA4GA1UEAxMHQW5kcm9pZDEiMCAGCSqGSIb3DQEJARYTYW5kcm9pZEBhbmRyb2lkLmNvbTCCASAwDQYJKoZIhvcNAQEBBQADggENADCCAQgCggEBANbOLggKv+IxTdGNs8/TGFy0PTP6DHThvbbR24kT9ixcOd9W+EaBPWW+wPPKQmsHxajtWjmQwWfna8mZuSeJS48LIgAZlKkpFeVyxW0qMBujb8X8ETrWy550NaFtI6t9+u7hZeTfHwqNvacKhp1RbE6dBRGWynwMVX8XW8N1+UjFaq6GCJukT4qmpN2afb8sCjUigq0GuMwYXrFVee74bQgLHWGJwPmvmLHC69EH6kWr22ijx4OKXlSIx2xT1AsSHee70w5iDBiK4aph27yH3TxkXy9V89TDdexAcKk/cVHYNnDBapcavl7y0RiQ4biu8ymM8Ga/nmzhRKya6G0cGw8CAQOjgfwwgfkwHQYDVR0OBBYEFI0cxb6VTEM8YYY6FbBMvAPyT+CyMIHJBgNVHSMEgcEwgb6AFI0cxb6VTEM8YYY6FbBMvAPyT+CyoYGapIGXMIGUMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEWMBQGA1UEBxMNTW91bnRhaW4gVmlldzEQMA4GA1UEChMHQW5kcm9pZDEQMA4GA1UECxMHQW5kcm9pZDEQMA4GA1UEAxMHQW5kcm9pZDEiMCAGCSqGSIb3DQEJARYTYW5kcm9pZEBhbmRyb2lkLmNvbYIJANWFuGx90071MAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEEBQADggEBABnTDPEF+3iSP0wNfdIjIz1AlnrPzgAIHVvXxunW7SBrDhEglQZBbKJEk5kT0mtKoOD1JMrSu1xuTKEBahWRbqHsXclaXjoBADb0kkjVEJu/Lh5hgYZnOjvlba8Ld7HCKePCVePoTJBdI4fvugnL8TsgK05aIskyY0hKI9L8KfqfGTl1lzOv2KoWD0KWwtAWPoGChZxmQ+nBli+gwYMzM1vAkP+aayLe0a1EQimlOalO762r0GXO0ks+UeXde2Z4e+8S/pf7pITEI/tP+MxJTALw9QUWEv9lKTk+jkbqxbsh8nfBUapfKqYn0eidpwq2AzVp3juYl7//fKnaPhJD9gs=
10 |
11 |
12 |
13 | -
14 | MIIEQzCCAyugAwIBAgIJAMLgh0ZkSjCNMA0GCSqGSIb3DQEBBAUAMHQxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRYwFAYDVQQHEw1Nb3VudGFpbiBWaWV3MRQwEgYDVQQKEwtHb29nbGUgSW5jLjEQMA4GA1UECxMHQW5kcm9pZDEQMA4GA1UEAxMHQW5kcm9pZDAeFw0wODA4MjEyMzEzMzRaFw0zNjAxMDcyMzEzMzRaMHQxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRYwFAYDVQQHEw1Nb3VudGFpbiBWaWV3MRQwEgYDVQQKEwtHb29nbGUgSW5jLjEQMA4GA1UECxMHQW5kcm9pZDEQMA4GA1UEAxMHQW5kcm9pZDCCASAwDQYJKoZIhvcNAQEBBQADggENADCCAQgCggEBAKtWLgDYO6IIrgqWbxJOKdoR8qtW0I9Y4sypEwPpt1TTcvZApxsdyxMJZ2JORland2qSGT2y5b+3JKkedxiLDmpHpDsz2WCbdxgxRczfey5YZnTJ4VZbH0xqWVW/8lGmPav5xVwnIiJS6HXk+BVKZF+JcWjAsb/GEuq/eFdpuzSqeYTcfi6idkyugwfYwXFU1+5fZKUaRKYCwkkFQVfcAs1fXA5V+++FGfvjJ/CxURaSxaBvGdGDhfXE28LWuT9ozCl5xw4Yq5OGazvV24mZVSoOO0yZ31j7kYvtwYK6NeADwbSxDdJEqO4k//0zOHKrUiGYXtqw/A0LFFtqoZKFjnkCAQOjgdkwgdYwHQYDVR0OBBYEFMd9jMIhF1Ylmn/Tgt9r45jk14alMIGmBgNVHSMEgZ4wgZuAFMd9jMIhF1Ylmn/Tgt9r45jk14aloXikdjB0MQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEWMBQGA1UEBxMNTW91bnRhaW4gVmlldzEUMBIGA1UEChMLR29vZ2xlIEluYy4xEDAOBgNVBAsTB0FuZHJvaWQxEDAOBgNVBAMTB0FuZHJvaWSCCQDC4IdGZEowjTAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBBAUAA4IBAQBt0lLO74UwLDYKqs6Tm8/yzKkEu116FmH4rkaymUIE0P9KaMftGlMexFlaYjzmB2OxZyl6euNXEsQH8gjwyxCUKRJNexBiGcCEyj6z+a1fuHHvkiaai+KL8W1EyNmgjmyy8AW7P+LLlkR+ho5zEHatRbM/YAnqGcFh5iZBqpknHf1SKMXFh4dd239FJ1jWYfbMDMy3NS5CTMQ2XFI1MvcyUTdZPErjQfTbQe3aDQsQcafEQPD+nqActifKZ0Np0IS9L9kR/wbNvyz6ENwPiTrjV2KRkEjH78ZMcUQXg0L3BYHJ3lc69Vs5Ddf9uUGGMYldX3WfMBEmh/9iFBDAaTCK
15 |
16 |
17 |
18 |
--------------------------------------------------------------------------------
/app/src/main/res/values/preloaded_fonts.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | - @font/poppins
5 |
6 |
7 |
--------------------------------------------------------------------------------
/app/src/main/res/values/strings.xml:
--------------------------------------------------------------------------------
1 |
2 | Animations
3 | Orion M42
4 | Bryan Goff on Unsplash
5 | The Orion Nebula, or M42, is one of the brigtest nebula from earth. With the naked eye you can sometimes see orion as the middle star in the \"sword\" of the Orion constelation.
6 | Next
7 | Click Here
8 | Key Frame Animation 1
9 | Key Frame Animation 2
10 | Search
11 | JORDAN ULTRA
12 | men\'s basketball shoe
13 | Select Size
14 | Add to bag
15 | Collapsing Toolbar
16 |
17 | Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vivamus malesuada, nisl eu rutrum ullamcorper, metus justo vehicula velit, non scelerisque leo ex at ex. Mauris fringilla facilisis neque, quis sodales dui. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi dapibus consequat fermentum. Proin fringilla scelerisque nunc, ac gravida turpis volutpat et. In hac habitasse platea dictumst. Etiam rutrum laoreet mauris vitae scelerisque. Curabitur nisl odio, pharetra a porta nec, rhoncus et sapien. Praesent at sapien eu risus ullamcorper lobortis quis at nunc.
18 |
19 | Fusce dolor tellus, aliquet sit amet est sit amet, interdum volutpat ipsum. Ut sagittis lorem erat, vel porta urna dignissim quis. Quisque elementum, orci non vestibulum tincidunt, dolor lectus laoreet dolor, ut ultrices massa quam id lorem. Vivamus mauris mi, auctor non orci vitae, aliquam vulputate urna. Phasellus volutpat sollicitudin sapien, ut iaculis leo tristique eget. Morbi accumsan sed tellus tempor maximus. Praesent malesuada ac mauris sit amet facilisis. Donec venenatis ipsum et orci tempus volutpat. In tincidunt sapien nec turpis congue, a semper dolor cursus. Nam vestibulum, tellus vel maximus eleifend, erat purus eleifend est, sit amet egestas elit mauris eu ligula. Integer ipsum urna, viverra ac velit vel, viverra malesuada lorem. Integer elementum rutrum venenatis. Duis consequat tellus eget sem facilisis, a fermentum tortor mattis. Curabitur mattis augue a augue tempus, congue convallis nibh congue. Proin lacinia, urna ac semper porta, augue augue euismod est, eu ultricies elit ex vitae dui. Pellentesque ac velit vel urna tempor posuere.
20 |
21 | Nullam ut nulla ac metus consequat auctor et arcu. Cras ullamcorper, dolor nec aliquet placerat, nisl arcu posuere purus, gravida condimentum arcu nibh sit amet est. Suspendisse at leo leo. Vestibulum eu turpis lacus. Cras ut ullamcorper mauris. Sed mattis, ante accumsan sodales ultricies, tortor lacus vehicula augue, at congue lacus metus sed ipsum. Ut nec fermentum justo, id laoreet leo. Phasellus rutrum enim et augue luctus auctor. Nulla sed elementum mauris, in condimentum ipsum. Donec condimentum accumsan nisl in interdum. Suspendisse vel commodo nunc. In dapibus ut sapien id bibendum. In eu maximus augue. Pellentesque dignissim accumsan consectetur. Fusce sit amet tempor sem. Morbi facilisis, ligula vitae dictum dapibus, turpis sapien elementum diam, id ornare magna nulla vitae purus.
22 |
23 | Donec vel urna mauris. Aliquam viverra non sapien at interdum. Curabitur tincidunt erat ac egestas elementum. Nam volutpat elit eget lorem eleifend, sed tempus nunc condimentum. Phasellus non ipsum euismod nulla pellentesque viverra in at mauris. Sed tincidunt massa a rhoncus elementum. Phasellus pellentesque nisl et nulla ultrices vestibulum.
24 |
25 | Integer feugiat ultricies ligula a venenatis. Phasellus nec faucibus justo. Duis iaculis odio ut lacus posuere egestas. Cras maximus nulla sem, ut faucibus dolor dapibus at. Quisque nunc mi, vestibulum nec tempor vitae, lobortis vel libero. Etiam maximus tortor quis lorem convallis porta porta vel quam. Vestibulum gravida lorem vitae magna placerat, quis pharetra odio aliquet. Nunc id justo fringilla, pretium nibh ac, venenatis neque.
26 |
27 | Parallax Effect
28 | An Interesting title
29 | Various relevant and insightful information
30 | M
31 |
32 | Lorem ipsum dolor sit amet, consectetuer adipiscing elit.
33 | Donec odio.
34 | Quisque volutpat mattis eros.
35 | Nullam malesuada erat ut turpis.
36 | Suspendisse urna nibh, viverra non, semper suscipit, posuere a, pede.
37 |
38 | Circular Positioning
39 |
40 |
--------------------------------------------------------------------------------
/app/src/main/res/values/styles.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
10 |
11 |
20 |
21 |
22 |
23 |
27 |
--------------------------------------------------------------------------------
/app/src/test/java/com/keyframeanimationdemo/ExampleUnitTest.kt:
--------------------------------------------------------------------------------
1 | package com.keyframeanimationdemo
2 |
3 | import org.junit.Test
4 |
5 | import org.junit.Assert.*
6 |
7 | /**
8 | * Example local unit test, which will execute on the development machine (host).
9 | *
10 | * See [testing documentation](http://d.android.com/tools/testing).
11 | */
12 | class ExampleUnitTest {
13 | @Test
14 | fun addition_isCorrect() {
15 | assertEquals(4, 2 + 2)
16 | }
17 | }
18 |
--------------------------------------------------------------------------------
/build.gradle:
--------------------------------------------------------------------------------
1 | // Top-level build file where you can add configuration options common to all sub-projects/modules.
2 |
3 | buildscript {
4 | ext.kotlin_version = '1.2.40'
5 | repositories {
6 | google()
7 | jcenter()
8 | }
9 | dependencies {
10 | classpath 'com.android.tools.build:gradle:3.1.1'
11 | classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
12 |
13 | // NOTE: Do not place your application dependencies here; they belong
14 | // in the individual module build.gradle files
15 | }
16 | }
17 |
18 | allprojects {
19 | repositories {
20 | google()
21 | jcenter()
22 | }
23 | }
24 |
25 | task clean(type: Delete) {
26 | delete rootProject.buildDir
27 | }
28 |
--------------------------------------------------------------------------------
/gif/Circular_Positioning.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/gif/Circular_Positioning.gif
--------------------------------------------------------------------------------
/gif/ShoppingKeyframeAnimation.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/gif/ShoppingKeyframeAnimation.gif
--------------------------------------------------------------------------------
/gif/collapsing toolbar.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/gif/collapsing toolbar.gif
--------------------------------------------------------------------------------
/gif/parallax_effect.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/gif/parallax_effect.gif
--------------------------------------------------------------------------------
/gif/shoopin_key_frame_animation.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/gif/shoopin_key_frame_animation.gif
--------------------------------------------------------------------------------
/gradle.properties:
--------------------------------------------------------------------------------
1 | # Project-wide Gradle settings.
2 | # IDE (e.g. Android Studio) users:
3 | # Gradle settings configured through the IDE *will override*
4 | # any settings specified in this file.
5 | # For more details on how to configure your build environment visit
6 | # http://www.gradle.org/docs/current/userguide/build_environment.html
7 | # Specifies the JVM arguments used for the daemon process.
8 | # The setting is particularly useful for tweaking memory settings.
9 | org.gradle.jvmargs=-Xmx1536m
10 | # When configured, Gradle will run in incubating parallel mode.
11 | # This option should only be used with decoupled projects. More details, visit
12 | # http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
13 | # org.gradle.parallel=true
14 |
--------------------------------------------------------------------------------
/gradle/wrapper/gradle-wrapper.jar:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/gradle/wrapper/gradle-wrapper.jar
--------------------------------------------------------------------------------
/gradle/wrapper/gradle-wrapper.properties:
--------------------------------------------------------------------------------
1 | #Mon Apr 02 17:22:24 IST 2018
2 | distributionBase=GRADLE_USER_HOME
3 | distributionPath=wrapper/dists
4 | zipStoreBase=GRADLE_USER_HOME
5 | zipStorePath=wrapper/dists
6 | distributionUrl=https\://services.gradle.org/distributions/gradle-4.4-all.zip
7 |
--------------------------------------------------------------------------------
/gradlew:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env bash
2 |
3 | ##############################################################################
4 | ##
5 | ## Gradle start up script for UN*X
6 | ##
7 | ##############################################################################
8 |
9 | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
10 | DEFAULT_JVM_OPTS=""
11 |
12 | APP_NAME="Gradle"
13 | APP_BASE_NAME=`basename "$0"`
14 |
15 | # Use the maximum available, or set MAX_FD != -1 to use that value.
16 | MAX_FD="maximum"
17 |
18 | warn ( ) {
19 | echo "$*"
20 | }
21 |
22 | die ( ) {
23 | echo
24 | echo "$*"
25 | echo
26 | exit 1
27 | }
28 |
29 | # OS specific support (must be 'true' or 'false').
30 | cygwin=false
31 | msys=false
32 | darwin=false
33 | case "`uname`" in
34 | CYGWIN* )
35 | cygwin=true
36 | ;;
37 | Darwin* )
38 | darwin=true
39 | ;;
40 | MINGW* )
41 | msys=true
42 | ;;
43 | esac
44 |
45 | # Attempt to set APP_HOME
46 | # Resolve links: $0 may be a link
47 | PRG="$0"
48 | # Need this for relative symlinks.
49 | while [ -h "$PRG" ] ; do
50 | ls=`ls -ld "$PRG"`
51 | link=`expr "$ls" : '.*-> \(.*\)$'`
52 | if expr "$link" : '/.*' > /dev/null; then
53 | PRG="$link"
54 | else
55 | PRG=`dirname "$PRG"`"/$link"
56 | fi
57 | done
58 | SAVED="`pwd`"
59 | cd "`dirname \"$PRG\"`/" >/dev/null
60 | APP_HOME="`pwd -P`"
61 | cd "$SAVED" >/dev/null
62 |
63 | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
64 |
65 | # Determine the Java command to use to start the JVM.
66 | if [ -n "$JAVA_HOME" ] ; then
67 | if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
68 | # IBM's JDK on AIX uses strange locations for the executables
69 | JAVACMD="$JAVA_HOME/jre/sh/java"
70 | else
71 | JAVACMD="$JAVA_HOME/bin/java"
72 | fi
73 | if [ ! -x "$JAVACMD" ] ; then
74 | die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
75 |
76 | Please set the JAVA_HOME variable in your environment to match the
77 | location of your Java installation."
78 | fi
79 | else
80 | JAVACMD="java"
81 | which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
82 |
83 | Please set the JAVA_HOME variable in your environment to match the
84 | location of your Java installation."
85 | fi
86 |
87 | # Increase the maximum file descriptors if we can.
88 | if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then
89 | MAX_FD_LIMIT=`ulimit -H -n`
90 | if [ $? -eq 0 ] ; then
91 | if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
92 | MAX_FD="$MAX_FD_LIMIT"
93 | fi
94 | ulimit -n $MAX_FD
95 | if [ $? -ne 0 ] ; then
96 | warn "Could not set maximum file descriptor limit: $MAX_FD"
97 | fi
98 | else
99 | warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
100 | fi
101 | fi
102 |
103 | # For Darwin, add options to specify how the application appears in the dock
104 | if $darwin; then
105 | GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
106 | fi
107 |
108 | # For Cygwin, switch paths to Windows format before running java
109 | if $cygwin ; then
110 | APP_HOME=`cygpath --path --mixed "$APP_HOME"`
111 | CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
112 | JAVACMD=`cygpath --unix "$JAVACMD"`
113 |
114 | # We build the pattern for arguments to be converted via cygpath
115 | ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
116 | SEP=""
117 | for dir in $ROOTDIRSRAW ; do
118 | ROOTDIRS="$ROOTDIRS$SEP$dir"
119 | SEP="|"
120 | done
121 | OURCYGPATTERN="(^($ROOTDIRS))"
122 | # Add a user-defined pattern to the cygpath arguments
123 | if [ "$GRADLE_CYGPATTERN" != "" ] ; then
124 | OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
125 | fi
126 | # Now convert the arguments - kludge to limit ourselves to /bin/sh
127 | i=0
128 | for arg in "$@" ; do
129 | CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
130 | CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
131 |
132 | if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
133 | eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
134 | else
135 | eval `echo args$i`="\"$arg\""
136 | fi
137 | i=$((i+1))
138 | done
139 | case $i in
140 | (0) set -- ;;
141 | (1) set -- "$args0" ;;
142 | (2) set -- "$args0" "$args1" ;;
143 | (3) set -- "$args0" "$args1" "$args2" ;;
144 | (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
145 | (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
146 | (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
147 | (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
148 | (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
149 | (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
150 | esac
151 | fi
152 |
153 | # Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules
154 | function splitJvmOpts() {
155 | JVM_OPTS=("$@")
156 | }
157 | eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS
158 | JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME"
159 |
160 | exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@"
161 |
--------------------------------------------------------------------------------
/gradlew.bat:
--------------------------------------------------------------------------------
1 | @if "%DEBUG%" == "" @echo off
2 | @rem ##########################################################################
3 | @rem
4 | @rem Gradle startup script for Windows
5 | @rem
6 | @rem ##########################################################################
7 |
8 | @rem Set local scope for the variables with windows NT shell
9 | if "%OS%"=="Windows_NT" setlocal
10 |
11 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
12 | set DEFAULT_JVM_OPTS=
13 |
14 | set DIRNAME=%~dp0
15 | if "%DIRNAME%" == "" set DIRNAME=.
16 | set APP_BASE_NAME=%~n0
17 | set APP_HOME=%DIRNAME%
18 |
19 | @rem Find java.exe
20 | if defined JAVA_HOME goto findJavaFromJavaHome
21 |
22 | set JAVA_EXE=java.exe
23 | %JAVA_EXE% -version >NUL 2>&1
24 | if "%ERRORLEVEL%" == "0" goto init
25 |
26 | echo.
27 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
28 | echo.
29 | echo Please set the JAVA_HOME variable in your environment to match the
30 | echo location of your Java installation.
31 |
32 | goto fail
33 |
34 | :findJavaFromJavaHome
35 | set JAVA_HOME=%JAVA_HOME:"=%
36 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe
37 |
38 | if exist "%JAVA_EXE%" goto init
39 |
40 | echo.
41 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
42 | echo.
43 | echo Please set the JAVA_HOME variable in your environment to match the
44 | echo location of your Java installation.
45 |
46 | goto fail
47 |
48 | :init
49 | @rem Get command-line arguments, handling Windowz variants
50 |
51 | if not "%OS%" == "Windows_NT" goto win9xME_args
52 | if "%@eval[2+2]" == "4" goto 4NT_args
53 |
54 | :win9xME_args
55 | @rem Slurp the command line arguments.
56 | set CMD_LINE_ARGS=
57 | set _SKIP=2
58 |
59 | :win9xME_args_slurp
60 | if "x%~1" == "x" goto execute
61 |
62 | set CMD_LINE_ARGS=%*
63 | goto execute
64 |
65 | :4NT_args
66 | @rem Get arguments from the 4NT Shell from JP Software
67 | set CMD_LINE_ARGS=%$
68 |
69 | :execute
70 | @rem Setup the command line
71 |
72 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
73 |
74 | @rem Execute Gradle
75 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
76 |
77 | :end
78 | @rem End local scope for the variables with windows NT shell
79 | if "%ERRORLEVEL%"=="0" goto mainEnd
80 |
81 | :fail
82 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
83 | rem the _cmd.exe /c_ return code!
84 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
85 | exit /b 1
86 |
87 | :mainEnd
88 | if "%OS%"=="Windows_NT" endlocal
89 |
90 | :omega
91 |
--------------------------------------------------------------------------------
/keyframeanimation.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ibhavikmakwana/Constraint-Layout-Animations/6cb008b48ab6256c46796bbc4cf39121b63a7849/keyframeanimation.gif
--------------------------------------------------------------------------------
/settings.gradle:
--------------------------------------------------------------------------------
1 | include ':app'
2 |
--------------------------------------------------------------------------------