From d6697a582b8919434ef4974b2a22f7a3fdc1a6d3 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Wed, 8 Jun 2016 15:55:32 +0800
Subject: [PATCH 01/38] =?UTF-8?q?=E4=BF=AE=E5=A4=8Dbug=EF=BC=8C=E5=A4=84?=
=?UTF-8?q?=E7=90=86=E5=85=BC=E5=AE=B9=E9=97=AE=E9=A2=98=EF=BC=8C=E8=AF=A6?=
=?UTF-8?q?=E8=A7=81README.md?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
README.md | 6 +-
build.gradle | 12 ++
.../study/activity/CapturePhotoActivity.java | 122 ++++++++++++++++--
.../clock/study/manager/FolderManager.java | 7 +
src/main/res/values/strings.xml | 4 +
5 files changed, 137 insertions(+), 14 deletions(-)
diff --git a/README.md b/README.md
index 03deee0..48fcbd4 100644
--- a/README.md
+++ b/README.md
@@ -8,10 +8,10 @@
- 本库libs下有个**AndroidUtils.aar**的依赖包,是由[AndroidUtils](https://github.com/D-clock/AndroidUtils)代码编译生成;
- 想要查看**AndroidUtils.aar**中的源代码,可以参考[这里](https://github.com/D-clock/Doc/blob/master/Android/%E4%B8%AA%E4%BA%BA%E6%94%B6%E8%97%8F/%E5%A6%82%E4%BD%95%E6%9F%A5%E7%9C%8Baar%E7%9A%84%E6%BA%90%E4%BB%A3%E7%A0%81.md)
-## 最新更新(编辑于2016-05-27)
+## 最新更新(编辑于2016-06-08)
-- 优化拍照实现;
-- 优化项目导入体验;
+- 兼容处理 Android M 版本的 Runtime Permission ;
+- 优化 build.gradle ,提高导入 moudle 体验;
## 归档文章
diff --git a/build.gradle b/build.gradle
index 29a1179..d52e2a3 100644
--- a/build.gradle
+++ b/build.gradle
@@ -32,3 +32,15 @@ dependencies {
//compile project(":AndroidUtils")
compile 'com.android.support:appcompat-v7:23.2.1'
}
+
+
+buildscript {
+ repositories {
+ jcenter()
+ }
+ dependencies {
+ classpath 'com.android.tools.build:gradle:2.1.0'
+ // NOTE: Do not place your application dependencies here; they belong
+ // in the individual module build.gradle files
+ }
+}
\ No newline at end of file
diff --git a/src/main/java/com/clock/study/activity/CapturePhotoActivity.java b/src/main/java/com/clock/study/activity/CapturePhotoActivity.java
index 9cbe5d1..f0d813b 100644
--- a/src/main/java/com/clock/study/activity/CapturePhotoActivity.java
+++ b/src/main/java/com/clock/study/activity/CapturePhotoActivity.java
@@ -1,10 +1,20 @@
package com.clock.study.activity;
+import android.Manifest;
+import android.content.DialogInterface;
import android.content.Intent;
+import android.content.pm.PackageManager;
+import android.net.Uri;
+import android.os.Build;
import android.os.Bundle;
+import android.provider.Settings;
+import android.support.annotation.NonNull;
+import android.support.v4.app.ActivityCompat;
+import android.support.v7.app.AlertDialog;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.View;
+import android.widget.Toast;
import com.clock.study.R;
import com.clock.study.helper.CapturePhotoHelper;
@@ -23,6 +33,11 @@ public class CapturePhotoActivity extends AppCompatActivity implements View.OnCl
private final static String TAG = CapturePhotoActivity.class.getSimpleName();
private final static String EXTRA_RESTORE_PHOTO = "extra_restore_photo";
+ /**
+ * 运行时权限申请码
+ */
+ private final static int RUNTIME_PERMISSION_REQUEST_CODE = 0x1;
+
private CapturePhotoHelper mCapturePhotoHelper;
private File mRestorePhotoFile;
@@ -32,8 +47,6 @@ protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_camera_take_photo);
- mCapturePhotoHelper = new CapturePhotoHelper(this, FolderManager.getPhotoFolder());
-
findViewById(R.id.iv_take_photo).setOnClickListener(this);
}
@@ -42,29 +55,62 @@ protected void onCreate(Bundle savedInstanceState) {
protected void onSaveInstanceState(Bundle outState) {
Log.i(TAG, "onSaveInstanceState");
super.onSaveInstanceState(outState);
- mRestorePhotoFile = mCapturePhotoHelper.getPhoto();
- Log.i(TAG, "onSaveInstanceState , mRestorePhotoFile: " + mRestorePhotoFile);
- if (mRestorePhotoFile != null) {
- outState.putSerializable(EXTRA_RESTORE_PHOTO, mRestorePhotoFile);
+ if (mCapturePhotoHelper != null) {
+ mRestorePhotoFile = mCapturePhotoHelper.getPhoto();
+ Log.i(TAG, "onSaveInstanceState , mRestorePhotoFile: " + mRestorePhotoFile);
+ if (mRestorePhotoFile != null) {
+ outState.putSerializable(EXTRA_RESTORE_PHOTO, mRestorePhotoFile);
+ }
}
-
}
@Override
protected void onRestoreInstanceState(Bundle savedInstanceState) {
Log.i(TAG, "onRestoreInstanceState");
super.onRestoreInstanceState(savedInstanceState);
- mRestorePhotoFile = (File) savedInstanceState.getSerializable(EXTRA_RESTORE_PHOTO);
- Log.i(TAG, "onRestoreInstanceState , mRestorePhotoFile: " + mRestorePhotoFile);
- mCapturePhotoHelper.setPhoto(mRestorePhotoFile);
+ if (mCapturePhotoHelper != null) {
+ mRestorePhotoFile = (File) savedInstanceState.getSerializable(EXTRA_RESTORE_PHOTO);
+ Log.i(TAG, "onRestoreInstanceState , mRestorePhotoFile: " + mRestorePhotoFile);
+ mCapturePhotoHelper.setPhoto(mRestorePhotoFile);
+ }
}
@Override
public void onClick(View v) {
int viewId = v.getId();
if (viewId == R.id.iv_take_photo) {
- mCapturePhotoHelper.capture();
+ if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { //Android M 处理Runtime Permission
+ if (ActivityCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED) {//检查是否有写入SD卡的授权
+ Log.i(TAG, "granted permission!");
+ turnOnCamera();
+ } else {
+ Log.i(TAG, "denied permission!");
+ if (ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
+ Log.i(TAG, "should show request permission rationale!");
+ }
+ requestPermission();
+ }
+ } else {
+ turnOnCamera();
+ }
+ }
+ }
+
+ /**
+ * 开启相机
+ */
+ private void turnOnCamera() {
+ if (mCapturePhotoHelper == null) {
+ mCapturePhotoHelper = new CapturePhotoHelper(this, FolderManager.getPhotoFolder());
}
+ mCapturePhotoHelper.capture();
+ }
+
+ /**
+ * 申请写入sd卡的权限
+ */
+ private void requestPermission() {
+ ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, RUNTIME_PERMISSION_REQUEST_CODE);
}
@Override
@@ -88,4 +134,58 @@ protected void onActivityResult(int requestCode, int resultCode, Intent data) {
}
}
+ @Override
+ public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
+ super.onRequestPermissionsResult(requestCode, permissions, grantResults);
+ if (requestCode == RUNTIME_PERMISSION_REQUEST_CODE) {
+ for (int index = 0; index < permissions.length; index++) {
+ String permission = permissions[index];
+ if (Manifest.permission.WRITE_EXTERNAL_STORAGE.equals(permission)) {
+ if (grantResults[index] == PackageManager.PERMISSION_GRANTED) {
+ Log.i(TAG, "onRequestPermissionsResult: permission is granted!");
+ turnOnCamera();
+
+ } else {
+ showMissingPermissionDialog();
+
+ }
+ }
+ }
+ }
+ }
+
+ /**
+ * 显示打开权限提示的对话框
+ */
+ private void showMissingPermissionDialog() {
+ AlertDialog.Builder builder = new AlertDialog.Builder(this);
+ builder.setTitle(R.string.help);
+ builder.setMessage(R.string.help_content);
+
+ builder.setNegativeButton(R.string.cancel, new DialogInterface.OnClickListener() {
+ @Override
+ public void onClick(DialogInterface dialog, int which) {
+ Toast.makeText(CapturePhotoActivity.this, R.string.camera_open_error, Toast.LENGTH_SHORT).show();
+ finish();
+ }
+ });
+
+ builder.setPositiveButton(R.string.settings, new DialogInterface.OnClickListener() {
+ @Override
+ public void onClick(DialogInterface dialog, int which) {
+ turnOnSettings();
+ }
+ });
+
+ builder.show();
+ }
+
+ /**
+ * 启动系统权限设置界面
+ */
+ private void turnOnSettings() {
+ Intent intent = new Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
+ intent.setData(Uri.parse("package:" + getPackageName()));
+ startActivity(intent);
+ }
}
diff --git a/src/main/java/com/clock/study/manager/FolderManager.java b/src/main/java/com/clock/study/manager/FolderManager.java
index 34f1851..19038e8 100644
--- a/src/main/java/com/clock/study/manager/FolderManager.java
+++ b/src/main/java/com/clock/study/manager/FolderManager.java
@@ -1,6 +1,13 @@
package com.clock.study.manager;
+import android.Manifest;
+import android.app.AlertDialog;
+import android.content.Context;
+import android.content.pm.PackageManager;
import android.os.Environment;
+import android.support.v4.app.ActivityCompat;
+
+import com.clock.study.R;
import java.io.File;
diff --git a/src/main/res/values/strings.xml b/src/main/res/values/strings.xml
index 881bb1d..de587c7 100644
--- a/src/main/res/values/strings.xml
+++ b/src/main/res/values/strings.xml
@@ -5,4 +5,8 @@
TakePhoto
显示到相册
未指定存储目录
+ 帮助
+ 当前权限被禁用,建议到设置界面开启权限!
+ 取消
+ 设置
From 20154c4ea402afa38e396e69d08741d4e13ec6f7 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Sun, 12 Jun 2016 12:57:02 +0800
Subject: [PATCH 02/38] update build.gradle
---
build.gradle | 23 +++++++++++------------
1 file changed, 11 insertions(+), 12 deletions(-)
diff --git a/build.gradle b/build.gradle
index d52e2a3..4f16e25 100644
--- a/build.gradle
+++ b/build.gradle
@@ -1,3 +1,14 @@
+buildscript {
+ repositories {
+ jcenter()
+ }
+ dependencies {
+ classpath 'com.android.tools.build:gradle:2.1.2'
+ // NOTE: Do not place your application dependencies here; they belong
+ // in the individual module build.gradle files
+ }
+}
+
apply plugin: 'com.android.application'
android {
@@ -31,16 +42,4 @@ dependencies {
compile(name: 'AndroidUtils', ext: 'aar')
//compile project(":AndroidUtils")
compile 'com.android.support:appcompat-v7:23.2.1'
-}
-
-
-buildscript {
- repositories {
- jcenter()
- }
- dependencies {
- classpath 'com.android.tools.build:gradle:2.1.0'
- // NOTE: Do not place your application dependencies here; they belong
- // in the individual module build.gradle files
- }
}
\ No newline at end of file
From 7063149f3914dfc03961b5bd40a53d3d3b279eb4 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Wed, 22 Jun 2016 12:03:10 +0800
Subject: [PATCH 03/38] =?UTF-8?q?=E6=B7=BB=E5=8A=A0RecyclerView=E5=A4=A7?=
=?UTF-8?q?=E5=85=A8.md?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
...erView \344\275\277\347\224\250\345\244\247\345\205\250.md" | 3 +++
1 file changed, 3 insertions(+)
create mode 100644 "notes/RecyclerView \344\275\277\347\224\250\345\244\247\345\205\250.md"
diff --git "a/notes/RecyclerView \344\275\277\347\224\250\345\244\247\345\205\250.md" "b/notes/RecyclerView \344\275\277\347\224\250\345\244\247\345\205\250.md"
new file mode 100644
index 0000000..2712705
--- /dev/null
+++ "b/notes/RecyclerView \344\275\277\347\224\250\345\244\247\345\205\250.md"
@@ -0,0 +1,3 @@
+# RecyclerView 使用大全
+
+整理罗列想要写的知识点
\ No newline at end of file
From 307275224a3615631ef027ab56e93d97e660fd18 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Fri, 1 Jul 2016 21:30:31 +0800
Subject: [PATCH 04/38] =?UTF-8?q?=E6=96=B0=E5=A2=9E=E4=B8=A4=E7=AF=87?=
=?UTF-8?q?=E6=96=B0=E7=9A=84=E6=96=87=E7=AB=A0md?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
...47\232\204\345\217\221\345\261\225\346\274\224\350\277\233.md" | 0
...6\267\261\345\205\245\344\275\277\347\224\250 RecyclerView.md" | 0
2 files changed, 0 insertions(+), 0 deletions(-)
create mode 100644 "notes/Android\345\212\250\347\224\273\347\232\204\345\217\221\345\261\225\346\274\224\350\277\233.md"
rename "notes/RecyclerView \344\275\277\347\224\250\345\244\247\345\205\250.md" => "notes/\346\267\261\345\205\245\344\275\277\347\224\250 RecyclerView.md" (100%)
diff --git "a/notes/Android\345\212\250\347\224\273\347\232\204\345\217\221\345\261\225\346\274\224\350\277\233.md" "b/notes/Android\345\212\250\347\224\273\347\232\204\345\217\221\345\261\225\346\274\224\350\277\233.md"
new file mode 100644
index 0000000..e69de29
diff --git "a/notes/RecyclerView \344\275\277\347\224\250\345\244\247\345\205\250.md" "b/notes/\346\267\261\345\205\245\344\275\277\347\224\250 RecyclerView.md"
similarity index 100%
rename from "notes/RecyclerView \344\275\277\347\224\250\345\244\247\345\205\250.md"
rename to "notes/\346\267\261\345\205\245\344\275\277\347\224\250 RecyclerView.md"
From 74dc69bdb80c0319b315d004ac958c337f33cc49 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Mon, 4 Jul 2016 18:15:48 +0800
Subject: [PATCH 05/38] =?UTF-8?q?=E6=B7=BB=E5=8A=A0=20Android=20Animation?=
=?UTF-8?q?=20=E4=BD=BF=E7=94=A8=E6=A0=97=E5=AD=90?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/main/AndroidManifest.xml | 1 +
.../study/activity/AndroidAnimActivity.java | 97 +++++++++++++++++++
.../clock/study/activity/MainActivity.java | 4 +
src/main/res/layout/activity_android_anim.xml | 40 ++++++++
src/main/res/layout/activity_main.xml | 9 +-
5 files changed, 150 insertions(+), 1 deletion(-)
create mode 100644 src/main/java/com/clock/study/activity/AndroidAnimActivity.java
create mode 100644 src/main/res/layout/activity_android_anim.xml
diff --git a/src/main/AndroidManifest.xml b/src/main/AndroidManifest.xml
index 794c2b8..a270a85 100644
--- a/src/main/AndroidManifest.xml
+++ b/src/main/AndroidManifest.xml
@@ -29,6 +29,7 @@
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/AndroidAnimActivity.java b/src/main/java/com/clock/study/activity/AndroidAnimActivity.java
new file mode 100644
index 0000000..32608e1
--- /dev/null
+++ b/src/main/java/com/clock/study/activity/AndroidAnimActivity.java
@@ -0,0 +1,97 @@
+package com.clock.study.activity;
+
+import android.support.v7.app.AppCompatActivity;
+import android.os.Bundle;
+import android.view.View;
+import android.view.animation.AlphaAnimation;
+import android.view.animation.Animation;
+import android.view.animation.AnimationSet;
+import android.view.animation.RotateAnimation;
+import android.view.animation.ScaleAnimation;
+import android.view.animation.TranslateAnimation;
+import android.widget.Button;
+
+import com.clock.study.R;
+
+/**
+ * Android动画效果实现复习
+ */
+public class AndroidAnimActivity extends AppCompatActivity implements View.OnClickListener {
+
+ private Button mBtnTranslate;
+ private Button mBtnScale;
+ private Button mBtnRotate;
+ private Button mBtnAlpha;
+ private Button mBtnSet;
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ setContentView(R.layout.activity_android_anim);
+
+ mBtnTranslate = (Button) findViewById(R.id.btn_translate);
+ mBtnTranslate.setOnClickListener(this);
+
+ mBtnScale = (Button) findViewById(R.id.btn_scale);
+ mBtnScale.setOnClickListener(this);
+
+ mBtnRotate = (Button) findViewById(R.id.btn_rotate);
+ mBtnRotate.setOnClickListener(this);
+
+ mBtnAlpha = (Button) findViewById(R.id.btn_alpha);
+ mBtnAlpha.setOnClickListener(this);
+
+ mBtnSet = (Button) findViewById(R.id.btn_set);
+ mBtnSet.setOnClickListener(this);
+
+ }
+
+ @Override
+ public void onClick(View v) {
+ int viewId = v.getId();
+ if (viewId == R.id.btn_translate) {//偏移动画
+ //TranslateAnimation translateAnim = new TranslateAnimation(0, 500, 0, 500);
+ /*TranslateAnimation translateAnim = new TranslateAnimation(Animation.ABSOLUTE, 0, Animation.ABSOLUTE, 500, Animation.ABSOLUTE, 0,
+ Animation.ABSOLUTE, 500);*/
+ TranslateAnimation translateAnim = new TranslateAnimation(Animation.RELATIVE_TO_PARENT, 0, Animation.RELATIVE_TO_PARENT, 1.0f, Animation.RELATIVE_TO_PARENT, 0,
+ Animation.RELATIVE_TO_PARENT, 1.0f);
+ translateAnim.setDuration(2000);
+ mBtnTranslate.startAnimation(translateAnim);
+ //translateAnim.setFillAfter(true);//保持动画效果
+
+ } else if (viewId == R.id.btn_scale) {//缩放动画
+
+ //ScaleAnimation scaleAnim = new ScaleAnimation(0.5f, 1, 0.5f, 1);
+ //ScaleAnimation scaleAnim = new ScaleAnimation(0.5f, 1, 0.5f, 1, 300, 300);
+ ScaleAnimation scaleAnim = new ScaleAnimation(0.5f, 1, 0.5f, 1, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
+ scaleAnim.setDuration(1000);
+ mBtnScale.startAnimation(scaleAnim);
+
+ } else if (viewId == R.id.btn_rotate) {//旋转动画
+
+ //RotateAnimation rotateAnim = new RotateAnimation(0, 360);
+ //RotateAnimation rotateAnim = new RotateAnimation(0, 360, 100, 100);
+ RotateAnimation rotateAnim = new RotateAnimation(0, 360, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
+ rotateAnim.setDuration(2000);
+ mBtnRotate.startAnimation(rotateAnim);
+
+ } else if (viewId == R.id.btn_alpha) {//透明度动画
+
+ AlphaAnimation alphaAnim = new AlphaAnimation(0, 1);
+ alphaAnim.setDuration(2000);
+ mBtnAlpha.startAnimation(alphaAnim);
+
+ } else if (viewId == R.id.btn_set) {//动画合集
+
+ AnimationSet animSet = new AnimationSet(true);
+ animSet.setDuration(2000);
+ RotateAnimation rotateAnim = new RotateAnimation(0, 360, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
+ animSet.addAnimation(rotateAnim);
+ AlphaAnimation alphaAnim = new AlphaAnimation(0, 1);
+ animSet.addAnimation(alphaAnim);
+ mBtnSet.startAnimation(animSet);
+
+ }
+
+ }
+}
diff --git a/src/main/java/com/clock/study/activity/MainActivity.java b/src/main/java/com/clock/study/activity/MainActivity.java
index 0637f11..3c26506 100644
--- a/src/main/java/com/clock/study/activity/MainActivity.java
+++ b/src/main/java/com/clock/study/activity/MainActivity.java
@@ -15,6 +15,7 @@ protected void onCreate(Bundle savedInstanceState) {
setContentView(R.layout.activity_main);
findViewById(R.id.btn_camera_take_photo).setOnClickListener(this);
+ findViewById(R.id.btn_android_anim).setOnClickListener(this);
}
@Override
@@ -23,6 +24,9 @@ public void onClick(View v) {
if (viewId == R.id.btn_camera_take_photo) {
Intent takePhotoIntent = new Intent(this, CapturePhotoActivity.class);
startActivity(takePhotoIntent);
+ } else if (viewId == R.id.btn_android_anim) {
+ Intent androidAnimIntent = new Intent(this, AndroidAnimActivity.class);
+ startActivity(androidAnimIntent);
}
}
}
diff --git a/src/main/res/layout/activity_android_anim.xml b/src/main/res/layout/activity_android_anim.xml
new file mode 100644
index 0000000..1804f66
--- /dev/null
+++ b/src/main/res/layout/activity_android_anim.xml
@@ -0,0 +1,40 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/main/res/layout/activity_main.xml b/src/main/res/layout/activity_main.xml
index 6054cb6..bbacf37 100644
--- a/src/main/res/layout/activity_main.xml
+++ b/src/main/res/layout/activity_main.xml
@@ -2,6 +2,7 @@
+ android:text="拍照保存实现" />
+
+
From 123f7f6fbc028574eb4fd583d5d68ebc83948019 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Tue, 5 Jul 2016 18:15:42 +0800
Subject: [PATCH 06/38] =?UTF-8?q?=E6=B7=BB=E5=8A=A0CustomAnimation?=
=?UTF-8?q?=E8=87=AA=E5=AE=9A=E4=B9=89=E5=8A=A8=E7=94=BB?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.../study/activity/AndroidAnimActivity.java | 12 +++++++++
.../study/animation/CustomAnimation.java | 25 +++++++++++++++++++
src/main/res/layout/activity_android_anim.xml | 6 +++++
3 files changed, 43 insertions(+)
create mode 100644 src/main/java/com/clock/study/animation/CustomAnimation.java
diff --git a/src/main/java/com/clock/study/activity/AndroidAnimActivity.java b/src/main/java/com/clock/study/activity/AndroidAnimActivity.java
index 32608e1..93b4a70 100644
--- a/src/main/java/com/clock/study/activity/AndroidAnimActivity.java
+++ b/src/main/java/com/clock/study/activity/AndroidAnimActivity.java
@@ -12,6 +12,7 @@
import android.widget.Button;
import com.clock.study.R;
+import com.clock.study.animation.CustomAnimation;
/**
* Android动画效果实现复习
@@ -23,6 +24,7 @@ public class AndroidAnimActivity extends AppCompatActivity implements View.OnCli
private Button mBtnRotate;
private Button mBtnAlpha;
private Button mBtnSet;
+ private Button mBtnCustom;
@Override
protected void onCreate(Bundle savedInstanceState) {
@@ -44,6 +46,9 @@ protected void onCreate(Bundle savedInstanceState) {
mBtnSet = (Button) findViewById(R.id.btn_set);
mBtnSet.setOnClickListener(this);
+ mBtnCustom = (Button) findViewById(R.id.btn_custom_anim);
+ mBtnCustom.setOnClickListener(this);
+
}
@Override
@@ -91,6 +96,13 @@ public void onClick(View v) {
animSet.addAnimation(alphaAnim);
mBtnSet.startAnimation(animSet);
+ } else if (viewId == R.id.btn_custom_anim) {
+
+ CustomAnimation customAnim = new CustomAnimation();//仿QQ抖屏动画效果
+ customAnim.setDuration(1000);
+ customAnim.setRepeatCount(3);
+ mBtnCustom.startAnimation(customAnim);
+
}
}
diff --git a/src/main/java/com/clock/study/animation/CustomAnimation.java b/src/main/java/com/clock/study/animation/CustomAnimation.java
new file mode 100644
index 0000000..d78eb02
--- /dev/null
+++ b/src/main/java/com/clock/study/animation/CustomAnimation.java
@@ -0,0 +1,25 @@
+package com.clock.study.animation;
+
+import android.util.Log;
+import android.view.animation.Animation;
+import android.view.animation.Transformation;
+
+/**
+ * 自定义Android的Animation动画,仿QQ窗口抖动动画
+ *
+ * Created by Clock on 2016/7/5.
+ */
+public class CustomAnimation extends Animation {
+
+ private final static String TAG = CustomAnimation.class.getSimpleName();
+
+ @Override
+ protected void applyTransformation(float interpolatedTime, Transformation t) {
+ Log.i(TAG, "applyTransformation");
+ t.getMatrix().setTranslate(
+ (float) Math.sin(interpolatedTime * 50) * 8,
+ (float) Math.sin(interpolatedTime * 50) * 8
+ );// 50越大频率越高,8越小振幅越小
+ super.applyTransformation(interpolatedTime, t);
+ }
+}
diff --git a/src/main/res/layout/activity_android_anim.xml b/src/main/res/layout/activity_android_anim.xml
index 1804f66..8189f07 100644
--- a/src/main/res/layout/activity_android_anim.xml
+++ b/src/main/res/layout/activity_android_anim.xml
@@ -37,4 +37,10 @@
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Animation Set" />
+
+
\ No newline at end of file
From f8355ef62e8b3c7c9b7a453914e20d63daec8214 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Fri, 8 Jul 2016 08:17:15 +0800
Subject: [PATCH 07/38] =?UTF-8?q?=E9=87=8D=E6=9E=84Animation=20Demo?=
=?UTF-8?q?=E7=95=8C=E9=9D=A2=E7=9A=84=E5=90=8D=E5=AD=97?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/main/AndroidManifest.xml | 2 +-
.../{AndroidAnimActivity.java => AnimationActivity.java} | 2 +-
src/main/java/com/clock/study/activity/MainActivity.java | 2 +-
3 files changed, 3 insertions(+), 3 deletions(-)
rename src/main/java/com/clock/study/activity/{AndroidAnimActivity.java => AnimationActivity.java} (97%)
diff --git a/src/main/AndroidManifest.xml b/src/main/AndroidManifest.xml
index a270a85..d753af2 100644
--- a/src/main/AndroidManifest.xml
+++ b/src/main/AndroidManifest.xml
@@ -29,7 +29,7 @@
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/AndroidAnimActivity.java b/src/main/java/com/clock/study/activity/AnimationActivity.java
similarity index 97%
rename from src/main/java/com/clock/study/activity/AndroidAnimActivity.java
rename to src/main/java/com/clock/study/activity/AnimationActivity.java
index 93b4a70..8a44471 100644
--- a/src/main/java/com/clock/study/activity/AndroidAnimActivity.java
+++ b/src/main/java/com/clock/study/activity/AnimationActivity.java
@@ -17,7 +17,7 @@
/**
* Android动画效果实现复习
*/
-public class AndroidAnimActivity extends AppCompatActivity implements View.OnClickListener {
+public class AnimationActivity extends AppCompatActivity implements View.OnClickListener {
private Button mBtnTranslate;
private Button mBtnScale;
diff --git a/src/main/java/com/clock/study/activity/MainActivity.java b/src/main/java/com/clock/study/activity/MainActivity.java
index 3c26506..ac99e05 100644
--- a/src/main/java/com/clock/study/activity/MainActivity.java
+++ b/src/main/java/com/clock/study/activity/MainActivity.java
@@ -25,7 +25,7 @@ public void onClick(View v) {
Intent takePhotoIntent = new Intent(this, CapturePhotoActivity.class);
startActivity(takePhotoIntent);
} else if (viewId == R.id.btn_android_anim) {
- Intent androidAnimIntent = new Intent(this, AndroidAnimActivity.class);
+ Intent androidAnimIntent = new Intent(this, AnimationActivity.class);
startActivity(androidAnimIntent);
}
}
From 77b449d74cc53585cf8c8685c66256d87b6befaf Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Sun, 10 Jul 2016 23:27:55 +0800
Subject: [PATCH 08/38] =?UTF-8?q?=E6=8F=90=E4=BA=A4Animation=E6=96=87?=
=?UTF-8?q?=E7=AB=A0=E5=86=85=E5=AE=B9=E8=AE=B0=E5=BD=95?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
...21\345\261\225\346\274\224\350\277\233.md" | 0
...4\273\357\274\232Animation\347\257\207.md" | 90 +++++++++++++++++++
.../study/activity/AnimationActivity.java | 11 +++
.../clock/study/activity/MainActivity.java | 4 +-
.../study/animation/CustomAnimation.java | 6 +-
.../animation/SimpleCustomAnimation.java | 46 ++++++++++
src/main/res/layout/activity_android_anim.xml | 6 ++
src/main/res/layout/activity_main.xml | 4 +-
8 files changed, 161 insertions(+), 6 deletions(-)
delete mode 100644 "notes/Android\345\212\250\347\224\273\347\232\204\345\217\221\345\261\225\346\274\224\350\277\233.md"
create mode 100644 "notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
create mode 100644 src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
diff --git "a/notes/Android\345\212\250\347\224\273\347\232\204\345\217\221\345\261\225\346\274\224\350\277\233.md" "b/notes/Android\345\212\250\347\224\273\347\232\204\345\217\221\345\261\225\346\274\224\350\277\233.md"
deleted file mode 100644
index e69de29..0000000
diff --git "a/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md" "b/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
new file mode 100644
index 0000000..3151fb6
--- /dev/null
+++ "b/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
@@ -0,0 +1,90 @@
+# 深入掌握 Animation 动画实现
+
+## applyTransformation
+
+传入两个参数 void applyTransformation (float interpolatedTime, Transformation t)
+
+interpolatedTime:时间比例系数,由0变化到1;
+t:包含两个部分,一个Alpha值和一个Matrix矩阵,Matrix默认是一个3X3的单位矩阵
+
+https://developer.android.com/reference/android/view/animation/Animation.html#applyTransformation(float, android.view.animation.Transformation)
+
+## 画图
+
+用 Python 的 MatPlotLib 来绘制一些正弦或者余弦的坐标图
+
+## Animation
+
+Animation动画只能对View起作用,能对View实现动画效果,但是View实际的触摸区域却没有发生改变
+
+偏移动画:TranslateAnimation,为 View 制造偏移的动画效果
+
+https://developer.android.com/reference/android/view/animation/TranslateAnimation.html
+
+TranslateAnimation动画的坐标值有以下三种类型
+
+- Animation.ABSOLUTE:绝对值,偏移量直接为像素数
+- Animation.RELATIVE_TO_SELF:相对值,偏移量为百分比,这个百分比相对于控件自身
+- Animation.RELATIVE_TO_PARENT:相对值,偏移量为百分比,这个百分比相对于控件的Parent
+
+缩放动画: ScaleAnimation,为 View 制造缩放的动画效果
+
+https://developer.android.com/reference/android/view/animation/ScaleAnimation.html
+
+构造函数有以下三类
+
+- ScaleAnimation (float fromX, float toX, float fromY, float toY):fromX、fromY是动画开始时的比例,toX、toY是动画结束时的比例。比例都是基于控件自身尺寸。
+- ScaleAnimation(float fromX, float toX, float fromY, float toY, float pivotX, float pivotY):在一的基础上可以指定缩放的轴点坐标
+- ScaleAnimation(float fromX, float toX, float fromY, float toY, int pivotXType, float pivotXValue, int pivotYType, float pivotYValue):在二的基础上可以指定轴点的类型
+
+旋转动画:RotateAnimation
+
+https://developer.android.com/reference/android/view/animation/RotateAnimation.html
+
+构造函数参数分为三种,角度,旋转轴点,比例系数
+
+透明度动画:AlphaAnimation
+
+https://developer.android.com/reference/android/view/animation/AlphaAnimation.html
+
+很简单的参数,只有透明度的比例系数
+
+动画合集:AnimationSet
+
+https://developer.android.com/reference/android/view/animation/AnimationSet.html
+
+## Animation API小结
+
+可以在xml中做的,也可以在代码里面做到
+
+动画的构造函数参数要么是绝对的像素值,要么是相对某个View的比例值。
+
+## Animation 实现原理
+
+研究动画,如何实现,应该对其原理进行分析才对。
+
+## 自定义 Animation
+
+[Android之自定义Animation动画](http://www.apkbus.com/blog-104974-52806.html)
+
+
+为什么一定是重写 initialize 和 applyTransformation 两个函数?从何处得知
+
+先搞定如何继承那两个函数来实现自定义动画效果的问题
+
+再通过 加断点 和 打Log 来调试,验证整个动画的实现流程。
+
+矩阵知识,以及矩阵生成的XY轴的图如何展示(有什么工具可以画出来吗)
+
+## 关于 Matrix
+
+Matrix 是一个 3 X 3 的矩阵
+
+不懂矩阵的乘法,可以查看阮一峰先生的博文 [理解矩阵乘法](http://www.ruanyifeng.com/blog/2015/09/matrix-multiplication.html),或者去维基百科。
+
+详细介绍 Android Matrix 矩阵的文章:
+
+Android Matrix理论与应用详解 http://zensheno.blog.51cto.com/2712776/513652
+
+Android Matrix:http://www.cnblogs.com/qiengo/archive/2012/06/30/2570874.html
+
diff --git a/src/main/java/com/clock/study/activity/AnimationActivity.java b/src/main/java/com/clock/study/activity/AnimationActivity.java
index 8a44471..cd1e9df 100644
--- a/src/main/java/com/clock/study/activity/AnimationActivity.java
+++ b/src/main/java/com/clock/study/activity/AnimationActivity.java
@@ -13,6 +13,7 @@
import com.clock.study.R;
import com.clock.study.animation.CustomAnimation;
+import com.clock.study.animation.SimpleCustomAnimation;
/**
* Android动画效果实现复习
@@ -24,6 +25,7 @@ public class AnimationActivity extends AppCompatActivity implements View.OnClick
private Button mBtnRotate;
private Button mBtnAlpha;
private Button mBtnSet;
+ private Button mBtnSimpleCustom;
private Button mBtnCustom;
@Override
@@ -46,6 +48,9 @@ protected void onCreate(Bundle savedInstanceState) {
mBtnSet = (Button) findViewById(R.id.btn_set);
mBtnSet.setOnClickListener(this);
+ mBtnSimpleCustom = (Button) findViewById(R.id.btn_simple_custom_anim);
+ mBtnSimpleCustom.setOnClickListener(this);
+
mBtnCustom = (Button) findViewById(R.id.btn_custom_anim);
mBtnCustom.setOnClickListener(this);
@@ -96,6 +101,12 @@ public void onClick(View v) {
animSet.addAnimation(alphaAnim);
mBtnSet.startAnimation(animSet);
+ } else if (viewId == R.id.btn_simple_custom_anim) {
+
+ SimpleCustomAnimation simpleCustomAnim = new SimpleCustomAnimation();//简单的自定义动画效果
+ simpleCustomAnim.setDuration(1000);
+ mBtnSimpleCustom.startAnimation(simpleCustomAnim);
+
} else if (viewId == R.id.btn_custom_anim) {
CustomAnimation customAnim = new CustomAnimation();//仿QQ抖屏动画效果
diff --git a/src/main/java/com/clock/study/activity/MainActivity.java b/src/main/java/com/clock/study/activity/MainActivity.java
index ac99e05..b1d1da5 100644
--- a/src/main/java/com/clock/study/activity/MainActivity.java
+++ b/src/main/java/com/clock/study/activity/MainActivity.java
@@ -15,7 +15,7 @@ protected void onCreate(Bundle savedInstanceState) {
setContentView(R.layout.activity_main);
findViewById(R.id.btn_camera_take_photo).setOnClickListener(this);
- findViewById(R.id.btn_android_anim).setOnClickListener(this);
+ findViewById(R.id.btn_animation).setOnClickListener(this);
}
@Override
@@ -24,7 +24,7 @@ public void onClick(View v) {
if (viewId == R.id.btn_camera_take_photo) {
Intent takePhotoIntent = new Intent(this, CapturePhotoActivity.class);
startActivity(takePhotoIntent);
- } else if (viewId == R.id.btn_android_anim) {
+ } else if (viewId == R.id.btn_animation) {
Intent androidAnimIntent = new Intent(this, AnimationActivity.class);
startActivity(androidAnimIntent);
}
diff --git a/src/main/java/com/clock/study/animation/CustomAnimation.java b/src/main/java/com/clock/study/animation/CustomAnimation.java
index d78eb02..dcd5dd0 100644
--- a/src/main/java/com/clock/study/animation/CustomAnimation.java
+++ b/src/main/java/com/clock/study/animation/CustomAnimation.java
@@ -15,11 +15,13 @@ public class CustomAnimation extends Animation {
@Override
protected void applyTransformation(float interpolatedTime, Transformation t) {
- Log.i(TAG, "applyTransformation");
t.getMatrix().setTranslate(
(float) Math.sin(interpolatedTime * 50) * 8,
(float) Math.sin(interpolatedTime * 50) * 8
);// 50越大频率越高,8越小振幅越小
- super.applyTransformation(interpolatedTime, t);
+ Log.i(TAG, "-------------applyTransformation-------------");
+ Log.i(TAG, "interpolatedTime:" + interpolatedTime);//动画持续的时间,时间比例系数(0.0 到 1.0)之间
+ Log.i(TAG, "transformation:" + t);//控制动画效果,Transformation包含两个信息,一个Alpha值,一个Matrix矩阵
+ Log.i(TAG, "-------------applyTransformation-------------");
}
}
diff --git a/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java b/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
new file mode 100644
index 0000000..0ef58bc
--- /dev/null
+++ b/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
@@ -0,0 +1,46 @@
+package com.clock.study.animation;
+
+import android.graphics.Matrix;
+import android.util.Log;
+import android.view.animation.Animation;
+import android.view.animation.Transformation;
+
+/**
+ * Created by Clock on 2016/7/9.
+ */
+public class SimpleCustomAnimation extends Animation {
+
+ private final static String TAG = SimpleCustomAnimation.class.getSimpleName();
+
+ private int mWidth, mHeight;
+
+ @Override
+ public void initialize(int width, int height, int parentWidth, int parentHeight) {
+ Log.i(TAG, "-------------initialize-------------");
+ Log.i(TAG, "width:" + width);
+ Log.i(TAG, "height:" + height);
+ Log.i(TAG, "parentWidth:" + parentWidth);
+ Log.i(TAG, "parentHeight:" + parentHeight);
+ Log.i(TAG, "-------------initialize-------------");
+ super.initialize(width, height, parentWidth, parentHeight);
+ this.mWidth = width;
+ this.mHeight = height;
+ }
+
+ @Override
+ protected void applyTransformation(float interpolatedTime, Transformation t) {
+ Matrix matrix = t.getMatrix();
+ //matrix.setTranslate((float) Math.sin(interpolatedTime * 50), interpolatedTime * 350);
+ //matrix.setRotate(interpolatedTime * 90);
+ //matrix.setScale(interpolatedTime * 3, interpolatedTime * 3);
+ //matrix.setSkew(interpolatedTime * 2, 0);
+ //matrix.setSkew(0, interpolatedTime * 2);
+ //matrix.setTranslate(0, (float) Math.sin(interpolatedTime * 80) * 10);
+ matrix.setScale(interpolatedTime * 1, interpolatedTime * 1, mWidth / 2, mHeight / 2);//线性缩放
+ Log.i(TAG, "-------------applyTransformation-------------");
+ Log.i(TAG, "interpolatedTime:" + interpolatedTime);//动画持续的时间,时间比例系数(0.0 到 1.0)之间
+ Log.i(TAG, "transformation:" + t);//控制动画效果,Transformation包含两个信息,一个Alpha值,一个Matrix矩阵,这里的Matrix默认是一个单位矩阵
+ Log.i(TAG, "-------------applyTransformation-------------");
+
+ }
+}
diff --git a/src/main/res/layout/activity_android_anim.xml b/src/main/res/layout/activity_android_anim.xml
index 8189f07..9caa2f8 100644
--- a/src/main/res/layout/activity_android_anim.xml
+++ b/src/main/res/layout/activity_android_anim.xml
@@ -38,6 +38,12 @@
android:layout_height="wrap_content"
android:text="Animation Set" />
+
+
+ android:text="Android Animation" />
From 7dc5a51658e01ed40fa21a0ff66b3e3434ef70f1 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Wed, 13 Jul 2016 00:16:01 +0800
Subject: [PATCH 09/38] =?UTF-8?q?=E6=9B=B4=E6=96=B0Animation=E7=AC=94?=
=?UTF-8?q?=E8=AE=B0MD=EF=BC=8C=E4=BB=A5=E5=8F=8ASimpleAnimation=E7=B1=BB?=
=?UTF-8?q?=E5=AE=9E=E7=8E=B0?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
...2\250\347\224\273\357\274\232Animation\347\257\207.md" | 6 ++++++
.../com/clock/study/animation/SimpleCustomAnimation.java | 8 +++++++-
2 files changed, 13 insertions(+), 1 deletion(-)
diff --git "a/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md" "b/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
index 3151fb6..be88aa1 100644
--- "a/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
+++ "b/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
@@ -67,6 +67,7 @@ https://developer.android.com/reference/android/view/animation/AnimationSet.html
[Android之自定义Animation动画](http://www.apkbus.com/blog-104974-52806.html)
+http://www.cnblogs.com/wondertwo/p/5295976.html
为什么一定是重写 initialize 和 applyTransformation 两个函数?从何处得知
@@ -88,3 +89,8 @@ Android Matrix理论与应用详解 http://zensheno.blog.51cto.com/2712776/51365
Android Matrix:http://www.cnblogs.com/qiengo/archive/2012/06/30/2570874.html
+
+http://liam0205.me/2014/09/11/matplotlib-tutorial-zh-cn/
+
+http://www.cnblogs.com/rustfisher/p/5071494.html
+
diff --git a/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java b/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
index 0ef58bc..9012020 100644
--- a/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
+++ b/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
@@ -25,6 +25,8 @@ public void initialize(int width, int height, int parentWidth, int parentHeight)
super.initialize(width, height, parentWidth, parentHeight);
this.mWidth = width;
this.mHeight = height;
+ setFillAfter(true);
+ setDuration(15000);
}
@Override
@@ -36,7 +38,11 @@ protected void applyTransformation(float interpolatedTime, Transformation t) {
//matrix.setSkew(interpolatedTime * 2, 0);
//matrix.setSkew(0, interpolatedTime * 2);
//matrix.setTranslate(0, (float) Math.sin(interpolatedTime * 80) * 10);
- matrix.setScale(interpolatedTime * 1, interpolatedTime * 1, mWidth / 2, mHeight / 2);//线性缩放
+ //matrix.setScale(interpolatedTime * 1, interpolatedTime * 1, mWidth / 2, mHeight / 2);//线性缩放
+ float[] data = new float[9];
+ matrix.getValues(data);
+ data[Matrix.MPERSP_0] = interpolatedTime * 1;
+ matrix.setValues(data);
Log.i(TAG, "-------------applyTransformation-------------");
Log.i(TAG, "interpolatedTime:" + interpolatedTime);//动画持续的时间,时间比例系数(0.0 到 1.0)之间
Log.i(TAG, "transformation:" + t);//控制动画效果,Transformation包含两个信息,一个Alpha值,一个Matrix矩阵,这里的Matrix默认是一个单位矩阵
From 83ca5fb7266afde20ce182951971a5b1d4320990 Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Wed, 13 Jul 2016 20:47:56 +0800
Subject: [PATCH 10/38] just some update
---
...4\273\357\274\232Animation\347\257\207.md" | 24 +++++++------------
.../animation/SimpleCustomAnimation.java | 14 +++++++----
2 files changed, 18 insertions(+), 20 deletions(-)
diff --git "a/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md" "b/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
index be88aa1..f7eacd5 100644
--- "a/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
+++ "b/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
@@ -63,19 +63,17 @@ https://developer.android.com/reference/android/view/animation/AnimationSet.html
研究动画,如何实现,应该对其原理进行分析才对。
-## 自定义 Animation
-
-[Android之自定义Animation动画](http://www.apkbus.com/blog-104974-52806.html)
+跟 View 的绘制原理有关,需要了解。
-http://www.cnblogs.com/wondertwo/p/5295976.html
+Android 动画框架详解:https://www.ibm.com/developerworks/cn/opensource/os-cn-android-anmt1/
-为什么一定是重写 initialize 和 applyTransformation 两个函数?从何处得知
+## 自定义 Animation
-先搞定如何继承那两个函数来实现自定义动画效果的问题
+http://www.cnblogs.com/wondertwo/p/5295976.html
-再通过 加断点 和 打Log 来调试,验证整个动画的实现流程。
+矩阵知识,以及矩阵生成的XY轴的图如何展示(有什么工具可以画出来吗)Python http://liam0205.me/2014/09/11/matplotlib-tutorial-zh-cn/
-矩阵知识,以及矩阵生成的XY轴的图如何展示(有什么工具可以画出来吗)
+这些动画效果遵循的数学公式是什么?????
## 关于 Matrix
@@ -85,12 +83,8 @@ Matrix 是一个 3 X 3 的矩阵
详细介绍 Android Matrix 矩阵的文章:
-Android Matrix理论与应用详解 http://zensheno.blog.51cto.com/2712776/513652
-
-Android Matrix:http://www.cnblogs.com/qiengo/archive/2012/06/30/2570874.html
-
+Android Matrix矩阵详解:http://www.maplejaw.com/2016/06/21/Android-Matrix%E7%9F%A9%E9%98%B5%E8%AF%A6%E8%A7%A3/index.html
-http://liam0205.me/2014/09/11/matplotlib-tutorial-zh-cn/
-
-http://www.cnblogs.com/rustfisher/p/5071494.html
+Android Matrix理论与应用详解 http://zensheno.blog.51cto.com/2712776/513652
+Android Matrix:http://www.cnblogs.com/qiengo/archive/2012/06/30/2570874.html(透视那块,既然文档没有提,那就稍作解释然后忽略即可)
diff --git a/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java b/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
index 9012020..3817e9c 100644
--- a/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
+++ b/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
@@ -25,8 +25,8 @@ public void initialize(int width, int height, int parentWidth, int parentHeight)
super.initialize(width, height, parentWidth, parentHeight);
this.mWidth = width;
this.mHeight = height;
- setFillAfter(true);
- setDuration(15000);
+ /*setFillAfter(true);
+ setDuration(15000);*/
}
@Override
@@ -39,10 +39,14 @@ protected void applyTransformation(float interpolatedTime, Transformation t) {
//matrix.setSkew(0, interpolatedTime * 2);
//matrix.setTranslate(0, (float) Math.sin(interpolatedTime * 80) * 10);
//matrix.setScale(interpolatedTime * 1, interpolatedTime * 1, mWidth / 2, mHeight / 2);//线性缩放
- float[] data = new float[9];
+ /*float[] data = new float[9];
matrix.getValues(data);
- data[Matrix.MPERSP_0] = interpolatedTime * 1;
- matrix.setValues(data);
+ data[Matrix.MPERSP_1] = interpolatedTime * 1;
+ matrix.setValues(data);*/
+ matrix.preScale(interpolatedTime, interpolatedTime, mWidth / 2, mHeight / 2);
+ matrix.preRotate(interpolatedTime * 360, mWidth / 2, mHeight / 2);
+ matrix.preTranslate(-mWidth / 3, -mHeight / 2);
+ matrix.postTranslate(mWidth, mHeight);
Log.i(TAG, "-------------applyTransformation-------------");
Log.i(TAG, "interpolatedTime:" + interpolatedTime);//动画持续的时间,时间比例系数(0.0 到 1.0)之间
Log.i(TAG, "transformation:" + t);//控制动画效果,Transformation包含两个信息,一个Alpha值,一个Matrix矩阵,这里的Matrix默认是一个单位矩阵
From c76c67dff2834316958783e2beee39bb2431b64d Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Thu, 14 Jul 2016 08:38:43 +0800
Subject: [PATCH 11/38] update doucumentation
---
...7\224\273\357\274\232Animation\347\257\207.md" | 15 ++++++++++++---
.../study/animation/SimpleCustomAnimation.java | 13 +++++++------
2 files changed, 19 insertions(+), 9 deletions(-)
diff --git "a/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md" "b/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
index f7eacd5..a7f7d49 100644
--- "a/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
+++ "b/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
@@ -71,9 +71,12 @@ Android 动画框架详解:https://www.ibm.com/developerworks/cn/opensource/os
http://www.cnblogs.com/wondertwo/p/5295976.html
-矩阵知识,以及矩阵生成的XY轴的图如何展示(有什么工具可以画出来吗)Python http://liam0205.me/2014/09/11/matplotlib-tutorial-zh-cn/
+矩阵知识,以及矩阵生成的XY轴的图如何展示(有什么工具可以画出来吗)
+
+这些动画效果遵循的数学公式是什么????? http://blog.csdn.net/linmiansheng/article/details/18820599
+
+例子:http://www.apkbus.com/blog-104974-52806.html
-这些动画效果遵循的数学公式是什么?????
## 关于 Matrix
@@ -87,4 +90,10 @@ Android Matrix矩阵详解:http://www.maplejaw.com/2016/06/21/Android-Matrix%E
Android Matrix理论与应用详解 http://zensheno.blog.51cto.com/2712776/513652
-Android Matrix:http://www.cnblogs.com/qiengo/archive/2012/06/30/2570874.html(透视那块,既然文档没有提,那就稍作解释然后忽略即可)
+Android Matrix:http://www.cnblogs.com/qiengo/archive/2012/06/30/2570874.html (透视那块,既然文档没有提,那就稍作解释然后忽略即可)
+
+矩阵的左乘右乘法概念:http://www.cnblogs.com/ylwn817/archive/2011/12/15/2288921.html
+
+2D平面中关于矩阵(Matrix)跟图形变换的讲解: http://blog.csdn.net/linmiansheng/article/details/18801947
+
+Android中关于矩阵(Matrix)前乘后乘的一些认识:http://blog.csdn.net/linmiansheng/article/details/18820599
diff --git a/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java b/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
index 3817e9c..2fb1149 100644
--- a/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
+++ b/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
@@ -25,8 +25,8 @@ public void initialize(int width, int height, int parentWidth, int parentHeight)
super.initialize(width, height, parentWidth, parentHeight);
this.mWidth = width;
this.mHeight = height;
- /*setFillAfter(true);
- setDuration(15000);*/
+ //setFillAfter(true);
+ //setDuration(15000);
}
@Override
@@ -43,10 +43,11 @@ protected void applyTransformation(float interpolatedTime, Transformation t) {
matrix.getValues(data);
data[Matrix.MPERSP_1] = interpolatedTime * 1;
matrix.setValues(data);*/
- matrix.preScale(interpolatedTime, interpolatedTime, mWidth / 2, mHeight / 2);
- matrix.preRotate(interpolatedTime * 360, mWidth / 2, mHeight / 2);
- matrix.preTranslate(-mWidth / 3, -mHeight / 2);
- matrix.postTranslate(mWidth, mHeight);
+ matrix.preScale(interpolatedTime, interpolatedTime);
+ matrix.preRotate(interpolatedTime * 360);
+ //matrix.preTranslate(-mWidth / 2, -mHeight / 2);
+ matrix.postTranslate(mWidth / 2, mHeight / 2);
+ //t.setAlpha(interpolatedTime);
Log.i(TAG, "-------------applyTransformation-------------");
Log.i(TAG, "interpolatedTime:" + interpolatedTime);//动画持续的时间,时间比例系数(0.0 到 1.0)之间
Log.i(TAG, "transformation:" + t);//控制动画效果,Transformation包含两个信息,一个Alpha值,一个Matrix矩阵,这里的Matrix默认是一个单位矩阵
From 2e4f1e3b40107873c6a3a3d5b460411e261d7b4e Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Fri, 15 Jul 2016 19:31:20 +0800
Subject: [PATCH 12/38] add AnimationTestActivity
---
src/main/AndroidManifest.xml | 3 ++-
.../study/activity/AnimationTestActivity.java | 15 +++++++++++++++
.../study/animation/SimpleCustomAnimation.java | 2 +-
src/main/res/layout/activity_animation_test.xml | 12 ++++++++++++
4 files changed, 30 insertions(+), 2 deletions(-)
create mode 100644 src/main/java/com/clock/study/activity/AnimationTestActivity.java
create mode 100644 src/main/res/layout/activity_animation_test.xml
diff --git a/src/main/AndroidManifest.xml b/src/main/AndroidManifest.xml
index d753af2..e1a6c84 100644
--- a/src/main/AndroidManifest.xml
+++ b/src/main/AndroidManifest.xml
@@ -29,7 +29,8 @@
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/AnimationTestActivity.java b/src/main/java/com/clock/study/activity/AnimationTestActivity.java
new file mode 100644
index 0000000..d867986
--- /dev/null
+++ b/src/main/java/com/clock/study/activity/AnimationTestActivity.java
@@ -0,0 +1,15 @@
+package com.clock.study.activity;
+
+import android.support.v7.app.AppCompatActivity;
+import android.os.Bundle;
+
+import com.clock.study.R;
+
+public class AnimationTestActivity extends AppCompatActivity {
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ setContentView(R.layout.activity_animation_test);
+ }
+}
diff --git a/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java b/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
index 2fb1149..a068715 100644
--- a/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
+++ b/src/main/java/com/clock/study/animation/SimpleCustomAnimation.java
@@ -45,7 +45,7 @@ protected void applyTransformation(float interpolatedTime, Transformation t) {
matrix.setValues(data);*/
matrix.preScale(interpolatedTime, interpolatedTime);
matrix.preRotate(interpolatedTime * 360);
- //matrix.preTranslate(-mWidth / 2, -mHeight / 2);
+ matrix.preTranslate(-mWidth / 2, -mHeight / 2);
matrix.postTranslate(mWidth / 2, mHeight / 2);
//t.setAlpha(interpolatedTime);
Log.i(TAG, "-------------applyTransformation-------------");
diff --git a/src/main/res/layout/activity_animation_test.xml b/src/main/res/layout/activity_animation_test.xml
new file mode 100644
index 0000000..9f129d0
--- /dev/null
+++ b/src/main/res/layout/activity_animation_test.xml
@@ -0,0 +1,12 @@
+
+
+
+
From fcf9c6afb64c39011325559821182468d94791fe Mon Sep 17 00:00:00 2001
From: clock <1084991652clock@gmail.com>
Date: Sun, 17 Jul 2016 23:50:06 +0800
Subject: [PATCH 13/38] =?UTF-8?q?=E7=A7=BB=E9=99=A4=E6=97=A0=E5=85=B3?=
=?UTF-8?q?=E7=9A=84=E5=8A=A8=E7=94=BB=EF=BC=8C=E6=B7=BB=E5=8A=A0Matrix?=
=?UTF-8?q?=E7=AC=94=E8=AE=B0?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
...4\273\357\274\232Animation\347\257\207.md" | 99 ------------------
src/main/AndroidManifest.xml | 2 +-
.../study/activity/AnimationActivity.java | 16 +--
.../study/activity/AnimationTestActivity.java | 54 +++++++++-
.../study/animation/CustomAnimation.java | 27 -----
src/main/res/layout/activity_android_anim.xml | 6 --
.../res/layout/activity_animation_test.xml | 22 ++--
src/main/res/layout/list_view_test_item.xml | 37 +++++++
src/main/res/mipmap-xxhdpi/lufy.png | Bin 0 -> 183405 bytes
9 files changed, 108 insertions(+), 155 deletions(-)
delete mode 100644 "notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
delete mode 100644 src/main/java/com/clock/study/animation/CustomAnimation.java
create mode 100644 src/main/res/layout/list_view_test_item.xml
create mode 100644 src/main/res/mipmap-xxhdpi/lufy.png
diff --git "a/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md" "b/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
deleted file mode 100644
index a7f7d49..0000000
--- "a/notes/Android\345\212\250\347\224\273\357\274\232Animation\347\257\207.md"
+++ /dev/null
@@ -1,99 +0,0 @@
-# 深入掌握 Animation 动画实现
-
-## applyTransformation
-
-传入两个参数 void applyTransformation (float interpolatedTime, Transformation t)
-
-interpolatedTime:时间比例系数,由0变化到1;
-t:包含两个部分,一个Alpha值和一个Matrix矩阵,Matrix默认是一个3X3的单位矩阵
-
-https://developer.android.com/reference/android/view/animation/Animation.html#applyTransformation(float, android.view.animation.Transformation)
-
-## 画图
-
-用 Python 的 MatPlotLib 来绘制一些正弦或者余弦的坐标图
-
-## Animation
-
-Animation动画只能对View起作用,能对View实现动画效果,但是View实际的触摸区域却没有发生改变
-
-偏移动画:TranslateAnimation,为 View 制造偏移的动画效果
-
-https://developer.android.com/reference/android/view/animation/TranslateAnimation.html
-
-TranslateAnimation动画的坐标值有以下三种类型
-
-- Animation.ABSOLUTE:绝对值,偏移量直接为像素数
-- Animation.RELATIVE_TO_SELF:相对值,偏移量为百分比,这个百分比相对于控件自身
-- Animation.RELATIVE_TO_PARENT:相对值,偏移量为百分比,这个百分比相对于控件的Parent
-
-缩放动画: ScaleAnimation,为 View 制造缩放的动画效果
-
-https://developer.android.com/reference/android/view/animation/ScaleAnimation.html
-
-构造函数有以下三类
-
-- ScaleAnimation (float fromX, float toX, float fromY, float toY):fromX、fromY是动画开始时的比例,toX、toY是动画结束时的比例。比例都是基于控件自身尺寸。
-- ScaleAnimation(float fromX, float toX, float fromY, float toY, float pivotX, float pivotY):在一的基础上可以指定缩放的轴点坐标
-- ScaleAnimation(float fromX, float toX, float fromY, float toY, int pivotXType, float pivotXValue, int pivotYType, float pivotYValue):在二的基础上可以指定轴点的类型
-
-旋转动画:RotateAnimation
-
-https://developer.android.com/reference/android/view/animation/RotateAnimation.html
-
-构造函数参数分为三种,角度,旋转轴点,比例系数
-
-透明度动画:AlphaAnimation
-
-https://developer.android.com/reference/android/view/animation/AlphaAnimation.html
-
-很简单的参数,只有透明度的比例系数
-
-动画合集:AnimationSet
-
-https://developer.android.com/reference/android/view/animation/AnimationSet.html
-
-## Animation API小结
-
-可以在xml中做的,也可以在代码里面做到
-
-动画的构造函数参数要么是绝对的像素值,要么是相对某个View的比例值。
-
-## Animation 实现原理
-
-研究动画,如何实现,应该对其原理进行分析才对。
-
-跟 View 的绘制原理有关,需要了解。
-
-Android 动画框架详解:https://www.ibm.com/developerworks/cn/opensource/os-cn-android-anmt1/
-
-## 自定义 Animation
-
-http://www.cnblogs.com/wondertwo/p/5295976.html
-
-矩阵知识,以及矩阵生成的XY轴的图如何展示(有什么工具可以画出来吗)
-
-这些动画效果遵循的数学公式是什么????? http://blog.csdn.net/linmiansheng/article/details/18820599
-
-例子:http://www.apkbus.com/blog-104974-52806.html
-
-
-## 关于 Matrix
-
-Matrix 是一个 3 X 3 的矩阵
-
-不懂矩阵的乘法,可以查看阮一峰先生的博文 [理解矩阵乘法](http://www.ruanyifeng.com/blog/2015/09/matrix-multiplication.html),或者去维基百科。
-
-详细介绍 Android Matrix 矩阵的文章:
-
-Android Matrix矩阵详解:http://www.maplejaw.com/2016/06/21/Android-Matrix%E7%9F%A9%E9%98%B5%E8%AF%A6%E8%A7%A3/index.html
-
-Android Matrix理论与应用详解 http://zensheno.blog.51cto.com/2712776/513652
-
-Android Matrix:http://www.cnblogs.com/qiengo/archive/2012/06/30/2570874.html (透视那块,既然文档没有提,那就稍作解释然后忽略即可)
-
-矩阵的左乘右乘法概念:http://www.cnblogs.com/ylwn817/archive/2011/12/15/2288921.html
-
-2D平面中关于矩阵(Matrix)跟图形变换的讲解: http://blog.csdn.net/linmiansheng/article/details/18801947
-
-Android中关于矩阵(Matrix)前乘后乘的一些认识:http://blog.csdn.net/linmiansheng/article/details/18820599
diff --git a/src/main/AndroidManifest.xml b/src/main/AndroidManifest.xml
index e1a6c84..7a0cbc0 100644
--- a/src/main/AndroidManifest.xml
+++ b/src/main/AndroidManifest.xml
@@ -30,7 +30,7 @@
android:label="@string/photo_preview"
android:screenOrientation="portrait" />
-
+
\ No newline at end of file
diff --git a/src/main/java/com/clock/study/activity/AnimationActivity.java b/src/main/java/com/clock/study/activity/AnimationActivity.java
index cd1e9df..523f1a9 100644
--- a/src/main/java/com/clock/study/activity/AnimationActivity.java
+++ b/src/main/java/com/clock/study/activity/AnimationActivity.java
@@ -1,7 +1,7 @@
package com.clock.study.activity;
-import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
+import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.view.animation.AlphaAnimation;
import android.view.animation.Animation;
@@ -12,7 +12,6 @@
import android.widget.Button;
import com.clock.study.R;
-import com.clock.study.animation.CustomAnimation;
import com.clock.study.animation.SimpleCustomAnimation;
/**
@@ -26,7 +25,6 @@ public class AnimationActivity extends AppCompatActivity implements View.OnClick
private Button mBtnAlpha;
private Button mBtnSet;
private Button mBtnSimpleCustom;
- private Button mBtnCustom;
@Override
protected void onCreate(Bundle savedInstanceState) {
@@ -51,9 +49,6 @@ protected void onCreate(Bundle savedInstanceState) {
mBtnSimpleCustom = (Button) findViewById(R.id.btn_simple_custom_anim);
mBtnSimpleCustom.setOnClickListener(this);
- mBtnCustom = (Button) findViewById(R.id.btn_custom_anim);
- mBtnCustom.setOnClickListener(this);
-
}
@Override
@@ -96,7 +91,9 @@ public void onClick(View v) {
AnimationSet animSet = new AnimationSet(true);
animSet.setDuration(2000);
RotateAnimation rotateAnim = new RotateAnimation(0, 360, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
+ ScaleAnimation scaleAnimation = new ScaleAnimation(0, 1, 0, 1, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
animSet.addAnimation(rotateAnim);
+ animSet.addAnimation(scaleAnimation);
AlphaAnimation alphaAnim = new AlphaAnimation(0, 1);
animSet.addAnimation(alphaAnim);
mBtnSet.startAnimation(animSet);
@@ -107,13 +104,6 @@ public void onClick(View v) {
simpleCustomAnim.setDuration(1000);
mBtnSimpleCustom.startAnimation(simpleCustomAnim);
- } else if (viewId == R.id.btn_custom_anim) {
-
- CustomAnimation customAnim = new CustomAnimation();//仿QQ抖屏动画效果
- customAnim.setDuration(1000);
- customAnim.setRepeatCount(3);
- mBtnCustom.startAnimation(customAnim);
-
}
}
diff --git a/src/main/java/com/clock/study/activity/AnimationTestActivity.java b/src/main/java/com/clock/study/activity/AnimationTestActivity.java
index d867986..187e5ed 100644
--- a/src/main/java/com/clock/study/activity/AnimationTestActivity.java
+++ b/src/main/java/com/clock/study/activity/AnimationTestActivity.java
@@ -2,14 +2,66 @@
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
+import android.view.View;
+import android.view.ViewGroup;
+import android.view.animation.Animation;
+import android.widget.BaseAdapter;
+import android.widget.ListView;
import com.clock.study.R;
+import com.clock.study.animation.SimpleCustomAnimation;
-public class AnimationTestActivity extends AppCompatActivity {
+/**
+ * 测试Animation动画效果
+ */
+public class AnimationTestActivity extends AppCompatActivity implements View.OnClickListener {
+
+ private ListView mTestListView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_animation_test);
+
+ mTestListView = (ListView) findViewById(R.id.list_view_test);
+ mTestListView.setAdapter(new SimpleTestListAdapter());
+
+ findViewById(R.id.btn_test_anim).setOnClickListener(this);
+ }
+
+ @Override
+ public void onClick(View v) {
+ int viewId = v.getId();
+ if (viewId == R.id.btn_test_anim) {
+ Animation animation = new SimpleCustomAnimation();
+ animation.setDuration(1000);
+ mTestListView.startAnimation(animation);
+ }
+ }
+
+ private class SimpleTestListAdapter extends BaseAdapter {
+
+ @Override
+ public int getCount() {
+ return 20;
+ }
+
+ @Override
+ public Object getItem(int position) {
+ return position;
+ }
+
+ @Override
+ public long getItemId(int position) {
+ return 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);
+ }
+ return convertView;
+ }
}
}
diff --git a/src/main/java/com/clock/study/animation/CustomAnimation.java b/src/main/java/com/clock/study/animation/CustomAnimation.java
deleted file mode 100644
index dcd5dd0..0000000
--- a/src/main/java/com/clock/study/animation/CustomAnimation.java
+++ /dev/null
@@ -1,27 +0,0 @@
-package com.clock.study.animation;
-
-import android.util.Log;
-import android.view.animation.Animation;
-import android.view.animation.Transformation;
-
-/**
- * 自定义Android的Animation动画,仿QQ窗口抖动动画
- *
- * Created by Clock on 2016/7/5.
- */
-public class CustomAnimation extends Animation {
-
- private final static String TAG = CustomAnimation.class.getSimpleName();
-
- @Override
- protected void applyTransformation(float interpolatedTime, Transformation t) {
- t.getMatrix().setTranslate(
- (float) Math.sin(interpolatedTime * 50) * 8,
- (float) Math.sin(interpolatedTime * 50) * 8
- );// 50越大频率越高,8越小振幅越小
- Log.i(TAG, "-------------applyTransformation-------------");
- Log.i(TAG, "interpolatedTime:" + interpolatedTime);//动画持续的时间,时间比例系数(0.0 到 1.0)之间
- Log.i(TAG, "transformation:" + t);//控制动画效果,Transformation包含两个信息,一个Alpha值,一个Matrix矩阵
- Log.i(TAG, "-------------applyTransformation-------------");
- }
-}
diff --git a/src/main/res/layout/activity_android_anim.xml b/src/main/res/layout/activity_android_anim.xml
index 9caa2f8..facc04c 100644
--- a/src/main/res/layout/activity_android_anim.xml
+++ b/src/main/res/layout/activity_android_anim.xml
@@ -43,10 +43,4 @@
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Simple Custom Animation " />
-
-
\ No newline at end of file
diff --git a/src/main/res/layout/activity_animation_test.xml b/src/main/res/layout/activity_animation_test.xml
index 9f129d0..1fa31c6 100644
--- a/src/main/res/layout/activity_animation_test.xml
+++ b/src/main/res/layout/activity_animation_test.xml
@@ -1,12 +1,18 @@
-
+ android:orientation="vertical">
-
+
+
+
+
diff --git a/src/main/res/layout/list_view_test_item.xml b/src/main/res/layout/list_view_test_item.xml
new file mode 100644
index 0000000..78b3558
--- /dev/null
+++ b/src/main/res/layout/list_view_test_item.xml
@@ -0,0 +1,37 @@
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/main/res/mipmap-xxhdpi/lufy.png b/src/main/res/mipmap-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^
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