From b44ef5004ea1baf926b18f9124cd7ebece2db492 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Thu, 21 Jul 2016 20:21:48 +0800
Subject: [PATCH 01/21] =?UTF-8?q?=E6=B7=BB=E5=8A=A0Animator=E7=BB=83?=
=?UTF-8?q?=E4=B9=A0=E4=BB=A3=E7=A0=81?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
build.gradle | 2 +-
src/main/AndroidManifest.xml | 11 ++-
.../study/activity/AnimatorActivity.java | 76 +++++++++++++++++++
.../clock/study/activity/MainActivity.java | 9 ++-
src/main/res/animator/simple_animator.xml | 18 +++++
src/main/res/layout/activity_animator.xml | 40 ++++++++++
src/main/res/layout/activity_main.xml | 6 ++
src/main/res/values/strings.xml | 3 +
8 files changed, 160 insertions(+), 5 deletions(-)
create mode 100644 src/main/java/com/clock/study/activity/AnimatorActivity.java
create mode 100644 src/main/res/animator/simple_animator.xml
create mode 100644 src/main/res/layout/activity_animator.xml
diff --git a/build.gradle b/build.gradle
index 4f16e25..0ad5e09 100644
--- a/build.gradle
+++ b/build.gradle
@@ -17,7 +17,7 @@ android {
defaultConfig {
applicationId "com.clock.study"
- minSdkVersion 9
+ minSdkVersion 11
targetSdkVersion 23
versionCode 1
versionName "1.0"
diff --git a/src/main/AndroidManifest.xml b/src/main/AndroidManifest.xml
index 7a0cbc0..863ae31 100644
--- a/src/main/AndroidManifest.xml
+++ b/src/main/AndroidManifest.xml
@@ -29,8 +29,15 @@
android:name=".activity.PhotoPreviewActivity"
android:label="@string/photo_preview"
android:screenOrientation="portrait" />
-
-
+
+
+
\ No newline at end of file
diff --git a/src/main/java/com/clock/study/activity/AnimatorActivity.java b/src/main/java/com/clock/study/activity/AnimatorActivity.java
new file mode 100644
index 0000000..5ffa395
--- /dev/null
+++ b/src/main/java/com/clock/study/activity/AnimatorActivity.java
@@ -0,0 +1,76 @@
+package com.clock.study.activity;
+
+import android.animation.Animator;
+import android.animation.AnimatorInflater;
+import android.animation.AnimatorSet;
+import android.animation.ObjectAnimator;
+import android.animation.ValueAnimator;
+import android.support.v7.app.AppCompatActivity;
+import android.os.Bundle;
+import android.util.Log;
+import android.view.View;
+import android.view.animation.AnimationSet;
+
+import com.clock.study.R;
+
+/**
+ * About Android Animator
+ *
+ * @author Clock
+ * @since 2016-07-21
+ */
+public class AnimatorActivity extends AppCompatActivity implements View.OnClickListener {
+
+ private static final String TAG = AnimatorActivity.class.getSimpleName();
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ setContentView(R.layout.activity_animator);
+
+ findViewById(R.id.btn_value_anim).setOnClickListener(this);
+ findViewById(R.id.btn_object_anim_alpha).setOnClickListener(this);
+ findViewById(R.id.btn_object_anim_rotation).setOnClickListener(this);
+ findViewById(R.id.btn_object_anim_set).setOnClickListener(this);
+ findViewById(R.id.btn_object_anim_xml).setOnClickListener(this);
+
+ }
+
+ @Override
+ public void onClick(View v) {
+ int viewId = v.getId();
+ if (viewId == R.id.btn_value_anim) {
+ ValueAnimator valueAnimator = ValueAnimator.ofInt(1, 100);
+ valueAnimator.setDuration(3000);
+ valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
+ @Override
+ public void onAnimationUpdate(ValueAnimator animation) {
+ int currentValue = (int) animation.getAnimatedValue();
+ Log.i(TAG, "currentValue: " + currentValue);
+ }
+ });
+ valueAnimator.start();
+ } else if (viewId == R.id.btn_object_anim_alpha) {
+ ObjectAnimator alphaObjectAnimator = ObjectAnimator.ofFloat(v, "alpha", 1f, 0f, 1f);
+ alphaObjectAnimator.setDuration(3000);
+ alphaObjectAnimator.start();
+ } else if (viewId == R.id.btn_object_anim_rotation) {
+ ObjectAnimator rotationObjectAnimator = ObjectAnimator.ofFloat(v, "rotation", 0f, 360f);
+ rotationObjectAnimator.setDuration(3000);
+ rotationObjectAnimator.start();
+ } else if (viewId == R.id.btn_object_anim_set) {
+ AnimatorSet animatorSet = new AnimatorSet();
+ ObjectAnimator alphaObjectAnimator = ObjectAnimator.ofFloat(v, "alpha", 1f, 0f, 1f);
+ ObjectAnimator rotationObjectAnimator = ObjectAnimator.ofFloat(v, "rotation", 0f, 360f);
+ animatorSet.play(alphaObjectAnimator).with(rotationObjectAnimator);
+ //animatorSet.play(alphaObjectAnimator).after(rotationObjectAnimator);
+ //animatorSet.playTogether(alphaObjectAnimator, rotationObjectAnimator);
+ animatorSet.setDuration(3000);
+ animatorSet.start();
+ } else if (viewId == R.id.btn_object_anim_xml) {
+ AnimatorSet animatorSet = (AnimatorSet) AnimatorInflater.loadAnimator(this, R.animator.simple_animator);
+ animatorSet.setTarget(v);
+ animatorSet.start();
+ }
+ }
+}
diff --git a/src/main/java/com/clock/study/activity/MainActivity.java b/src/main/java/com/clock/study/activity/MainActivity.java
index b1d1da5..0738d6b 100644
--- a/src/main/java/com/clock/study/activity/MainActivity.java
+++ b/src/main/java/com/clock/study/activity/MainActivity.java
@@ -16,6 +16,8 @@ protected void onCreate(Bundle savedInstanceState) {
findViewById(R.id.btn_camera_take_photo).setOnClickListener(this);
findViewById(R.id.btn_animation).setOnClickListener(this);
+ findViewById(R.id.btn_animator).setOnClickListener(this);
+
}
@Override
@@ -25,8 +27,11 @@ public void onClick(View v) {
Intent takePhotoIntent = new Intent(this, CapturePhotoActivity.class);
startActivity(takePhotoIntent);
} else if (viewId == R.id.btn_animation) {
- Intent androidAnimIntent = new Intent(this, AnimationActivity.class);
- startActivity(androidAnimIntent);
+ Intent animationIntent = new Intent(this, AnimationActivity.class);
+ startActivity(animationIntent);
+ } else if (viewId == R.id.btn_animator) {
+ Intent animatorIntent = new Intent(this, AnimatorActivity.class);
+ startActivity(animatorIntent);
}
}
}
diff --git a/src/main/res/animator/simple_animator.xml b/src/main/res/animator/simple_animator.xml
new file mode 100644
index 0000000..87a4808
--- /dev/null
+++ b/src/main/res/animator/simple_animator.xml
@@ -0,0 +1,18 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/main/res/layout/activity_animator.xml b/src/main/res/layout/activity_animator.xml
new file mode 100644
index 0000000..0ccb647
--- /dev/null
+++ b/src/main/res/layout/activity_animator.xml
@@ -0,0 +1,40 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/main/res/layout/activity_main.xml b/src/main/res/layout/activity_main.xml
index c061c3d..3346670 100644
--- a/src/main/res/layout/activity_main.xml
+++ b/src/main/res/layout/activity_main.xml
@@ -19,4 +19,10 @@
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Android Animation" />
+
+
diff --git a/src/main/res/values/strings.xml b/src/main/res/values/strings.xml
index de587c7..0f9a929 100644
--- a/src/main/res/values/strings.xml
+++ b/src/main/res/values/strings.xml
@@ -9,4 +9,7 @@
当前权限被禁用,建议到设置界面开启权限!
取消
设置
+ Android Animation
+ Android Animator
+ Animation Test
From c87af7ef87097270b49ece4b52bb84597c3bbf57 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Fri, 22 Jul 2016 18:53:12 +0800
Subject: [PATCH 02/21] =?UTF-8?q?=E6=B7=BB=E5=8A=A0TypeEvaluator=E7=BB=83?=
=?UTF-8?q?=E4=B9=A0=E4=BB=A3=E7=A0=81?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.../study/activity/AnimatorActivity.java | 32 ++++++---
src/main/res/layout/activity_animator.xml | 70 ++++++++++++-------
2 files changed, 70 insertions(+), 32 deletions(-)
diff --git a/src/main/java/com/clock/study/activity/AnimatorActivity.java b/src/main/java/com/clock/study/activity/AnimatorActivity.java
index 5ffa395..f67bee3 100644
--- a/src/main/java/com/clock/study/activity/AnimatorActivity.java
+++ b/src/main/java/com/clock/study/activity/AnimatorActivity.java
@@ -1,15 +1,14 @@
package com.clock.study.activity;
-import android.animation.Animator;
import android.animation.AnimatorInflater;
import android.animation.AnimatorSet;
+import android.animation.FloatEvaluator;
import android.animation.ObjectAnimator;
import android.animation.ValueAnimator;
-import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
+import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.View;
-import android.view.animation.AnimationSet;
import com.clock.study.R;
@@ -23,16 +22,21 @@ public class AnimatorActivity extends AppCompatActivity implements View.OnClickL
private static final String TAG = AnimatorActivity.class.getSimpleName();
+ private View mTarget;
+
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_animator);
+ mTarget = findViewById(R.id.anim_target);
+
findViewById(R.id.btn_value_anim).setOnClickListener(this);
findViewById(R.id.btn_object_anim_alpha).setOnClickListener(this);
findViewById(R.id.btn_object_anim_rotation).setOnClickListener(this);
findViewById(R.id.btn_object_anim_set).setOnClickListener(this);
findViewById(R.id.btn_object_anim_xml).setOnClickListener(this);
+ findViewById(R.id.btn_float_evaluator).setOnClickListener(this);
}
@@ -51,17 +55,17 @@ public void onAnimationUpdate(ValueAnimator animation) {
});
valueAnimator.start();
} else if (viewId == R.id.btn_object_anim_alpha) {
- ObjectAnimator alphaObjectAnimator = ObjectAnimator.ofFloat(v, "alpha", 1f, 0f, 1f);
+ ObjectAnimator alphaObjectAnimator = ObjectAnimator.ofFloat(mTarget, "alpha", 1f, 0f, 1f);
alphaObjectAnimator.setDuration(3000);
alphaObjectAnimator.start();
} else if (viewId == R.id.btn_object_anim_rotation) {
- ObjectAnimator rotationObjectAnimator = ObjectAnimator.ofFloat(v, "rotation", 0f, 360f);
+ ObjectAnimator rotationObjectAnimator = ObjectAnimator.ofFloat(mTarget, "rotation", 0f, 360f);
rotationObjectAnimator.setDuration(3000);
rotationObjectAnimator.start();
} else if (viewId == R.id.btn_object_anim_set) {
AnimatorSet animatorSet = new AnimatorSet();
- ObjectAnimator alphaObjectAnimator = ObjectAnimator.ofFloat(v, "alpha", 1f, 0f, 1f);
- ObjectAnimator rotationObjectAnimator = ObjectAnimator.ofFloat(v, "rotation", 0f, 360f);
+ ObjectAnimator alphaObjectAnimator = ObjectAnimator.ofFloat(mTarget, "alpha", 1f, 0f, 1f);
+ ObjectAnimator rotationObjectAnimator = ObjectAnimator.ofFloat(mTarget, "rotation", 0f, 360f);
animatorSet.play(alphaObjectAnimator).with(rotationObjectAnimator);
//animatorSet.play(alphaObjectAnimator).after(rotationObjectAnimator);
//animatorSet.playTogether(alphaObjectAnimator, rotationObjectAnimator);
@@ -69,8 +73,20 @@ public void onAnimationUpdate(ValueAnimator animation) {
animatorSet.start();
} else if (viewId == R.id.btn_object_anim_xml) {
AnimatorSet animatorSet = (AnimatorSet) AnimatorInflater.loadAnimator(this, R.animator.simple_animator);
- animatorSet.setTarget(v);
+ animatorSet.setTarget(mTarget);
animatorSet.start();
+ } else if (viewId == R.id.btn_float_evaluator) {
+ FloatEvaluator floatEvaluator = new FloatEvaluator();
+ ValueAnimator valueAnimator = ValueAnimator.ofObject(floatEvaluator, 0f, 360f);
+ valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
+ @Override
+ public void onAnimationUpdate(ValueAnimator animation) {
+ float value = (float) animation.getAnimatedValue();
+ Log.i(TAG, "float evaluator value: " + value);
+ }
+ });
+ valueAnimator.setDuration(3000);
+ valueAnimator.start();
}
}
}
diff --git a/src/main/res/layout/activity_animator.xml b/src/main/res/layout/activity_animator.xml
index 0ccb647..2bbc0ba 100644
--- a/src/main/res/layout/activity_animator.xml
+++ b/src/main/res/layout/activity_animator.xml
@@ -8,33 +8,55 @@
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin">
-
+
-
+ android:layout_height="match_parent">
-
+
-
+
+
+
+
+
+
+
+
+
+
+
+
+
-
From 94d55def1dc28a00a5c91b95f92cd727eb4da4a7 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Fri, 22 Jul 2016 18:53:50 +0800
Subject: [PATCH 03/21] =?UTF-8?q?=E6=B7=BB=E5=8A=A0TypeEvaluator=E7=BB=83?=
=?UTF-8?q?=E4=B9=A0=E4=BB=A3=E7=A0=81?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/main/java/com/clock/study/animator/Test.java | 7 +++++++
1 file changed, 7 insertions(+)
create mode 100644 src/main/java/com/clock/study/animator/Test.java
diff --git a/src/main/java/com/clock/study/animator/Test.java b/src/main/java/com/clock/study/animator/Test.java
new file mode 100644
index 0000000..342bd22
--- /dev/null
+++ b/src/main/java/com/clock/study/animator/Test.java
@@ -0,0 +1,7 @@
+package com.clock.study.animator;
+
+/**
+ * Created by Administrator on 2016/7/22.
+ */
+public class Test {
+}
From 58ce3e9efe1a40ddd53687f6f0e48b4f717db1db Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Sat, 23 Jul 2016 21:06:15 +0800
Subject: [PATCH 04/21] =?UTF-8?q?=E6=B7=BB=E5=8A=A0=E4=B8=80=E4=BA=9B=20An?=
=?UTF-8?q?imator=20=E5=8A=A8=E7=94=BB=E5=AE=9E=E8=B7=B5=E4=BB=A3=E7=A0=81?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.../study/activity/AnimatorActivity.java | 200 ++++++++++++++++--
.../clock/study/animator/ColorEvaluator.java | 31 +++
.../java/com/clock/study/animator/Test.java | 7 -
src/main/res/layout/activity_animator.xml | 28 ++-
.../java/com/clock/study/ExampleUnitTest.java | 2 +-
5 files changed, 245 insertions(+), 23 deletions(-)
create mode 100644 src/main/java/com/clock/study/animator/ColorEvaluator.java
delete mode 100644 src/main/java/com/clock/study/animator/Test.java
diff --git a/src/main/java/com/clock/study/activity/AnimatorActivity.java b/src/main/java/com/clock/study/activity/AnimatorActivity.java
index f67bee3..91d4622 100644
--- a/src/main/java/com/clock/study/activity/AnimatorActivity.java
+++ b/src/main/java/com/clock/study/activity/AnimatorActivity.java
@@ -2,13 +2,17 @@
import android.animation.AnimatorInflater;
import android.animation.AnimatorSet;
-import android.animation.FloatEvaluator;
+import android.animation.Keyframe;
import android.animation.ObjectAnimator;
+import android.animation.PropertyValuesHolder;
import android.animation.ValueAnimator;
+import android.graphics.Color;
import android.os.Bundle;
+import android.support.v4.view.ViewCompat;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.View;
+import android.view.animation.BounceInterpolator;
import com.clock.study.R;
@@ -36,7 +40,11 @@ protected void onCreate(Bundle savedInstanceState) {
findViewById(R.id.btn_object_anim_rotation).setOnClickListener(this);
findViewById(R.id.btn_object_anim_set).setOnClickListener(this);
findViewById(R.id.btn_object_anim_xml).setOnClickListener(this);
- findViewById(R.id.btn_float_evaluator).setOnClickListener(this);
+ findViewById(R.id.btn_simple_value_animator).setOnClickListener(this);
+ findViewById(R.id.btn_value_animator_argb).setOnClickListener(this);
+ findViewById(R.id.btn_bounce_interpolator).setOnClickListener(this);
+ findViewById(R.id.btn_simple_key_frame).setOnClickListener(this);
+ findViewById(R.id.btn_shake_key_frame).setOnClickListener(this);
}
@@ -54,14 +62,17 @@ public void onAnimationUpdate(ValueAnimator animation) {
}
});
valueAnimator.start();
+
} else if (viewId == R.id.btn_object_anim_alpha) {
ObjectAnimator alphaObjectAnimator = ObjectAnimator.ofFloat(mTarget, "alpha", 1f, 0f, 1f);
alphaObjectAnimator.setDuration(3000);
alphaObjectAnimator.start();
+
} else if (viewId == R.id.btn_object_anim_rotation) {
ObjectAnimator rotationObjectAnimator = ObjectAnimator.ofFloat(mTarget, "rotation", 0f, 360f);
rotationObjectAnimator.setDuration(3000);
rotationObjectAnimator.start();
+
} else if (viewId == R.id.btn_object_anim_set) {
AnimatorSet animatorSet = new AnimatorSet();
ObjectAnimator alphaObjectAnimator = ObjectAnimator.ofFloat(mTarget, "alpha", 1f, 0f, 1f);
@@ -71,22 +82,185 @@ public void onAnimationUpdate(ValueAnimator animation) {
//animatorSet.playTogether(alphaObjectAnimator, rotationObjectAnimator);
animatorSet.setDuration(3000);
animatorSet.start();
+
} else if (viewId == R.id.btn_object_anim_xml) {
AnimatorSet animatorSet = (AnimatorSet) AnimatorInflater.loadAnimator(this, R.animator.simple_animator);
animatorSet.setTarget(mTarget);
animatorSet.start();
- } else if (viewId == R.id.btn_float_evaluator) {
- FloatEvaluator floatEvaluator = new FloatEvaluator();
- ValueAnimator valueAnimator = ValueAnimator.ofObject(floatEvaluator, 0f, 360f);
- valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
- @Override
- public void onAnimationUpdate(ValueAnimator animation) {
- float value = (float) animation.getAnimatedValue();
- Log.i(TAG, "float evaluator value: " + value);
+
+ } else if (viewId == R.id.btn_simple_value_animator) {
+ displayColorAnimation(mTarget, "#0000ff", "#ff0000");
+
+ } else if (viewId == R.id.btn_value_animator_argb) {
+ if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.LOLLIPOP) {
+ int startColor = 0x00000000;
+ int centerColor = 0xff00ff89;
+ int endColor = 0x00000000;
+ ValueAnimator valueAnimator = ValueAnimator.ofArgb(startColor, centerColor, endColor);
+ valueAnimator.setDuration(6000);
+ valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
+ @Override
+ public void onAnimationUpdate(ValueAnimator animation) {
+ int color = (int) animation.getAnimatedValue();
+ mTarget.setBackgroundColor(color);
+ }
+ });
+ valueAnimator.start();
+ }
+
+ } else if (viewId == R.id.btn_bounce_interpolator) {
+ ObjectAnimator objectAnimator = ObjectAnimator.ofFloat(mTarget, "translationY", 0f, 1500f);
+ objectAnimator.setInterpolator(new BounceInterpolator());
+ objectAnimator.setDuration(4000);
+ objectAnimator.start();
+
+ } else if (viewId == R.id.btn_simple_key_frame) {
+ Keyframe kf0 = Keyframe.ofFloat(0f, 0f);
+ Keyframe kf1 = Keyframe.ofFloat(.5f, 360f);
+ Keyframe kf2 = Keyframe.ofFloat(1f, 0f);
+ PropertyValuesHolder pvhRotation = PropertyValuesHolder.ofKeyframe("rotation", kf0, kf1, kf2);
+ ObjectAnimator rotationAnim = ObjectAnimator.ofPropertyValuesHolder(mTarget, pvhRotation);
+ rotationAnim.setDuration(5000);
+ rotationAnim.start();
+
+ } else if (viewId == R.id.btn_shake_key_frame) {
+ displayShakeAnimator(mTarget, 1f);
+
+ }
+ }
+
+ /**
+ * 创建一个旋转动画
+ *
+ * @param target
+ * @param shakeFactor
+ * @return
+ */
+ private void displayShakeAnimator(View target, float shakeFactor) {
+ Keyframe scaleXkf0 = Keyframe.ofFloat(0f, 1f);
+ Keyframe scaleXkf1 = Keyframe.ofFloat(0.1f, 0.9f);
+ Keyframe scaleXkf2 = Keyframe.ofFloat(0.2f, 0.9f);
+ Keyframe scaleXkf3 = Keyframe.ofFloat(0.3f, 0.9f);
+ Keyframe scaleXkf4 = Keyframe.ofFloat(0.4f, 1.1f);
+ Keyframe scaleXkf5 = Keyframe.ofFloat(0.5f, 1.1f);
+ Keyframe scaleXkf6 = Keyframe.ofFloat(0.6f, 1.1f);
+ Keyframe scaleXkf7 = Keyframe.ofFloat(0.7f, 1.1f);
+ Keyframe scaleXkf8 = Keyframe.ofFloat(0.8f, 1.1f);
+ Keyframe scaleXkf9 = Keyframe.ofFloat(0.9f, 1.1f);
+ Keyframe scaleXkf10 = Keyframe.ofFloat(1f, 1f);
+
+ PropertyValuesHolder scaleXHolder = PropertyValuesHolder.ofKeyframe("scaleX", scaleXkf0, scaleXkf1, scaleXkf2, scaleXkf3, scaleXkf4,
+ scaleXkf5, scaleXkf6, scaleXkf7, scaleXkf8, scaleXkf9, scaleXkf10);
+
+ Keyframe scaleYkf0 = Keyframe.ofFloat(0f, 1f);
+ Keyframe scaleYkf1 = Keyframe.ofFloat(0.1f, 0.9f);
+ Keyframe scaleYkf2 = Keyframe.ofFloat(0.2f, 0.9f);
+ Keyframe scaleYkf3 = Keyframe.ofFloat(0.3f, 0.9f);
+ Keyframe scaleYkf4 = Keyframe.ofFloat(0.4f, 1.1f);
+ Keyframe scaleYkf5 = Keyframe.ofFloat(0.5f, 1.1f);
+ Keyframe scaleYkf6 = Keyframe.ofFloat(0.6f, 1.1f);
+ Keyframe scaleYkf7 = Keyframe.ofFloat(0.7f, 1.1f);
+ Keyframe scaleYkf8 = Keyframe.ofFloat(0.8f, 1.1f);
+ Keyframe scaleYkf9 = Keyframe.ofFloat(0.9f, 1.1f);
+ Keyframe scaleYkf10 = Keyframe.ofFloat(1f, 1f);
+ PropertyValuesHolder scaleYHolder = PropertyValuesHolder.ofKeyframe("scaleY", scaleYkf0, scaleYkf1, scaleYkf2, scaleYkf3, scaleYkf4,
+ scaleYkf5, scaleYkf6, scaleYkf7, scaleYkf8, scaleYkf9, scaleYkf10);
+
+
+ PropertyValuesHolder rotationHolder = PropertyValuesHolder.ofKeyframe("rotation",
+ Keyframe.ofFloat(0f, 0),
+ Keyframe.ofFloat(0.1f, -3 * shakeFactor),
+ Keyframe.ofFloat(0.2f, -3 * shakeFactor),
+ Keyframe.ofFloat(0.3f, 3 * shakeFactor),
+ Keyframe.ofFloat(0.4f, -3 * shakeFactor),
+ Keyframe.ofFloat(0.5f, 3 * shakeFactor),
+ Keyframe.ofFloat(0.6f, -3 * shakeFactor),
+ Keyframe.ofFloat(0.7f, -3 * shakeFactor),
+ Keyframe.ofFloat(0.8f, 3 * shakeFactor),
+ Keyframe.ofFloat(0.9f, -3 * shakeFactor),
+ Keyframe.ofFloat(1f, 0));
+
+
+ ObjectAnimator.ofPropertyValuesHolder(target, scaleXHolder, scaleYHolder, rotationHolder).setDuration(1000).start();
+ }
+
+ /**
+ * 显示颜色变化的动画
+ *
+ * @param target
+ * @param startColor
+ * @param endColor
+ */
+ private void displayColorAnimation(final View target, final String startColor, final String endColor) {
+ ValueAnimator valueAnimator = ValueAnimator.ofFloat(0f, 100f);
+ valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
+ @Override
+ public void onAnimationUpdate(ValueAnimator animation) {
+ if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.HONEYCOMB_MR1) {
+ float fraction = animation.getAnimatedFraction();
+ if (target != null) {
+ int startRed = Integer.parseInt(startColor.substring(1, 3), 16);
+ int startGreen = Integer.parseInt(startColor.substring(3, 5), 16);
+ int startBlue = Integer.parseInt(startColor.substring(5, 7), 16);
+ int endRed = Integer.parseInt(endColor.substring(1, 3), 16);
+ int endGreen = Integer.parseInt(endColor.substring(3, 5), 16);
+ int endBlue = Integer.parseInt(endColor.substring(5, 7), 16);
+
+ int redDiff = Math.abs(endRed - startRed);
+ int greenDiff = Math.abs(endGreen - startGreen);
+ int blueDiff = Math.abs(endBlue - startBlue);
+ int colorDiff = redDiff + greenDiff + blueDiff;
+
+ int currRed = getCurrentColor(startRed, endRed, colorDiff, fraction);
+ int currGreen = getCurrentColor(startGreen, endGreen, colorDiff, fraction);
+ int currBlue = getCurrentColor(startBlue, endBlue, colorDiff, fraction);
+
+ String colorString = "#" + getHexString(currRed) + getHexString(currGreen) + getHexString(currBlue);
+ int color = Color.parseColor(colorString);
+ target.setBackgroundColor(color);
+
+ }
}
- });
- valueAnimator.setDuration(3000);
- valueAnimator.start();
+
+ }
+ });
+ valueAnimator.setDuration(3000);
+ valueAnimator.start();
+
+ }
+
+ /**
+ * 获取当前新颜色
+ *
+ * @param startColor
+ * @param endColor
+ * @param colorDiff
+ * @param fraction
+ * @return
+ */
+ private int getCurrentColor(int startColor, int endColor, int colorDiff, float fraction) {
+ int currentColor = 0;
+ if (startColor > endColor) {
+ currentColor = (int) (startColor - fraction * colorDiff);
+ } else {
+ currentColor = (int) (startColor + fraction * colorDiff);
+ }
+ if (currentColor >= 0 && currentColor <= 256) {//最终的色值要确保在0到256之间
+ return currentColor;
+ } else {
+ currentColor = endColor;
+ }
+ return currentColor;
+ }
+
+ /**
+ * 将10进制颜色值转换成16进制。
+ */
+ private String getHexString(int value) {
+ String hexString = Integer.toHexString(value);
+ if (hexString.length() == 1) {
+ hexString = "0" + hexString;
}
+ return hexString;
}
}
diff --git a/src/main/java/com/clock/study/animator/ColorEvaluator.java b/src/main/java/com/clock/study/animator/ColorEvaluator.java
new file mode 100644
index 0000000..22e1328
--- /dev/null
+++ b/src/main/java/com/clock/study/animator/ColorEvaluator.java
@@ -0,0 +1,31 @@
+package com.clock.study.animator;
+
+import android.animation.TypeEvaluator;
+
+/**
+ * 仿照了 ArgbEvaluator 的系统实现,用于产生颜色过度渐变效果
+ *
+ * Created by Clock on 2016/7/22.
+ */
+public class ColorEvaluator implements TypeEvaluator {
+
+ @Override
+ public Object evaluate(float fraction, Object startValue, Object endValue) {
+ int startInt = (Integer) startValue;
+ int startA = (startInt >> 24) & 0xff;
+ int startR = (startInt >> 16) & 0xff;
+ int startG = (startInt >> 8) & 0xff;
+ int startB = startInt & 0xff;
+
+ int endInt = (Integer) endValue;
+ int endA = (endInt >> 24) & 0xff;
+ int endR = (endInt >> 16) & 0xff;
+ int endG = (endInt >> 8) & 0xff;
+ int endB = endInt & 0xff;
+
+ return (int) ((startA + (int) (fraction * (endA - startA))) << 24) |
+ (int) ((startR + (int) (fraction * (endR - startR))) << 16) |
+ (int) ((startG + (int) (fraction * (endG - startG))) << 8) |
+ (int) ((startB + (int) (fraction * (endB - startB))));
+ }
+}
diff --git a/src/main/java/com/clock/study/animator/Test.java b/src/main/java/com/clock/study/animator/Test.java
deleted file mode 100644
index 342bd22..0000000
--- a/src/main/java/com/clock/study/animator/Test.java
+++ /dev/null
@@ -1,7 +0,0 @@
-package com.clock.study.animator;
-
-/**
- * Created by Administrator on 2016/7/22.
- */
-public class Test {
-}
diff --git a/src/main/res/layout/activity_animator.xml b/src/main/res/layout/activity_animator.xml
index 2bbc0ba..e24cc1f 100644
--- a/src/main/res/layout/activity_animator.xml
+++ b/src/main/res/layout/activity_animator.xml
@@ -52,10 +52,34 @@
android:text="Object Animator (Xml)" />
+ android:text="Simple Value Animator" />
+
+
+
+
+
+
+
+
diff --git a/src/test/java/com/clock/study/ExampleUnitTest.java b/src/test/java/com/clock/study/ExampleUnitTest.java
index 310fb93..36e3ec5 100644
--- a/src/test/java/com/clock/study/ExampleUnitTest.java
+++ b/src/test/java/com/clock/study/ExampleUnitTest.java
@@ -5,7 +5,7 @@
import static org.junit.Assert.*;
/**
- * To work on unit tests, switch the Test Artifact in the Build Variants view.
+ * To work on unit tests, switch the ColorEvaluator Artifact in the Build Variants view.
*/
public class ExampleUnitTest {
@Test
From 6b1ebe411914922009fae417b8d4383bbfdf38c3 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Fri, 29 Jul 2016 01:17:00 +0800
Subject: [PATCH 05/21] =?UTF-8?q?=E7=A7=BB=E9=99=A4RecyclerView=E7=9A=84md?=
=?UTF-8?q?=E6=96=87=E7=AB=A0?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
...67\261\345\205\245\344\275\277\347\224\250 RecyclerView.md" | 3 ---
1 file changed, 3 deletions(-)
delete mode 100644 "notes/\346\267\261\345\205\245\344\275\277\347\224\250 RecyclerView.md"
diff --git "a/notes/\346\267\261\345\205\245\344\275\277\347\224\250 RecyclerView.md" "b/notes/\346\267\261\345\205\245\344\275\277\347\224\250 RecyclerView.md"
deleted file mode 100644
index 2712705..0000000
--- "a/notes/\346\267\261\345\205\245\344\275\277\347\224\250 RecyclerView.md"
+++ /dev/null
@@ -1,3 +0,0 @@
-# RecyclerView 使用大全
-
-整理罗列想要写的知识点
\ No newline at end of file
From a0bae2db584dc78614f26a73c4e08fc2a18f429d Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Mon, 1 Aug 2016 10:54:36 +0800
Subject: [PATCH 06/21] =?UTF-8?q?=E5=90=88=E5=B9=B6=E4=BB=A3=E7=A0=81?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.../java/com/clock/study/activity/AnimationTestActivity.java | 2 +-
src/main/res/layout/activity_animator.xml | 2 +-
.../layout/{list_view_test_item.xml => author_info_layout.xml} | 0
3 files changed, 2 insertions(+), 2 deletions(-)
rename src/main/res/layout/{list_view_test_item.xml => author_info_layout.xml} (100%)
diff --git a/src/main/java/com/clock/study/activity/AnimationTestActivity.java b/src/main/java/com/clock/study/activity/AnimationTestActivity.java
index 187e5ed..24c2eac 100644
--- a/src/main/java/com/clock/study/activity/AnimationTestActivity.java
+++ b/src/main/java/com/clock/study/activity/AnimationTestActivity.java
@@ -59,7 +59,7 @@ public long getItemId(int position) {
@Override
public View getView(int position, View convertView, ViewGroup parent) {
if (convertView == null) {
- convertView = View.inflate(parent.getContext(), R.layout.list_view_test_item, null);
+ convertView = View.inflate(parent.getContext(), R.layout.author_info_layout, null);
}
return convertView;
}
diff --git a/src/main/res/layout/activity_animator.xml b/src/main/res/layout/activity_animator.xml
index e24cc1f..4788b01 100644
--- a/src/main/res/layout/activity_animator.xml
+++ b/src/main/res/layout/activity_animator.xml
@@ -10,7 +10,7 @@
+ layout="@layout/author_info_layout" />
Date: Thu, 4 Aug 2016 09:45:18 +0800
Subject: [PATCH 07/21] =?UTF-8?q?=E6=B7=BB=E5=8A=A0=E6=96=B0=E7=9A=84note?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
...\345\275\223ListView\351\201\207\344\270\212RecyclerView.md" | 2 ++
1 file changed, 2 insertions(+)
create mode 100644 "notes/\345\275\223ListView\351\201\207\344\270\212RecyclerView.md"
diff --git "a/notes/\345\275\223ListView\351\201\207\344\270\212RecyclerView.md" "b/notes/\345\275\223ListView\351\201\207\344\270\212RecyclerView.md"
new file mode 100644
index 0000000..06e0507
--- /dev/null
+++ "b/notes/\345\275\223ListView\351\201\207\344\270\212RecyclerView.md"
@@ -0,0 +1,2 @@
+# 当 ListView 遇上 RecyclerView
+
From 69bc41e14e1c77bcdc6d144dc4a90212e6a3ad1c Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Thu, 4 Aug 2016 11:51:00 +0800
Subject: [PATCH 08/21] =?UTF-8?q?=E7=A7=BB=E9=99=A4RecyclerView=E7=9A=84no?=
=?UTF-8?q?te?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
...\345\275\223ListView\351\201\207\344\270\212RecyclerView.md" | 2 --
1 file changed, 2 deletions(-)
delete mode 100644 "notes/\345\275\223ListView\351\201\207\344\270\212RecyclerView.md"
diff --git "a/notes/\345\275\223ListView\351\201\207\344\270\212RecyclerView.md" "b/notes/\345\275\223ListView\351\201\207\344\270\212RecyclerView.md"
deleted file mode 100644
index 06e0507..0000000
--- "a/notes/\345\275\223ListView\351\201\207\344\270\212RecyclerView.md"
+++ /dev/null
@@ -1,2 +0,0 @@
-# 当 ListView 遇上 RecyclerView
-
From 06f36c44d0ff58664881106c82d5beb6554d2bea Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Thu, 11 Aug 2016 18:22:51 +0800
Subject: [PATCH 09/21] =?UTF-8?q?=E6=B7=BB=E5=8A=A0UiModeManager=E4=BD=BF?=
=?UTF-8?q?=E7=94=A8?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/main/AndroidManifest.xml | 1 +
.../clock/study/activity/MainActivity.java | 4 ++
.../study/activity/NightModeActivity.java | 60 +++++++++++++++++++
src/main/res/layout/activity_main.xml | 7 +++
src/main/res/layout/activity_night_mode.xml | 45 ++++++++++++++
5 files changed, 117 insertions(+)
create mode 100644 src/main/java/com/clock/study/activity/NightModeActivity.java
create mode 100644 src/main/res/layout/activity_night_mode.xml
diff --git a/src/main/AndroidManifest.xml b/src/main/AndroidManifest.xml
index 863ae31..1a4ec8c 100644
--- a/src/main/AndroidManifest.xml
+++ b/src/main/AndroidManifest.xml
@@ -38,6 +38,7 @@
+
\ No newline at end of file
diff --git a/src/main/java/com/clock/study/activity/MainActivity.java b/src/main/java/com/clock/study/activity/MainActivity.java
index 0738d6b..1b449f6 100644
--- a/src/main/java/com/clock/study/activity/MainActivity.java
+++ b/src/main/java/com/clock/study/activity/MainActivity.java
@@ -17,6 +17,7 @@ protected void onCreate(Bundle savedInstanceState) {
findViewById(R.id.btn_camera_take_photo).setOnClickListener(this);
findViewById(R.id.btn_animation).setOnClickListener(this);
findViewById(R.id.btn_animator).setOnClickListener(this);
+ findViewById(R.id.btn_night_mode).setOnClickListener(this);
}
@@ -32,6 +33,9 @@ public void onClick(View v) {
} else if (viewId == R.id.btn_animator) {
Intent animatorIntent = new Intent(this, AnimatorActivity.class);
startActivity(animatorIntent);
+ } else if (viewId == R.id.btn_night_mode) {
+ Intent animatorIntent = new Intent(this, NightModeActivity.class);
+ startActivity(animatorIntent);
}
}
}
diff --git a/src/main/java/com/clock/study/activity/NightModeActivity.java b/src/main/java/com/clock/study/activity/NightModeActivity.java
new file mode 100644
index 0000000..ed2a04a
--- /dev/null
+++ b/src/main/java/com/clock/study/activity/NightModeActivity.java
@@ -0,0 +1,60 @@
+package com.clock.study.activity;
+
+import android.app.UiModeManager;
+import android.content.Context;
+import android.support.v7.app.AppCompatActivity;
+import android.os.Bundle;
+import android.util.Log;
+import android.widget.RadioButton;
+import android.widget.RadioGroup;
+
+import com.clock.study.R;
+
+/**
+ * 夜间模式实现方案
+ *
+ * @author Clock
+ * @since 2016=08-11
+ */
+public class NightModeActivity extends AppCompatActivity implements RadioGroup.OnCheckedChangeListener {
+
+ private final static String TAG = NightModeActivity.class.getSimpleName();
+
+ private UiModeManager mUiModeManager;
+ private RadioGroup mUiModeGroup;
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ setContentView(R.layout.activity_night_mode);
+
+ mUiModeManager = (UiModeManager) getSystemService(Context.UI_MODE_SERVICE);
+
+ mUiModeGroup = (RadioGroup) findViewById(R.id.rg_ui_mode);
+ mUiModeGroup.setOnCheckedChangeListener(this);
+ RadioButton normalMode = (RadioButton) findViewById(R.id.rb_normal);
+ normalMode.setChecked(true);
+
+ }
+
+ @Override
+ public void onCheckedChanged(RadioGroup group, int checkedId) {
+ if (mUiModeGroup == group) {
+ int currentModeType = mUiModeManager.getCurrentModeType();
+ Log.i(TAG, "currentModeType: " + currentModeType);
+ if (checkedId == R.id.rb_normal) {
+ mUiModeManager.disableCarMode(0);
+ mUiModeManager.setNightMode(UiModeManager.MODE_NIGHT_NO);
+
+ } else if (checkedId == R.id.rb_night_mode) {//夜间模式
+ mUiModeManager.enableCarMode(0);
+ mUiModeManager.setNightMode(UiModeManager.MODE_NIGHT_YES);
+
+ } else if (checkedId == R.id.rb_car_mode) {//车载模式
+ mUiModeManager.disableCarMode(0);
+ mUiModeManager.setNightMode(UiModeManager.MODE_NIGHT_NO);
+
+ }
+ }
+ }
+}
diff --git a/src/main/res/layout/activity_main.xml b/src/main/res/layout/activity_main.xml
index 3346670..f575bec 100644
--- a/src/main/res/layout/activity_main.xml
+++ b/src/main/res/layout/activity_main.xml
@@ -25,4 +25,11 @@
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Android Animator" />
+
+
+
diff --git a/src/main/res/layout/activity_night_mode.xml b/src/main/res/layout/activity_night_mode.xml
new file mode 100644
index 0000000..70aff24
--- /dev/null
+++ b/src/main/res/layout/activity_night_mode.xml
@@ -0,0 +1,45 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
From 070cc5b6c21f0b0ec86d0d3ad1961ac42f732119 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Fri, 12 Aug 2016 18:32:16 +0800
Subject: [PATCH 10/21] =?UTF-8?q?=E6=B7=BB=E5=8A=A0UiModeManager=E5=AE=9E?=
=?UTF-8?q?=E8=B7=B5=E4=BB=A3=E7=A0=81?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.../study/activity/NightModeActivity.java | 26 ++++++++++--------
src/main/res/layout/activity_night_mode.xml | 11 ++------
.../res/mipmap-night-hdpi/ic_launcher.png | Bin 0 -> 3418 bytes
.../res/mipmap-night-mdpi/ic_launcher.png | Bin 0 -> 2206 bytes
.../res/mipmap-night-xhdpi/ic_launcher.png | Bin 0 -> 4842 bytes
.../res/mipmap-night-xxhdpi/ic_launcher.png | Bin 0 -> 7718 bytes
src/main/res/mipmap-night-xxhdpi/lufy.png | Bin 0 -> 183405 bytes
.../res/mipmap-night-xxxhdpi/ic_launcher.png | Bin 0 -> 10486 bytes
src/main/res/values-night/colors.xml | 6 ++++
9 files changed, 23 insertions(+), 20 deletions(-)
create mode 100644 src/main/res/mipmap-night-hdpi/ic_launcher.png
create mode 100644 src/main/res/mipmap-night-mdpi/ic_launcher.png
create mode 100644 src/main/res/mipmap-night-xhdpi/ic_launcher.png
create mode 100644 src/main/res/mipmap-night-xxhdpi/ic_launcher.png
create mode 100644 src/main/res/mipmap-night-xxhdpi/lufy.png
create mode 100644 src/main/res/mipmap-night-xxxhdpi/ic_launcher.png
create mode 100644 src/main/res/values-night/colors.xml
diff --git a/src/main/java/com/clock/study/activity/NightModeActivity.java b/src/main/java/com/clock/study/activity/NightModeActivity.java
index ed2a04a..dcd05ae 100644
--- a/src/main/java/com/clock/study/activity/NightModeActivity.java
+++ b/src/main/java/com/clock/study/activity/NightModeActivity.java
@@ -2,8 +2,9 @@
import android.app.UiModeManager;
import android.content.Context;
-import android.support.v7.app.AppCompatActivity;
+import android.content.res.Configuration;
import android.os.Bundle;
+import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.widget.RadioButton;
import android.widget.RadioGroup;
@@ -40,21 +41,24 @@ protected void onCreate(Bundle savedInstanceState) {
@Override
public void onCheckedChanged(RadioGroup group, int checkedId) {
if (mUiModeGroup == group) {
- int currentModeType = mUiModeManager.getCurrentModeType();
- Log.i(TAG, "currentModeType: " + currentModeType);
+ int currentModeType = mUiModeManager.getCurrentModeType();//获取 UI 模式
+ Log.e(TAG, "currentModeType value is : " + currentModeType);
if (checkedId == R.id.rb_normal) {
- mUiModeManager.disableCarMode(0);
- mUiModeManager.setNightMode(UiModeManager.MODE_NIGHT_NO);
+ if (currentModeType == Configuration.UI_MODE_TYPE_CAR) {
+ mUiModeManager.disableCarMode(0);//关闭车载模式
+ mUiModeManager.setNightMode(UiModeManager.MODE_NIGHT_NO);
+ }
} else if (checkedId == R.id.rb_night_mode) {//夜间模式
- mUiModeManager.enableCarMode(0);
- mUiModeManager.setNightMode(UiModeManager.MODE_NIGHT_YES);
-
- } else if (checkedId == R.id.rb_car_mode) {//车载模式
- mUiModeManager.disableCarMode(0);
- mUiModeManager.setNightMode(UiModeManager.MODE_NIGHT_NO);
+ if (currentModeType == Configuration.UI_MODE_TYPE_NORMAL) {
+ //Note: On API 22 and below, changes to the night mode are only effective when the car or desk mode is enabled on a device.
+ // Starting in API 23, changes to night mode are always effective.
+ mUiModeManager.enableCarMode(0);//启用车载模式
+ mUiModeManager.setNightMode(UiModeManager.MODE_NIGHT_YES);
+ }
}
}
}
+
}
diff --git a/src/main/res/layout/activity_night_mode.xml b/src/main/res/layout/activity_night_mode.xml
index 70aff24..49ae5f5 100644
--- a/src/main/res/layout/activity_night_mode.xml
+++ b/src/main/res/layout/activity_night_mode.xml
@@ -26,20 +26,13 @@
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
- android:text="Normal" />
-
-
+ android:text="普通模式" />
+ android:text="夜间模式" />
diff --git a/src/main/res/mipmap-night-hdpi/ic_launcher.png b/src/main/res/mipmap-night-hdpi/ic_launcher.png
new file mode 100644
index 0000000000000000000000000000000000000000..cde69bcccec65160d92116f20ffce4fce0b5245c
GIT binary patch
literal 3418
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
literal 0
HcmV?d00001
diff --git a/src/main/res/mipmap-night-xhdpi/ic_launcher.png b/src/main/res/mipmap-night-xhdpi/ic_launcher.png
new file mode 100644
index 0000000000000000000000000000000000000000..bfa42f0e7b91d006d22352c9ff2f134e504e3c1d
GIT binary patch
literal 4842
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
literal 0
HcmV?d00001
diff --git a/src/main/res/mipmap-night-xxhdpi/ic_launcher.png b/src/main/res/mipmap-night-xxhdpi/ic_launcher.png
new file mode 100644
index 0000000000000000000000000000000000000000..324e72cdd7480cb983fa1bcc7ce686e51ef87fe7
GIT binary patch
literal 7718
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
literal 0
HcmV?d00001
diff --git a/src/main/res/mipmap-night-xxhdpi/lufy.png b/src/main/res/mipmap-night-xxhdpi/lufy.png
new file mode 100644
index 0000000000000000000000000000000000000000..0984cda0a59240cfc3fe68251b45d77dfbd8d1c1
GIT binary patch
literal 183405
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%0A4aD$fs1ckBxHISV`B|;cN5IaPKZ(Ib-VQ54kpK^
z2!$rt-QPet>l~!kLOjZhQ>YPlgf8iKs}6DILT1KNO9cgQ#-5pk^7EqD!d_;iy`sbK
zpH?T^cU0iS