2 Komitmen 0c13a726fa ... 20a9076686

Pembuat SHA1 Pesan Tanggal
  liuqilin 20a9076686 增加备份短码功能 7 tahun lalu
  liuqilin 546c0a404d backup 7 tahun lalu
41 mengubah file dengan 5328 tambahan dan 4336 penghapusan
  1. TEMPAT SAMPAH
      .vs/Garden5_2017/v15/Server/sqlite3/storage.ide
  2. 32 0
      Assets/Plugins/Alipay/IOS/AlipaySDK.framework.meta
  3. 69 0
      Assets/Resource/Animations/Credit.controller
  4. 10 0
      Assets/Resource/Animations/Credit.controller.meta
  5. 155 0
      Assets/Resource/Animations/CreditAnimation.anim
  6. 10 0
      Assets/Resource/Animations/CreditAnimation.anim.meta
  7. 4 608
      Assets/Resource/Logo.unity
  8. 271 0
      Assets/Resource/Prefab/Object/Garden.prefab
  9. 618 98
      Assets/Resource/Prefab/PrefabUI/Canvas.prefab
  10. 1 1
      Assets/Resource/Shader/DragonboneUGUIMat.mat
  11. 1 1
      Assets/Resource/Shader/GrayMat.mat
  12. 10 0
      Assets/Resource/Sprite/Editor/HotUpdate/NewFlower.meta
  13. 29 0
      Assets/Resource/Sprite/PhotoShop.renderTexture
  14. 10 0
      Assets/Resource/Sprite/PhotoShop.renderTexture.meta
  15. 1 1
      Assets/Resource/XML/PlayerConfig.xml
  16. 3 0
      Assets/Resource/XML/lan/ChineseSimplified.xml
  17. 2 0
      Assets/Resource/XML/lan/ChineseTraditional.xml
  18. 2 0
      Assets/Resource/XML/lan/English.xml
  19. TEMPAT SAMPAH
      Assets/Resource/Xlsx/language_config.xlsx
  20. 56 40
      Assets/Script/Label/CanvasLabel.cs
  21. 33 0
      Assets/Script/Label/LanguageLabel.cs
  22. 3447 3447
      Assets/Script/Manage/AnimManager.cs
  23. 128 21
      Assets/Script/Manage/ConfigManager.cs
  24. 14 0
      Assets/Script/Manage/HttpManager.cs
  25. 3 0
      Assets/Script/Manage/Initializer.cs
  26. 112 0
      Assets/Script/Manage/Panel/BackupIDPanel.cs
  27. 13 0
      Assets/Script/Manage/Panel/BackupIDPanel.cs.meta
  28. 34 0
      Assets/Script/Manage/PhotoShopCamera.cs
  29. 13 0
      Assets/Script/Manage/PhotoShopCamera.cs.meta
  30. 12 0
      Assets/Script/Manage/PlayerManager.cs
  31. 55 38
      Assets/Script/Manage/PlayerPrefManager.cs
  32. 2 2
      Assets/Script/Manage/UIManager.cs
  33. 20 1
      Assets/Script/Object/Player.cs
  34. 66 6
      Assets/Script/Social/FashionShowCloseBox.cs
  35. 8 2
      Assets/Script/Tool/Auxiliary.cs
  36. 66 61
      Assets/Script/Tool/Test.cs
  37. 4 4
      Assets/Tookits/LabelUtility/LabelUtility.prefab
  38. 1 0
      ProjectSettings/GraphicsSettings.asset
  39. 12 0
      ProjectSettings/QualitySettings.asset
  40. 1 1
      ProjectSettings/UnityConnectSettings.asset
  41. 0 4
      第五期.txt

TEMPAT SAMPAH
.vs/Garden5_2017/v15/Server/sqlite3/storage.ide


+ 32 - 0
Assets/Plugins/Alipay/IOS/AlipaySDK.framework.meta

@@ -0,0 +1,32 @@
+fileFormatVersion: 2
+guid: 786969225a8dc4e0eb4e00a91e7e1501
+folderAsset: yes
+timeCreated: 1502698138
+licenseType: Pro
+PluginImporter:
+  externalObjects: {}
+  serializedVersion: 2
+  iconMap: {}
+  executionOrder: {}
+  isPreloaded: 0
+  isOverridable: 0
+  platformData:
+  - first:
+      Any: 
+    second:
+      enabled: 0
+      settings: {}
+  - first:
+      Editor: Editor
+    second:
+      enabled: 0
+      settings:
+        DefaultValueInitialized: true
+  - first:
+      iPhone: iOS
+    second:
+      enabled: 1
+      settings: {}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 

+ 69 - 0
Assets/Resource/Animations/Credit.controller

@@ -0,0 +1,69 @@
+%YAML 1.1
+%TAG !u! tag:unity3d.com,2011:
+--- !u!91 &9100000
+AnimatorController:
+  m_ObjectHideFlags: 0
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 0}
+  m_Name: Credit
+  serializedVersion: 5
+  m_AnimatorParameters: []
+  m_AnimatorLayers:
+  - serializedVersion: 5
+    m_Name: Base Layer
+    m_StateMachine: {fileID: 1107703467221588716}
+    m_Mask: {fileID: 0}
+    m_Motions: []
+    m_Behaviours: []
+    m_BlendingMode: 0
+    m_SyncedLayerIndex: -1
+    m_DefaultWeight: 0
+    m_IKPass: 0
+    m_SyncedLayerAffectsTiming: 0
+    m_Controller: {fileID: 9100000}
+--- !u!1102 &1102471154494222088
+AnimatorState:
+  serializedVersion: 5
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 0}
+  m_Name: CreditAnimation
+  m_Speed: 0.075
+  m_CycleOffset: 0
+  m_Transitions: []
+  m_StateMachineBehaviours: []
+  m_Position: {x: 50, y: 50, z: 0}
+  m_IKOnFeet: 0
+  m_WriteDefaultValues: 1
+  m_Mirror: 0
+  m_SpeedParameterActive: 0
+  m_MirrorParameterActive: 0
+  m_CycleOffsetParameterActive: 0
+  m_TimeParameterActive: 0
+  m_Motion: {fileID: 7400000, guid: 114751d93e650564083a2133a0704c8c, type: 2}
+  m_Tag: 
+  m_SpeedParameter: 
+  m_MirrorParameter: 
+  m_CycleOffsetParameter: 
+  m_TimeParameter: 
+--- !u!1107 &1107703467221588716
+AnimatorStateMachine:
+  serializedVersion: 5
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 0}
+  m_Name: Base Layer
+  m_ChildStates:
+  - serializedVersion: 1
+    m_State: {fileID: 1102471154494222088}
+    m_Position: {x: 312, y: 156, z: 0}
+  m_ChildStateMachines: []
+  m_AnyStateTransitions: []
+  m_EntryTransitions: []
+  m_StateMachineTransitions: {}
+  m_StateMachineBehaviours: []
+  m_AnyStatePosition: {x: 50, y: 20, z: 0}
+  m_EntryPosition: {x: 50, y: 120, z: 0}
+  m_ExitPosition: {x: 800, y: 120, z: 0}
+  m_ParentStateMachinePosition: {x: 800, y: 20, z: 0}
+  m_DefaultState: {fileID: 1102471154494222088}

+ 10 - 0
Assets/Resource/Animations/Credit.controller.meta

@@ -0,0 +1,10 @@
+fileFormatVersion: 2
+guid: 600ce29782a14244cb165426375fe30d
+timeCreated: 1525935167
+licenseType: Pro
+NativeFormatImporter:
+  externalObjects: {}
+  mainObjectFileID: 9100000
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 

+ 155 - 0
Assets/Resource/Animations/CreditAnimation.anim

@@ -0,0 +1,155 @@
+%YAML 1.1
+%TAG !u! tag:unity3d.com,2011:
+--- !u!74 &7400000
+AnimationClip:
+  m_ObjectHideFlags: 0
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 0}
+  m_Name: CreditAnimation
+  serializedVersion: 6
+  m_Legacy: 0
+  m_Compressed: 0
+  m_UseHighQualityCurve: 1
+  m_RotationCurves: []
+  m_CompressedRotationCurves: []
+  m_EulerCurves: []
+  m_PositionCurves: []
+  m_ScaleCurves: []
+  m_FloatCurves:
+  - curve:
+      serializedVersion: 2
+      m_Curve:
+      - serializedVersion: 2
+        time: 0
+        value: 0.50003
+        inSlope: 0
+        outSlope: 0
+        tangentMode: 136
+      - serializedVersion: 2
+        time: 1
+        value: 0.50003
+        inSlope: 0
+        outSlope: 0
+        tangentMode: 136
+      m_PreInfinity: 2
+      m_PostInfinity: 2
+      m_RotationOrder: 4
+    attribute: m_AnchoredPosition.x
+    path: 
+    classID: 224
+    script: {fileID: 0}
+  - curve:
+      serializedVersion: 2
+      m_Curve:
+      - serializedVersion: 2
+        time: 0
+        value: -500
+        inSlope: 0
+        outSlope: 1372
+        tangentMode: 69
+      - serializedVersion: 2
+        time: 1
+        value: 872
+        inSlope: 0
+        outSlope: 0
+        tangentMode: 136
+      m_PreInfinity: 2
+      m_PostInfinity: 2
+      m_RotationOrder: 4
+    attribute: m_AnchoredPosition.y
+    path: 
+    classID: 224
+    script: {fileID: 0}
+  m_PPtrCurves: []
+  m_SampleRate: 60
+  m_WrapMode: 0
+  m_Bounds:
+    m_Center: {x: 0, y: 0, z: 0}
+    m_Extent: {x: 0, y: 0, z: 0}
+  m_ClipBindingConstant:
+    genericBindings:
+    - serializedVersion: 2
+      path: 0
+      attribute: 538195251
+      script: {fileID: 0}
+      typeID: 224
+      customType: 0
+      isPPtrCurve: 0
+    - serializedVersion: 2
+      path: 0
+      attribute: 1460864421
+      script: {fileID: 0}
+      typeID: 224
+      customType: 0
+      isPPtrCurve: 0
+    pptrCurveMapping: []
+  m_AnimationClipSettings:
+    serializedVersion: 2
+    m_AdditiveReferencePoseClip: {fileID: 0}
+    m_AdditiveReferencePoseTime: 0
+    m_StartTime: 0
+    m_StopTime: 1
+    m_OrientationOffsetY: 0
+    m_Level: 0
+    m_CycleOffset: 0
+    m_HasAdditiveReferencePose: 0
+    m_LoopTime: 0
+    m_LoopBlend: 0
+    m_LoopBlendOrientation: 0
+    m_LoopBlendPositionY: 0
+    m_LoopBlendPositionXZ: 0
+    m_KeepOriginalOrientation: 0
+    m_KeepOriginalPositionY: 1
+    m_KeepOriginalPositionXZ: 0
+    m_HeightFromFeet: 0
+    m_Mirror: 0
+  m_EditorCurves:
+  - curve:
+      serializedVersion: 2
+      m_Curve:
+      - serializedVersion: 2
+        time: 0
+        value: 0.50003
+        inSlope: 0
+        outSlope: 0
+        tangentMode: 136
+      - serializedVersion: 2
+        time: 1
+        value: 0.50003
+        inSlope: 0
+        outSlope: 0
+        tangentMode: 136
+      m_PreInfinity: 2
+      m_PostInfinity: 2
+      m_RotationOrder: 4
+    attribute: m_AnchoredPosition.x
+    path: 
+    classID: 224
+    script: {fileID: 0}
+  - curve:
+      serializedVersion: 2
+      m_Curve:
+      - serializedVersion: 2
+        time: 0
+        value: -500
+        inSlope: 0
+        outSlope: 1372
+        tangentMode: 69
+      - serializedVersion: 2
+        time: 1
+        value: 872
+        inSlope: 0
+        outSlope: 0
+        tangentMode: 136
+      m_PreInfinity: 2
+      m_PostInfinity: 2
+      m_RotationOrder: 4
+    attribute: m_AnchoredPosition.y
+    path: 
+    classID: 224
+    script: {fileID: 0}
+  m_EulerEditorCurves: []
+  m_HasGenericRootTransform: 0
+  m_HasMotionFloatCurves: 0
+  m_GenerateMotionCurves: 0
+  m_Events: []

+ 10 - 0
Assets/Resource/Animations/CreditAnimation.anim.meta

@@ -0,0 +1,10 @@
+fileFormatVersion: 2
+guid: 114751d93e650564083a2133a0704c8c
+timeCreated: 1525935197
+licenseType: Pro
+NativeFormatImporter:
+  externalObjects: {}
+  mainObjectFileID: 7400000
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 

+ 4 - 608
Assets/Resource/Logo.unity

@@ -341,7 +341,7 @@ RectTransform:
   m_PrefabInternal: {fileID: 0}
   m_GameObject: {fileID: 841147520}
   m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
-  m_LocalPosition: {x: 431.5, y: 242.5, z: 0}
+  m_LocalPosition: {x: 488.5, y: 275, z: 0}
   m_LocalScale: {x: 1, y: 1, z: 1}
   m_Children:
   - {fileID: 722194762}
@@ -441,609 +441,6 @@ Transform:
   m_Father: {fileID: 0}
   m_RootOrder: 2
   m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
---- !u!1001 &1410421050
-Prefab:
-  m_ObjectHideFlags: 0
-  serializedVersion: 2
-  m_Modification:
-    m_TransformParent: {fileID: 0}
-    m_Modifications:
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 431.5
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 242.5
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.z
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalRotation.x
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalRotation.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalRotation.z
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalRotation.w
-      value: 1
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_RootOrder
-      value: 4
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_AnchoredPosition.x
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_AnchoredPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_SizeDelta.x
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_SizeDelta.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_AnchorMin.x
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_AnchorMin.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_AnchorMax.x
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_AnchorMax.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_Pivot.x
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229560457679016, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_Pivot.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224086116989199640, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 281.09998
-      objectReference: {fileID: 0}
-    - target: {fileID: 224086116989199640, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -362.65698
-      objectReference: {fileID: 0}
-    - target: {fileID: 224091459645508686, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -154.70001
-      objectReference: {fileID: 0}
-    - target: {fileID: 224099813649884984, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 433.65
-      objectReference: {fileID: 0}
-    - target: {fileID: 224099813649884984, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 411.42175
-      objectReference: {fileID: 0}
-    - target: {fileID: 224112471647553194, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -28.749512
-      objectReference: {fileID: 0}
-    - target: {fileID: 224120953201147624, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 512.5755
-      objectReference: {fileID: 0}
-    - target: {fileID: 224150419401261650, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 161.23474
-      objectReference: {fileID: 0}
-    - target: {fileID: 224150419401261650, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 354.55173
-      objectReference: {fileID: 0}
-    - target: {fileID: 224184519637183256, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -0.00018310547
-      objectReference: {fileID: 0}
-    - target: {fileID: 224184519637183256, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 443.797
-      objectReference: {fileID: 0}
-    - target: {fileID: 224205480760145378, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 433.65
-      objectReference: {fileID: 0}
-    - target: {fileID: 224205480760145378, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 361.64175
-      objectReference: {fileID: 0}
-    - target: {fileID: 224210425470604074, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 433.65
-      objectReference: {fileID: 0}
-    - target: {fileID: 224210425470604074, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 361.64175
-      objectReference: {fileID: 0}
-    - target: {fileID: 224229987913313428, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -28.749512
-      objectReference: {fileID: 0}
-    - target: {fileID: 224246745822826590, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 107.399994
-      objectReference: {fileID: 0}
-    - target: {fileID: 224246745822826590, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 558.729
-      objectReference: {fileID: 0}
-    - target: {fileID: 224265650823470674, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224275068483267696, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224299276166683738, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 512.7435
-      objectReference: {fileID: 0}
-    - target: {fileID: 224310892626649794, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 380.29993
-      objectReference: {fileID: 0}
-    - target: {fileID: 224310892626649794, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 131.21167
-      objectReference: {fileID: 0}
-    - target: {fileID: 224315228996335140, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 0.25003052
-      objectReference: {fileID: 0}
-    - target: {fileID: 224315228996335140, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0.026855469
-      objectReference: {fileID: 0}
-    - target: {fileID: 224385199567227060, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -0.000061035156
-      objectReference: {fileID: 0}
-    - target: {fileID: 224385448420456962, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224392598831522604, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224392598831522604, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224400564893835002, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -0.0008544922
-      objectReference: {fileID: 0}
-    - target: {fileID: 224426866187220190, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 203.79999
-      objectReference: {fileID: 0}
-    - target: {fileID: 224426866187220190, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -362.537
-      objectReference: {fileID: 0}
-    - target: {fileID: 224441247632943000, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -0.000061035156
-      objectReference: {fileID: 0}
-    - target: {fileID: 224447031464319014, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 0.00030517578
-      objectReference: {fileID: 0}
-    - target: {fileID: 224447031464319014, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 512.55194
-      objectReference: {fileID: 0}
-    - target: {fileID: 224454810572374558, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -118.94
-      objectReference: {fileID: 0}
-    - target: {fileID: 224454810572374558, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 363.04865
-      objectReference: {fileID: 0}
-    - target: {fileID: 224457616253165912, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224484911662611480, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 281.09998
-      objectReference: {fileID: 0}
-    - target: {fileID: 224484911662611480, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -362.65698
-      objectReference: {fileID: 0}
-    - target: {fileID: 224522843245776806, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -267.5
-      objectReference: {fileID: 0}
-    - target: {fileID: 224522843245776806, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -517.907
-      objectReference: {fileID: 0}
-    - target: {fileID: 224531325457519484, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -356.80005
-      objectReference: {fileID: 0}
-    - target: {fileID: 224531325457519484, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 556.607
-      objectReference: {fileID: 0}
-    - target: {fileID: 224537139003440908, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 224.09833
-      objectReference: {fileID: 0}
-    - target: {fileID: 224537139003440908, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -587.90643
-      objectReference: {fileID: 0}
-    - target: {fileID: 224539019914823462, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 161.23492
-      objectReference: {fileID: 0}
-    - target: {fileID: 224539019914823462, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 503.68173
-      objectReference: {fileID: 0}
-    - target: {fileID: 224550188810486676, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -20
-      objectReference: {fileID: 0}
-    - target: {fileID: 224550188810486676, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 373.48956
-      objectReference: {fileID: 0}
-    - target: {fileID: 224554522440556642, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -37
-      objectReference: {fileID: 0}
-    - target: {fileID: 224554522440556642, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 439.1012
-      objectReference: {fileID: 0}
-    - target: {fileID: 224572059650207352, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -3.9002686
-      objectReference: {fileID: 0}
-    - target: {fileID: 224572059650207352, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -587.9064
-      objectReference: {fileID: 0}
-    - target: {fileID: 224580230788332784, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -4.000061
-      objectReference: {fileID: 0}
-    - target: {fileID: 224580230788332784, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -539.7279
-      objectReference: {fileID: 0}
-    - target: {fileID: 224609626671811272, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224651894813843656, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224658464670550476, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224692999868696848, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 554.907
-      objectReference: {fileID: 0}
-    - target: {fileID: 224705257369728430, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 281.09998
-      objectReference: {fileID: 0}
-    - target: {fileID: 224705257369728430, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -362.65698
-      objectReference: {fileID: 0}
-    - target: {fileID: 224716162044755026, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -297.69986
-      objectReference: {fileID: 0}
-    - target: {fileID: 224716162044755026, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 231.50699
-      objectReference: {fileID: 0}
-    - target: {fileID: 224722632151102834, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -129.5
-      objectReference: {fileID: 0}
-    - target: {fileID: 224722632151102834, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 307.73956
-      objectReference: {fileID: 0}
-    - target: {fileID: 224731758561882008, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 14.5
-      objectReference: {fileID: 0}
-    - target: {fileID: 224731758561882008, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 241.94559
-      objectReference: {fileID: 0}
-    - target: {fileID: 224747832885531626, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -356.80005
-      objectReference: {fileID: 0}
-    - target: {fileID: 224747832885531626, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 556.107
-      objectReference: {fileID: 0}
-    - target: {fileID: 224779440116827300, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -132.90002
-      objectReference: {fileID: 0}
-    - target: {fileID: 224779440116827300, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0.22125244
-      objectReference: {fileID: 0}
-    - target: {fileID: 224804073292249356, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 267.8
-      objectReference: {fileID: 0}
-    - target: {fileID: 224804073292249356, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 558.729
-      objectReference: {fileID: 0}
-    - target: {fileID: 224840547970510414, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 365
-      objectReference: {fileID: 0}
-    - target: {fileID: 224840547970510414, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -554.62695
-      objectReference: {fileID: 0}
-    - target: {fileID: 224843116074166976, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 551.78656
-      objectReference: {fileID: 0}
-    - target: {fileID: 224884269752229032, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 72.09894
-      objectReference: {fileID: 0}
-    - target: {fileID: 224884269752229032, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -587.90607
-      objectReference: {fileID: 0}
-    - target: {fileID: 224885158513677532, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224893316639651102, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: 149.0998
-      objectReference: {fileID: 0}
-    - target: {fileID: 224893316639651102, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -587.9066
-      objectReference: {fileID: 0}
-    - target: {fileID: 224927080000622308, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224961117816331688, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.x
-      value: -297.69998
-      objectReference: {fileID: 0}
-    - target: {fileID: 224961117816331688, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 231.50699
-      objectReference: {fileID: 0}
-    - target: {fileID: 1948781497737682, guid: 8647d80b558fa724a84d05f9e6aee9bc, type: 2}
-      propertyPath: m_Name
-      value: Canvas (1)
-      objectReference: {fileID: 0}
-    - target: {fileID: 224514817400265690, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224679397496895964, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: -36.20703
-      objectReference: {fileID: 0}
-    - target: {fileID: 224410250384729040, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224694386806689142, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224556376707151520, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224549302067237646, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224216352824261512, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224429567860854048, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224821526948636738, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224659296306368858, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224181304112279672, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224513441037128402, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224499353917912188, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 224317587197903578, guid: 8647d80b558fa724a84d05f9e6aee9bc,
-        type: 2}
-      propertyPath: m_LocalPosition.y
-      value: 0
-      objectReference: {fileID: 0}
-    - target: {fileID: 1948781497737682, guid: 8647d80b558fa724a84d05f9e6aee9bc, type: 2}
-      propertyPath: m_IsActive
-      value: 0
-      objectReference: {fileID: 0}
-    m_RemovedComponents: []
-  m_ParentPrefab: {fileID: 100100000, guid: 8647d80b558fa724a84d05f9e6aee9bc, type: 2}
-  m_IsPrefabParent: 0
 --- !u!1 &1511433816
 GameObject:
   m_ObjectHideFlags: 0
@@ -1257,10 +654,9 @@ MonoBehaviour:
   m_Name: 
   m_EditorClassIdentifier: 
   AuditEdition: 0
-  DebugMode: 1
-  CatchException: 0
-  DebugModeGo: {fileID: 1264531325540048, guid: b22fd2d9abc702d43ac62a412537d4e9,
-    type: 2}
+  DebugMode: 0
+  CatchException: 1
+  DebugModeGo: {fileID: 0}
 --- !u!4 &1833966245
 Transform:
   m_ObjectHideFlags: 0

+ 271 - 0
Assets/Resource/Prefab/Object/Garden.prefab

@@ -105,6 +105,21 @@ GameObject:
   m_NavMeshLayer: 0
   m_StaticEditorFlags: 0
   m_IsActive: 0
+--- !u!1 &1190183145941090
+GameObject:
+  m_ObjectHideFlags: 0
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 100100000}
+  serializedVersion: 5
+  m_Component:
+  - component: {fileID: 4024228029520060}
+  m_Layer: 5
+  m_Name: PhotoShop
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 0
 --- !u!1 &1256352428073408
 GameObject:
   m_ObjectHideFlags: 1
@@ -121,6 +136,22 @@ GameObject:
   m_NavMeshLayer: 0
   m_StaticEditorFlags: 0
   m_IsActive: 0
+--- !u!1 &1282667609278624
+GameObject:
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 100100000}
+  serializedVersion: 5
+  m_Component:
+  - component: {fileID: 4588216630637812}
+  - component: {fileID: 212563239013512148}
+  m_Layer: 0
+  m_Name: PhotoShopBg
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
 --- !u!1 &1313790546883648
 GameObject:
   m_ObjectHideFlags: 1
@@ -183,6 +214,22 @@ GameObject:
   m_NavMeshLayer: 0
   m_StaticEditorFlags: 0
   m_IsActive: 1
+--- !u!1 &1399450636664792
+GameObject:
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 100100000}
+  serializedVersion: 5
+  m_Component:
+  - component: {fileID: 4694261110752360}
+  - component: {fileID: 212722959070800348}
+  m_Layer: 0
+  m_Name: PhotoShopShadow
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
 --- !u!1 &1407192791261292
 GameObject:
   m_ObjectHideFlags: 1
@@ -415,6 +462,22 @@ GameObject:
   m_NavMeshLayer: 0
   m_StaticEditorFlags: 0
   m_IsActive: 1
+--- !u!1 &1613910783807824
+GameObject:
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 100100000}
+  serializedVersion: 5
+  m_Component:
+  - component: {fileID: 4040572101889252}
+  - component: {fileID: 20538975865931150}
+  m_Layer: 5
+  m_Name: PhotoShopCamera
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
 --- !u!1 &1665676138942020
 GameObject:
   m_ObjectHideFlags: 1
@@ -479,6 +542,21 @@ GameObject:
   m_NavMeshLayer: 0
   m_StaticEditorFlags: 0
   m_IsActive: 0
+--- !u!1 &1721322120182818
+GameObject:
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 100100000}
+  serializedVersion: 5
+  m_Component:
+  - component: {fileID: 4285244055568782}
+  m_Layer: 0
+  m_Name: PhotoShopPlayer
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
 --- !u!1 &1728925240400126
 GameObject:
   m_ObjectHideFlags: 1
@@ -671,6 +749,34 @@ Transform:
   m_Father: {fileID: 4257060777002720}
   m_RootOrder: 0
   m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+--- !u!4 &4024228029520060
+Transform:
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 100100000}
+  m_GameObject: {fileID: 1190183145941090}
+  m_LocalRotation: {x: -0, y: -0, z: -0, w: 1}
+  m_LocalPosition: {x: 0, y: -15.46, z: 0}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_Children:
+  - {fileID: 4588216630637812}
+  - {fileID: 4040572101889252}
+  m_Father: {fileID: 4257060777002720}
+  m_RootOrder: 3
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+--- !u!4 &4040572101889252
+Transform:
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 100100000}
+  m_GameObject: {fileID: 1613910783807824}
+  m_LocalRotation: {x: -0, y: -0, z: -0, w: 1}
+  m_LocalPosition: {x: 0, y: -0.45000076, z: 0}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_Children: []
+  m_Father: {fileID: 4024228029520060}
+  m_RootOrder: 1
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
 --- !u!4 &4068698844593858
 Transform:
   m_ObjectHideFlags: 1
@@ -794,6 +900,7 @@ Transform:
   - {fileID: 4008559618325982}
   - {fileID: 4576759688754552}
   - {fileID: 224526022893638850}
+  - {fileID: 4024228029520060}
   m_Father: {fileID: 0}
   m_RootOrder: 0
   m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
@@ -810,6 +917,19 @@ Transform:
   m_Father: {fileID: 4008559618325982}
   m_RootOrder: 3
   m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+--- !u!4 &4285244055568782
+Transform:
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 100100000}
+  m_GameObject: {fileID: 1721322120182818}
+  m_LocalRotation: {x: -0, y: -0, z: -0, w: 1}
+  m_LocalPosition: {x: -5.82, y: -3.33, z: -1}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_Children: []
+  m_Father: {fileID: 4588216630637812}
+  m_RootOrder: 0
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
 --- !u!4 &4321082446622300
 Transform:
   m_ObjectHideFlags: 1
@@ -1005,6 +1125,21 @@ Transform:
   m_Father: {fileID: 4008559618325982}
   m_RootOrder: 7
   m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+--- !u!4 &4588216630637812
+Transform:
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 100100000}
+  m_GameObject: {fileID: 1282667609278624}
+  m_LocalRotation: {x: -0, y: -0, z: -0, w: 1}
+  m_LocalPosition: {x: 0, y: -0.45000076, z: 2}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_Children:
+  - {fileID: 4285244055568782}
+  - {fileID: 4694261110752360}
+  m_Father: {fileID: 4024228029520060}
+  m_RootOrder: 0
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
 --- !u!4 &4594713365202588
 Transform:
   m_ObjectHideFlags: 1
@@ -1057,6 +1192,19 @@ Transform:
   m_Father: {fileID: 4008559618325982}
   m_RootOrder: 9
   m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+--- !u!4 &4694261110752360
+Transform:
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 100100000}
+  m_GameObject: {fileID: 1399450636664792}
+  m_LocalRotation: {x: -0, y: -0, z: -0, w: 1}
+  m_LocalPosition: {x: -5.84, y: -3.38, z: -1}
+  m_LocalScale: {x: 1.2, y: 1.2, z: 1.2}
+  m_Children: []
+  m_Father: {fileID: 4588216630637812}
+  m_RootOrder: 1
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
 --- !u!4 &4732436779443374
 Transform:
   m_ObjectHideFlags: 1
@@ -1205,6 +1353,41 @@ Transform:
   m_Father: {fileID: 4243570825903678}
   m_RootOrder: 4
   m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+--- !u!20 &20538975865931150
+Camera:
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 100100000}
+  m_GameObject: {fileID: 1613910783807824}
+  m_Enabled: 1
+  serializedVersion: 2
+  m_ClearFlags: 1
+  m_BackGroundColor: {r: 0.19215687, g: 0.3019608, b: 0.4745098, a: 0}
+  m_NormalizedViewPortRect:
+    serializedVersion: 2
+    x: 0
+    y: 0
+    width: 1
+    height: 1
+  near clip plane: 0.3
+  far clip plane: 1000
+  field of view: 60
+  orthographic: 1
+  orthographic size: 5.56
+  m_Depth: 0
+  m_CullingMask:
+    serializedVersion: 2
+    m_Bits: 4294967295
+  m_RenderingPath: -1
+  m_TargetTexture: {fileID: 8400000, guid: d34f4dbba81b1b743a561b7bfedd9de0, type: 2}
+  m_TargetDisplay: 0
+  m_TargetEye: 3
+  m_HDR: 1
+  m_AllowMSAA: 1
+  m_ForceIntoRT: 0
+  m_OcclusionCulling: 1
+  m_StereoConvergence: 10
+  m_StereoSeparation: 0.022
 --- !u!61 &61724106738148120
 BoxCollider2D:
   m_ObjectHideFlags: 1
@@ -1731,6 +1914,50 @@ SpriteRenderer:
   m_SpriteTileMode: 0
   m_WasSpriteAssigned: 1
   m_MaskInteraction: 0
+--- !u!212 &212563239013512148
+SpriteRenderer:
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 100100000}
+  m_GameObject: {fileID: 1282667609278624}
+  m_Enabled: 1
+  m_CastShadows: 0
+  m_ReceiveShadows: 0
+  m_DynamicOccludee: 1
+  m_MotionVectors: 1
+  m_LightProbeUsage: 1
+  m_ReflectionProbeUsage: 1
+  m_Materials:
+  - {fileID: 10754, guid: 0000000000000000f000000000000000, type: 0}
+  m_StaticBatchInfo:
+    firstSubMesh: 0
+    subMeshCount: 0
+  m_StaticBatchRoot: {fileID: 0}
+  m_ProbeAnchor: {fileID: 0}
+  m_LightProbeVolumeOverride: {fileID: 0}
+  m_ScaleInLightmap: 1
+  m_PreserveUVs: 0
+  m_IgnoreNormalsForChartDetection: 0
+  m_ImportantGI: 0
+  m_StitchLightmapSeams: 0
+  m_SelectedEditorRenderState: 0
+  m_MinimumChartSize: 4
+  m_AutoUVMaxDistance: 0.5
+  m_AutoUVMaxAngle: 89
+  m_LightmapParameters: {fileID: 0}
+  m_SortingLayerID: 0
+  m_SortingLayer: 0
+  m_SortingOrder: 0
+  m_Sprite: {fileID: 21300000, guid: f16cd7e57d83b50409772d65f476f475, type: 3}
+  m_Color: {r: 1, g: 1, b: 1, a: 1}
+  m_FlipX: 0
+  m_FlipY: 0
+  m_DrawMode: 0
+  m_Size: {x: 19.2, y: 10.8}
+  m_AdaptiveModeThreshold: 0.5
+  m_SpriteTileMode: 0
+  m_WasSpriteAssigned: 1
+  m_MaskInteraction: 0
 --- !u!212 &212678618548551084
 SpriteRenderer:
   m_ObjectHideFlags: 1
@@ -1819,6 +2046,50 @@ SpriteRenderer:
   m_SpriteTileMode: 0
   m_WasSpriteAssigned: 1
   m_MaskInteraction: 0
+--- !u!212 &212722959070800348
+SpriteRenderer:
+  m_ObjectHideFlags: 1
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 100100000}
+  m_GameObject: {fileID: 1399450636664792}
+  m_Enabled: 1
+  m_CastShadows: 0
+  m_ReceiveShadows: 0
+  m_DynamicOccludee: 1
+  m_MotionVectors: 1
+  m_LightProbeUsage: 1
+  m_ReflectionProbeUsage: 1
+  m_Materials:
+  - {fileID: 10754, guid: 0000000000000000f000000000000000, type: 0}
+  m_StaticBatchInfo:
+    firstSubMesh: 0
+    subMeshCount: 0
+  m_StaticBatchRoot: {fileID: 0}
+  m_ProbeAnchor: {fileID: 0}
+  m_LightProbeVolumeOverride: {fileID: 0}
+  m_ScaleInLightmap: 1
+  m_PreserveUVs: 0
+  m_IgnoreNormalsForChartDetection: 0
+  m_ImportantGI: 0
+  m_StitchLightmapSeams: 0
+  m_SelectedEditorRenderState: 0
+  m_MinimumChartSize: 4
+  m_AutoUVMaxDistance: 0.5
+  m_AutoUVMaxAngle: 89
+  m_LightmapParameters: {fileID: 0}
+  m_SortingLayerID: 0
+  m_SortingLayer: 0
+  m_SortingOrder: 0
+  m_Sprite: {fileID: 21300236, guid: c486bd2e1e577b24a86013546709abda, type: 3}
+  m_Color: {r: 1, g: 1, b: 1, a: 1}
+  m_FlipX: 0
+  m_FlipY: 0
+  m_DrawMode: 0
+  m_Size: {x: 2.1, y: 0.4}
+  m_AdaptiveModeThreshold: 0.5
+  m_SpriteTileMode: 0
+  m_WasSpriteAssigned: 1
+  m_MaskInteraction: 0
 --- !u!212 &212760045093916298
 SpriteRenderer:
   m_ObjectHideFlags: 1

File diff ditekan karena terlalu besar
+ 618 - 98
Assets/Resource/Prefab/PrefabUI/Canvas.prefab


+ 1 - 1
Assets/Resource/Shader/DragonboneUGUIMat.mat

@@ -8,7 +8,7 @@ Material:
   m_PrefabInternal: {fileID: 0}
   m_Name: DragonboneUGUIMat
   m_Shader: {fileID: 10770, guid: 0000000000000000f000000000000000, type: 0}
-  m_ShaderKeywords: UNITY_UI_CLIP_RECT _EMISSION
+  m_ShaderKeywords: _EMISSION
   m_LightmapFlags: 1
   m_EnableInstancingVariants: 0
   m_DoubleSidedGI: 0

+ 1 - 1
Assets/Resource/Shader/GrayMat.mat

@@ -8,7 +8,7 @@ Material:
   m_PrefabInternal: {fileID: 0}
   m_Name: GrayMat
   m_Shader: {fileID: 4800000, guid: ac390d8200b91bd419e2d7b9e580d07d, type: 3}
-  m_ShaderKeywords: UNITY_UI_CLIP_RECT _EMISSION
+  m_ShaderKeywords: _EMISSION
   m_LightmapFlags: 1
   m_EnableInstancingVariants: 0
   m_DoubleSidedGI: 0

+ 10 - 0
Assets/Resource/Sprite/Editor/HotUpdate/NewFlower.meta

@@ -0,0 +1,10 @@
+fileFormatVersion: 2
+guid: 46b274c8414a222419da71c9a4da16df
+folderAsset: yes
+timeCreated: 1516869190
+licenseType: Pro
+DefaultImporter:
+  externalObjects: {}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 

+ 29 - 0
Assets/Resource/Sprite/PhotoShop.renderTexture

@@ -0,0 +1,29 @@
+%YAML 1.1
+%TAG !u! tag:unity3d.com,2011:
+--- !u!84 &8400000
+RenderTexture:
+  m_ObjectHideFlags: 0
+  m_PrefabParentObject: {fileID: 0}
+  m_PrefabInternal: {fileID: 0}
+  m_Name: PhotoShop
+  m_ImageContentsHash:
+    serializedVersion: 2
+    Hash: 00000000000000000000000000000000
+  m_Width: 1024
+  m_Height: 576
+  m_AntiAliasing: 1
+  m_DepthFormat: 2
+  m_ColorFormat: 0
+  m_MipMap: 0
+  m_GenerateMips: 1
+  m_SRGB: 0
+  m_TextureSettings:
+    serializedVersion: 2
+    m_FilterMode: 1
+    m_Aniso: 0
+    m_MipBias: 0
+    m_WrapU: 1
+    m_WrapV: 1
+    m_WrapW: 1
+  m_Dimension: 2
+  m_VolumeDepth: 1

+ 10 - 0
Assets/Resource/Sprite/PhotoShop.renderTexture.meta

@@ -0,0 +1,10 @@
+fileFormatVersion: 2
+guid: d34f4dbba81b1b743a561b7bfedd9de0
+timeCreated: 1525923266
+licenseType: Pro
+NativeFormatImporter:
+  externalObjects: {}
+  mainObjectFileID: 8400000
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 

+ 1 - 1
Assets/Resource/XML/PlayerConfig.xml

@@ -1,5 +1,5 @@
 <PlayerConfig>
-  <Version value="39" />
+  <Version value="41" />
   <ReplayVersion value="1" />
   
   <ID value="Default" />

+ 3 - 0
Assets/Resource/XML/lan/ChineseSimplified.xml

@@ -119,6 +119,9 @@
 
 程序 水怪
 ]]></Lc_CreditsContent>
+    <Ld_Title desc=""><![CDATA[备份短码]]></Ld_Title>
+    <Ld_PlaceHolder desc=""><![CDATA[《我的甜蜜花园》
+我的用户短码为 : %NUM%]]></Ld_PlaceHolder>
     <M_Tit desc=""><![CDATA[成就]]></M_Tit>
     <J_Info0 desc=""><![CDATA[获得]]></J_Info0>
     <J_Info1 desc=""><![CDATA[使用技能:]]></J_Info1>

+ 2 - 0
Assets/Resource/XML/lan/ChineseTraditional.xml

@@ -119,6 +119,8 @@
 
 程式 水怪
 ]]></Lc_CreditsContent>
+    <Ld_Title desc=""><![CDATA[]]></Ld_Title>
+    <Ld_PlaceHolder desc=""><![CDATA[]]></Ld_PlaceHolder>
     <M_Tit desc=""><![CDATA[成就]]></M_Tit>
     <J_Info0 desc=""><![CDATA[獲得]]></J_Info0>
     <J_Info1 desc=""><![CDATA[使用技能:]]></J_Info1>

+ 2 - 0
Assets/Resource/XML/lan/English.xml

@@ -119,6 +119,8 @@ Music&Audio 十三叔
 
 Program 水怪
 ]]></Lc_CreditsContent>
+    <Ld_Title desc=""><![CDATA[]]></Ld_Title>
+    <Ld_PlaceHolder desc=""><![CDATA[]]></Ld_PlaceHolder>
     <M_Tit desc=""><![CDATA[Achievement]]></M_Tit>
     <J_Info0 desc=""><![CDATA[Get]]></J_Info0>
     <J_Info1 desc=""><![CDATA[Use skill:]]></J_Info1>

TEMPAT SAMPAH
Assets/Resource/Xlsx/language_config.xlsx


+ 56 - 40
Assets/Script/Label/CanvasLabel.cs

@@ -120,8 +120,11 @@ public class CanvasLabel
     public static string L_User = "L_User";
     public static string L_UserTit = "L_UserTit";
     public static string L_UserLab = "L_UserLab";
+    public static string L_UserBtns = "L_UserBtns";
     public static string L_ChangeBtn = "L_ChangeBtn";
     public static string L_ChangeLab = "L_ChangeLab";
+    public static string L_BackupBtn = "L_BackupBtn";
+    public static string L_BackupLab = "L_BackupLab";
     public static string L_ResetBtn = "L_ResetBtn";
     public static string L_ResetLab = "L_ResetLab";
     public static string L_Audio = "L_Audio";
@@ -176,6 +179,19 @@ public class CanvasLabel
     public static string Lc_Pos = "Lc_Pos";
     public static string Lc_CreditsContent = "Lc_CreditsContent";
     public static string Lc_CreditsIcon = "Lc_CreditsIcon";
+    public static string Ld_Info = "Ld_Info";
+    public static string Ld_Info0 = "Ld_Info0";
+    public static string Ld_Tit = "Ld_Tit";
+    public static string Ld_Cancel = "Ld_Cancel";
+    public static string Ld_CancelLab = "Ld_CancelLab";
+    public static string Ld_Confirm = "Ld_Confirm";
+    public static string Ld_ConfirmLab = "Ld_ConfirmLab";
+    public static string Ld_InputField0 = "Ld_InputField0";
+    public static string Ld_InputLab0 = "Ld_InputLab0";
+    public static string Ld_Placeholder0 = "Ld_Placeholder0";
+    public static string Ld_InputField = "Ld_InputField";
+    public static string Ld_InputLab = "Ld_InputLab";
+    public static string Ld_Placeholder = "Ld_Placeholder";
     public static string La_Info = "La_Info";
     public static string La_Info0 = "La_Info0";
     public static string La_Tit = "La_Tit";
@@ -770,33 +786,6 @@ public class CanvasLabel
     public static string S_ScrollRect = "S_ScrollRect";
     public static string S_Grid = "S_Grid";
     public static string S_Tit = "S_Tit";
-    public static string Z_PlazaRoomList = "Z_PlazaRoomList";
-    public static string Z_BK = "Z_BK";
-    public static string Z_Panel = "Z_Panel";
-    public static string Z_Create = "Z_Create";
-    public static string Z_CreateLab = "Z_CreateLab";
-    public static string Z_Close = "Z_Close";
-    public static string Z_CloseLab = "Z_CloseLab";
-    public static string Z_ScrollRect = "Z_ScrollRect";
-    public static string Z_Frame = "Z_Frame";
-    public static string Z_Grid = "Z_Grid";
-    public static string Z_Tit = "Z_Tit";
-    public static string Z_Info = "Z_Info";
-    public static string Z_Info0 = "Z_Info0";
-    public static string Z_InfoLab0 = "Z_InfoLab0";
-    public static string Z_Info1 = "Z_Info1";
-    public static string Z_InfoLab1 = "Z_InfoLab1";
-    public static string Z_Info2 = "Z_Info2";
-    public static string Z_InfoLab2 = "Z_InfoLab2";
-    public static string Z_Info3 = "Z_Info3";
-    public static string Z_InfoLab3 = "Z_InfoLab3";
-    public static string Z_Info4 = "Z_Info4";
-    public static string Z_InfoLab4 = "Z_InfoLab4";
-    public static string Z_Info5 = "Z_Info5";
-    public static string Z_InfoImg50 = "Z_InfoImg50";
-    public static string Z_InfoImg51 = "Z_InfoImg51";
-    public static string Z_InfoLab5 = "Z_InfoLab5";
-    public static string Z_Tip = "Z_Tip";
     public static string AA_CreatePlazaRoom = "AA_CreatePlazaRoom";
     public static string AA_Panel = "AA_Panel";
     public static string AA_Lab = "AA_Lab";
@@ -824,6 +813,33 @@ public class CanvasLabel
     public static string AAb_HandleSlideArea = "AAb_HandleSlideArea";
     public static string AAb_Handle = "AAb_Handle";
     public static string AA_Tip = "AA_Tip";
+    public static string Z_PlazaRoomList = "Z_PlazaRoomList";
+    public static string Z_BK = "Z_BK";
+    public static string Z_Panel = "Z_Panel";
+    public static string Z_Create = "Z_Create";
+    public static string Z_CreateLab = "Z_CreateLab";
+    public static string Z_Close = "Z_Close";
+    public static string Z_CloseLab = "Z_CloseLab";
+    public static string Z_ScrollRect = "Z_ScrollRect";
+    public static string Z_Frame = "Z_Frame";
+    public static string Z_Grid = "Z_Grid";
+    public static string Z_Tit = "Z_Tit";
+    public static string Z_Info = "Z_Info";
+    public static string Z_Info0 = "Z_Info0";
+    public static string Z_InfoLab0 = "Z_InfoLab0";
+    public static string Z_Info1 = "Z_Info1";
+    public static string Z_InfoLab1 = "Z_InfoLab1";
+    public static string Z_Info2 = "Z_Info2";
+    public static string Z_InfoLab2 = "Z_InfoLab2";
+    public static string Z_Info3 = "Z_Info3";
+    public static string Z_InfoLab3 = "Z_InfoLab3";
+    public static string Z_Info4 = "Z_Info4";
+    public static string Z_InfoLab4 = "Z_InfoLab4";
+    public static string Z_Info5 = "Z_Info5";
+    public static string Z_InfoImg50 = "Z_InfoImg50";
+    public static string Z_InfoImg51 = "Z_InfoImg51";
+    public static string Z_InfoLab5 = "Z_InfoLab5";
+    public static string Z_Tip = "Z_Tip";
     public static string W_HudParent = "W_HudParent";
     public static string I_BlackMask = "I_BlackMask";
     public static string I_Lab = "I_Lab";
@@ -913,19 +929,6 @@ public class CanvasLabel
     public static string O_Pos = "O_Pos";
     public static string O_Lab = "O_Lab";
     public static string V_BlackMask = "V_BlackMask";
-    public static string T_NickName = "T_NickName";
-    public static string T_NickNameBK = "T_NickNameBK";
-    public static string T_NickNameCard = "T_NickNameCard";
-    public static string T_CloseParent = "T_CloseParent";
-    public static string T_Close = "T_Close";
-    public static string T_Confirm = "T_Confirm";
-    public static string T_ConfirmLab = "T_ConfirmLab";
-    public static string T_Tit = "T_Tit";
-    public static string T_InputField = "T_InputField";
-    public static string T_InputLab = "T_InputLab";
-    public static string T_Random = "T_Random";
-    public static string T_CostTxt = "T_CostTxt";
-    public static string T_CostImagePlus = "T_CostImagePlus";
     public static string AC_EnterMinigamePanelMask = "AC_EnterMinigamePanelMask";
     public static string AC_EnterMinigamePanel = "AC_EnterMinigamePanel";
     public static string AC_Title = "AC_Title";
@@ -942,6 +945,19 @@ public class CanvasLabel
     public static string AC_ScrollPos2 = "AC_ScrollPos2";
     public static string AC_GamaTypeText0 = "AC_GamaTypeText0";
     public static string AC_GamaTypeText1 = "AC_GamaTypeText1";
+    public static string T_NickName = "T_NickName";
+    public static string T_NickNameBK = "T_NickNameBK";
+    public static string T_NickNameCard = "T_NickNameCard";
+    public static string T_CloseParent = "T_CloseParent";
+    public static string T_Close = "T_Close";
+    public static string T_Confirm = "T_Confirm";
+    public static string T_ConfirmLab = "T_ConfirmLab";
+    public static string T_Tit = "T_Tit";
+    public static string T_InputField = "T_InputField";
+    public static string T_InputLab = "T_InputLab";
+    public static string T_Random = "T_Random";
+    public static string T_CostTxt = "T_CostTxt";
+    public static string T_CostImagePlus = "T_CostImagePlus";
     public static string AE_PlazaroomMemberPanelParent = "AE_PlazaroomMemberPanelParent";
     public static string AE_PlazaroomMemberPanelMask = "AE_PlazaroomMemberPanelMask";
     public static string AE_PlazaroomMemberPanel = "AE_PlazaroomMemberPanel";

+ 33 - 0
Assets/Script/Label/LanguageLabel.cs

@@ -134,6 +134,8 @@ public class LanguageLabel
     	public static string UI__Lb_Send2 = "UI__Lb_Send2";
     	public static string UI__Lb_Send3 = "UI__Lb_Send3";
     	public static string UI__Lc_CreditsContent = "UI__Lc_CreditsContent";
+    	public static string UI__Ld_Title = "UI__Ld_Title";
+    	public static string UI__Ld_PlaceHolder = "UI__Ld_PlaceHolder";
     	public static string UI__M_Tit = "UI__M_Tit";
     	public static string UI__J_Info0 = "UI__J_Info0";
     	public static string UI__J_Info1 = "UI__J_Info1";
@@ -399,6 +401,21 @@ public class LanguageLabel
     	public static string FlowerName__Flower48 = "FlowerName__Flower48";
     	public static string FlowerName__Flower49 = "FlowerName__Flower49";
     	public static string FlowerName__Flower50 = "FlowerName__Flower50";
+    	public static string FlowerName__Flower51 = "FlowerName__Flower51";
+    	public static string FlowerName__Flower52 = "FlowerName__Flower52";
+    	public static string FlowerName__Flower53 = "FlowerName__Flower53";
+    	public static string FlowerName__Flower54 = "FlowerName__Flower54";
+    	public static string FlowerName__Flower55 = "FlowerName__Flower55";
+    	public static string FlowerName__Flower56 = "FlowerName__Flower56";
+    	public static string FlowerName__Flower57 = "FlowerName__Flower57";
+    	public static string FlowerName__Flower58 = "FlowerName__Flower58";
+    	public static string FlowerName__Flower59 = "FlowerName__Flower59";
+    	public static string FlowerName__Flower60 = "FlowerName__Flower60";
+    	public static string FlowerName__Flower61 = "FlowerName__Flower61";
+    	public static string FlowerName__Flower62 = "FlowerName__Flower62";
+    	public static string FlowerName__Flower63 = "FlowerName__Flower63";
+    	public static string FlowerName__Flower64 = "FlowerName__Flower64";
+    	public static string FlowerName__Flower65 = "FlowerName__Flower65";
     	public static string FlowerColor = "FlowerColor";
     	public static string FlowerColor__Flower0 = "FlowerColor__Flower0";
     	public static string FlowerColor__Flower1 = "FlowerColor__Flower1";
@@ -451,6 +468,21 @@ public class LanguageLabel
     	public static string FlowerColor__Flower48 = "FlowerColor__Flower48";
     	public static string FlowerColor__Flower49 = "FlowerColor__Flower49";
     	public static string FlowerColor__Flower50 = "FlowerColor__Flower50";
+    	public static string FlowerColor__Flower51 = "FlowerColor__Flower51";
+    	public static string FlowerColor__Flower52 = "FlowerColor__Flower52";
+    	public static string FlowerColor__Flower53 = "FlowerColor__Flower53";
+    	public static string FlowerColor__Flower54 = "FlowerColor__Flower54";
+    	public static string FlowerColor__Flower55 = "FlowerColor__Flower55";
+    	public static string FlowerColor__Flower56 = "FlowerColor__Flower56";
+    	public static string FlowerColor__Flower57 = "FlowerColor__Flower57";
+    	public static string FlowerColor__Flower58 = "FlowerColor__Flower58";
+    	public static string FlowerColor__Flower59 = "FlowerColor__Flower59";
+    	public static string FlowerColor__Flower60 = "FlowerColor__Flower60";
+    	public static string FlowerColor__Flower61 = "FlowerColor__Flower61";
+    	public static string FlowerColor__Flower62 = "FlowerColor__Flower62";
+    	public static string FlowerColor__Flower63 = "FlowerColor__Flower63";
+    	public static string FlowerColor__Flower64 = "FlowerColor__Flower64";
+    	public static string FlowerColor__Flower65 = "FlowerColor__Flower65";
     	public static string SkillName = "SkillName";
     	public static string SkillName__Pack1 = "SkillName__Pack1";
     	public static string SkillName__Pack2 = "SkillName__Pack2";
@@ -990,6 +1022,7 @@ public class LanguageLabel
     	public static string Tip__Tip8 = "Tip__Tip8";
     	public static string Tip__Tip9 = "Tip__Tip9";
     	public static string Tip__Tip10 = "Tip__Tip10";
+    	public static string Tip__Tip11 = "Tip__Tip11";
     	public static string MinigameName = "MinigameName";
     	public static string MinigameName__Punch = "MinigameName__Punch";
     	public static string MinigameName__Memory = "MinigameName__Memory";

+ 3447 - 3447
Assets/Script/Manage/AnimManager.cs

@@ -1,3448 +1,3448 @@
-using UnityEngine;
-using UnityEngine.UI;
-using UnityEngine.Events;
-
-using System;
-using System.Collections;
-using System.Collections.Generic;
-
-public enum Curve
-{
-    Linear,
-    EaseOutQuad,
-}
-
-public enum EventType
-{
-    ForwardStart,
-    BackwardStart,
-    ForwardFinish,
-    BackwardFinish,
-}
-
-
-public delegate float TimerFunction(float value, float duration, float start, float delta);
-
-
-public delegate float ShakeFunctionF(float timer, float duration, int repeat, float start, float strength);
-
-public delegate Color ShakeFunctionC(float timer, float duration, int repeat, Color start, Color strength);
-
-public delegate Vector3 ShakeFunctionV(float timer, float duration, int repeat, Vector3 start, Vector3 strength);
-
-
-public delegate float CurveFunctionF(float timer, float duration, float start, float delta);
-
-public delegate Color CurveFunctionC(float timer, float duration, Color start, Color delta);
-
-public delegate Vector3 CurveFunctionV(float timer, float duration, Vector3 start, Vector3 delta);
-
-
-public class MaterialUnit
-{
-    public Material Material;
-    public Transform Transform;
-
-    public List<string> PropertyList;
-
-    public MaterialUnit(Material material, Transform transform, List<string> propertyList)
-    {
-        Material = material;
-        Transform = transform;
-        PropertyList = propertyList;
-    }
-
-
-    public void SetFloat(float value)
-    {
-        for (int i = 0; i < PropertyList.Count; i++)
-        {
-            Material.SetFloat(PropertyList[i], value);
-        }
-    }
-
-    public void SetColor(Color value)
-    {
-        for (int i = 0; i < PropertyList.Count; i++)
-        {
-            Material.SetColor(PropertyList[i], value);
-        }
-    }
-
-    public float GetFloat()
-    {
-        return Material.GetFloat(PropertyList[0]);
-    }
-
-    public Color GetColor()
-    {
-        return Material.GetColor(PropertyList[0]);
-    }
-}
-
-public class AnimManager : Regist
-{
-    #region 变量
-
-    public static List<MoveRoot> MoveForList = new List<MoveRoot>();
-    public static List<MoveRoot> MoveBacList = new List<MoveRoot>();
-
-    public static Dictionary<Curve, TimerFunction> TimerFunctionDic = new Dictionary<Curve, TimerFunction>();
-
-    public static Dictionary<Curve, ShakeFunctionF> ShakeFuncDicF = new Dictionary<Curve, ShakeFunctionF>();
-    public static Dictionary<Curve, ShakeFunctionC> ShakeFuncDicC = new Dictionary<Curve, ShakeFunctionC>();
-    public static Dictionary<Curve, ShakeFunctionV> ShakeFuncDicV = new Dictionary<Curve, ShakeFunctionV>();
-
-    public static Dictionary<Curve, CurveFunctionF> CurveFuncDicF = new Dictionary<Curve, CurveFunctionF>();
-    public static Dictionary<Curve, CurveFunctionC> CurveFuncDicC = new Dictionary<Curve, CurveFunctionC>();
-    public static Dictionary<Curve, CurveFunctionV> CurveFuncDicV = new Dictionary<Curve, CurveFunctionV>();
-
-    public static Dictionary<Transform, Shake> ShakeDic = new Dictionary<Transform, Shake>();
-    public static Dictionary<Transform, Move2D> MoveDic2D = new Dictionary<Transform, Move2D>();
-    public static Dictionary<Transform, Move3D> MoveDic3D = new Dictionary<Transform, Move3D>();
-    public static Dictionary<Transform, Zoom2D> ZoomDic2D = new Dictionary<Transform, Zoom2D>();
-
-    public static Dictionary<Transform, TweenSr> TweenSrDic = new Dictionary<Transform, TweenSr>();
-    public static Dictionary<Transform, TweenCG> TweenCgDic = new Dictionary<Transform, TweenCG>();
-    public static Dictionary<Transform, TweenGra> TweenGraDic = new Dictionary<Transform, TweenGra>();
-    public static Dictionary<Transform, TweenVec> TweenVecDic = new Dictionary<Transform, TweenVec>();
-    public static Dictionary<Transform, TweenEuler> TweenEulerDic = new Dictionary<Transform, TweenEuler>();
-    public static Dictionary<Transform, TweenFont> TweenFontDic = new Dictionary<Transform, TweenFont>();
-    public static Dictionary<Transform, TweenRect> TweenRectDic = new Dictionary<Transform, TweenRect>();
-    public static Dictionary<Transform, TweenScale> TweenScaleDic = new Dictionary<Transform, TweenScale>();
-    public static Dictionary<Transform, TweenOutline> TweenOutlineDic = new Dictionary<Transform, TweenOutline>();
-    public static Dictionary<Transform, TweenNumber> TweenNumberDic = new Dictionary<Transform, TweenNumber>();
-    public static Dictionary<Renderer, TweenRenderer> TweenRendererDic = new Dictionary<Renderer, TweenRenderer>();
-    public static Dictionary<AudioSource, TweenAudio> TweenAudioDic = new Dictionary<AudioSource, TweenAudio>();
-
-    public static Dictionary<MaterialUnit, TweenMatColor> TweenMatColorDic = new Dictionary<MaterialUnit, TweenMatColor>();
-    public static Dictionary<MaterialUnit, TweenMatFloat> TweenMatFloatDic = new Dictionary<MaterialUnit, TweenMatFloat>();
-    public static Dictionary<MeshFilter, TweenGrayMesh> TweenGrayMeshDic = new Dictionary<MeshFilter, TweenGrayMesh>();
-
-    public static Dictionary<Transform, StreamScale> StreamScaleDic = new Dictionary<Transform, StreamScale>();
-
-    #endregion
-
-    public void Update()
-    {
-        for (int i = 0; i < MoveForList.Count; i++)
-        {
-            MoveRoot move = MoveForList[i];
-
-            if (move.DoForward())
-            {
-                if (MoveForList.Remove(move))
-                {
-                    i--;
-                }
-            }
-        }
-
-        for (int i = 0; i < MoveBacList.Count; i++)
-        {
-            MoveRoot move = MoveBacList[i];
-
-            if (move.DoBackward())
-            {
-                if (MoveBacList.Remove(move))
-                {
-                    i--;
-                }
-            }
-        }
-    }
-
-
-    public override bool InitAtOnce()
-    {
-        if (base.InitAtOnce())
-        {
-            return true;
-        }
-
-        TimerFunctionDic.Add(Curve.Linear, LinearTimer);
-        TimerFunctionDic.Add(Curve.EaseOutQuad, EaseOutQuadTimer);
-
-        ShakeFuncDicF.Add(Curve.Linear, ShakeLinear);
-        ShakeFuncDicF.Add(Curve.EaseOutQuad, ShakeEaseOutQuad);
-
-        ShakeFuncDicC.Add(Curve.Linear, ShakeLinear);
-        ShakeFuncDicC.Add(Curve.EaseOutQuad, ShakeEaseOutQuad);
-
-        ShakeFuncDicV.Add(Curve.Linear, ShakeLinear);
-        ShakeFuncDicV.Add(Curve.EaseOutQuad, ShakeEaseOutQuad);
-
-        CurveFuncDicF.Add(Curve.Linear, Linear);
-        CurveFuncDicF.Add(Curve.EaseOutQuad, EaseOutQuad);
-
-        CurveFuncDicC.Add(Curve.Linear, Linear);
-        CurveFuncDicC.Add(Curve.EaseOutQuad, EaseOutQuad);
-
-        CurveFuncDicV.Add(Curve.Linear, Linear);
-        CurveFuncDicV.Add(Curve.EaseOutQuad, EaseOutQuad);
-
-        enabled = true;
-
-        return false;
-    }
-
-
-    #region 曲线
-
-    public static float LinearTimer(float value, float duration, float start, float delta)
-    {
-        return (value - start)*duration/delta;
-    }
-
-    public static float EaseOutQuadTimer(float value, float duration, float start, float delta)
-    {
-        return ((2 - Mathf.Sqrt(4 - 4*(value - start)/delta))/2)*duration;
-    }
-
-
-    public static float ShakeLinear(float timer, float duration, int repeat, float start, float strength)
-    {
-        float sliceTime = duration/(4*repeat);
-
-        for (int i = 0; i < repeat*4; i += 4)
-        {
-            if (timer > duration)
-            {
-                return start;
-            }
-
-            if (timer <= (i + 1)*sliceTime)
-            {
-                timer -= (i)*sliceTime;
-
-                return Linear(timer, sliceTime, start, strength/(i/4 + 1));
-            }
-            else if (timer <= (i + 3)*sliceTime)
-            {
-                timer -= (i + 1)*sliceTime;
-
-                return Linear(timer, 2*sliceTime, start + strength/(i/4 + 1), -2*strength/(i/4 + 1));
-            }
-            else if (timer <= (i + 4)*sliceTime)
-            {
-                timer -= (i + 3)*sliceTime;
-
-                return Linear(timer, sliceTime, start - strength/(i/4 + 1), strength/(i/4 + 1));
-            }
-        }
-
-        throw new Exception();
-    }
-
-    public static Color ShakeLinear(float timer, float duration, int repeat, Color start, Color strength)
-    {
-        float sliceTime = duration/(4*repeat);
-
-        for (int i = 0; i < repeat*4; i += 4)
-        {
-            if (timer > duration)
-            {
-                return start;
-            }
-
-            if (timer <= (i + 1)*sliceTime)
-            {
-                timer -= (i)*sliceTime;
-
-                return Linear(timer, sliceTime, start, strength/(i/4 + 1));
-            }
-            else if (timer <= (i + 3)*sliceTime)
-            {
-                timer -= (i + 1)*sliceTime;
-
-                return Linear(timer, 2*sliceTime, start + strength/(i/4 + 1), -2*strength/(i/4 + 1));
-            }
-            else if (timer <= (i + 4)*sliceTime)
-            {
-                timer -= (i + 3)*sliceTime;
-
-                return Linear(timer, sliceTime, start - strength/(i/4 + 1), strength/(i/4 + 1));
-            }
-        }
-
-        throw new Exception();
-    }
-
-    public static Vector3 ShakeLinear(float timer, float duration, int repeat, Vector3 start, Vector3 strength)
-    {
-        float sliceTime = duration/(4*repeat);
-
-        for (int i = 0; i < repeat*4; i += 4)
-        {
-            if (timer > duration)
-            {
-                return start;
-            }
-
-            if (timer <= (i + 1)*sliceTime)
-            {
-                timer -= (i)*sliceTime;
-
-                return Linear(timer, sliceTime, start, strength/(i/4 + 1));
-            }
-            else if (timer <= (i + 3)*sliceTime)
-            {
-                timer -= (i + 1)*sliceTime;
-
-                return Linear(timer, 2*sliceTime, start + strength/(i/4 + 1), -2*strength/(i/4 + 1));
-            }
-            else if (timer <= (i + 4)*sliceTime)
-            {
-                timer -= (i + 3)*sliceTime;
-
-                return Linear(timer, sliceTime, start - strength/(i/4 + 1), strength/(i/4 + 1));
-            }
-        }
-
-        throw new Exception();
-    }
-
-
-    public static float ShakeEaseOutQuad(float timer, float duration, int repeat, float start, float strength)
-    {
-        float sliceTime = duration/(4*repeat);
-
-        for (int i = 0; i < repeat*4; i += 4)
-        {
-            if (timer > duration)
-            {
-                return start;
-            }
-
-            if (timer <= (i + 1)*sliceTime)
-            {
-                timer -= (i)*sliceTime;
-
-                return EaseOutQuad(timer, sliceTime, start, strength/(i/4 + 1));
-            }
-            else if (timer <= (i + 3)*sliceTime)
-            {
-                timer -= (i + 1)*sliceTime;
-
-                return EaseOutQuad(timer, 2*sliceTime, start + strength/(i/4 + 1), -2*strength/(i/4 + 1));
-            }
-            else if (timer <= (i + 4)*sliceTime)
-            {
-                timer -= (i + 3)*sliceTime;
-
-                return EaseOutQuad(timer, sliceTime, start - strength/(i/4 + 1), strength/(i/4 + 1));
-            }
-        }
-
-        throw new Exception();
-    }
-
-    public static Color ShakeEaseOutQuad(float timer, float duration, int repeat, Color start, Color strength)
-    {
-        float sliceTime = duration/(4*repeat);
-
-        for (int i = 0; i < repeat*4; i += 4)
-        {
-            if (timer > duration)
-            {
-                return start;
-            }
-
-            if (timer <= (i + 1)*sliceTime)
-            {
-                timer -= (i)*sliceTime;
-
-                return EaseOutQuad(timer, sliceTime, start, strength/(i/4 + 1));
-            }
-            else if (timer <= (i + 3)*sliceTime)
-            {
-                timer -= (i + 1)*sliceTime;
-
-                return EaseOutQuad(timer, 2*sliceTime, start + strength/(i/4 + 1), -2*strength/(i/4 + 1));
-            }
-            else if (timer <= (i + 4)*sliceTime)
-            {
-                timer -= (i + 3)*sliceTime;
-
-                return EaseOutQuad(timer, sliceTime, start - strength/(i/4 + 1), strength/(i/4 + 1));
-            }
-        }
-
-        throw new Exception();
-    }
-
-    public static Vector3 ShakeEaseOutQuad(float timer, float duration, int repeat, Vector3 start, Vector3 strength)
-    {
-        float sliceTime = duration/(4*repeat);
-
-        for (int i = 0; i < repeat*4; i += 4)
-        {
-            if (timer > duration)
-            {
-                return start;
-            }
-
-            if (timer <= (i + 1)*sliceTime)
-            {
-                timer -= (i)*sliceTime;
-
-                return EaseOutQuad(timer, sliceTime, start, strength/(i/4 + 1));
-            }
-            else if (timer <= (i + 3)*sliceTime)
-            {
-                timer -= (i + 1)*sliceTime;
-
-                return EaseOutQuad(timer, 2*sliceTime, start + strength/(i/4 + 1), -2*strength/(i/4 + 1));
-            }
-            else if (timer <= (i + 4)*sliceTime)
-            {
-                timer -= (i + 3)*sliceTime;
-
-                return EaseOutQuad(timer, sliceTime, start - strength/(i/4 + 1), strength/(i/4 + 1));
-            }
-        }
-
-        throw new Exception();
-    }
-
-
-    public static float Linear(float timer, float duration, float start, float delta)
-    {
-        if (timer >= duration)
-        {
-            return start + delta;
-        }
-
-        if (duration.Equal(0))
-        {
-            return delta + start;
-        }
-        else
-        {
-            return delta*timer/duration + start;
-        }
-    }
-
-    public static Color Linear(float timer, float duration, Color start, Color delta)
-    {
-        return new Color(Linear(timer, duration, start.r, delta.r), Linear(timer, duration, start.g, delta.g), Linear(timer, duration, start.b, delta.b), Linear(timer, duration, start.a, delta.a));
-    }
-
-    public static Vector3 Linear(float timer, float duration, Vector3 start, Vector3 delta)
-    {
-        return new Vector3(Linear(timer, duration, start.x, delta.x), Linear(timer, duration, start.y, delta.y), Linear(timer, duration, start.z, delta.z));
-    }
-
-
-    public static float EaseOutQuad(float timer, float duration, float start, float delta)
-    {
-        if (timer >= duration)
-        {
-            return start + delta;
-        }
-
-        if (duration.Equal(0))
-        {
-            return delta + start;
-        }
-        else
-        {
-            timer /= duration;
-            
-            return -delta*timer*(timer - 2) + start;
-        }
-    }
-
-    public static Color EaseOutQuad(float timer, float duration, Color start, Color delta)
-    {
-        return new Color(EaseOutQuad(timer, duration, start.r, delta.r), EaseOutQuad(timer, duration, start.g, delta.g), EaseOutQuad(timer, duration, start.b, delta.b), EaseOutQuad(timer, duration, start.a, delta.a));
-    }
-
-    public static Vector3 EaseOutQuad(float timer, float duration, Vector3 start, Vector3 delta)
-    {
-        return new Vector3(EaseOutQuad(timer, duration, start.x, delta.x), EaseOutQuad(timer, duration, start.y, delta.y), EaseOutQuad(timer, duration, start.z, delta.z));
-    }
-
-    #endregion
-
-    #region 播放动画
-
-    public static Shake Shake(Transform target, float duration, int repeat, Vector3 strength, Curve curve)
-    {
-        Shake move;
-
-        if (ShakeDic.TryGetValue(target, out move))
-        {
-            move.StartShake(repeat, duration, strength, curve);
-        }
-        else
-        {
-            move = CreateShake(target);
-
-            move.StartShake(repeat, duration, strength, curve);
-        }
-
-        return move;
-    }
-
-
-    public static Move2D Move2D(Transform target, Vector3 destination, float duration, bool local, Curve curve)
-    {
-        Move2D move;
-
-        if (local)
-        {
-            destination.z = target.localPosition.z;
-        }
-        else
-        {
-            destination.z = target.position.z;
-        }
-
-        if (MoveDic2D.TryGetValue(target, out move))
-        {
-            move.StartMove(destination, duration, local, curve);
-
-            return move;
-        }
-        else
-        {
-            move = CreateMove2D(target);
-
-            move.StartMove(destination, duration, local, curve);
-
-            return move;
-        }
-    }
-
-    public static Move3D Move3D(Transform target, Vector3 destination, float duration, bool local, Curve curve)
-    {
-        Move3D move;
-
-        if (MoveDic3D.TryGetValue(target, out move))
-        {
-            move.StartMove(destination, duration, local, curve);
-
-            return move;
-        }
-        else
-        {
-            move = CreateMove3D(target);
-
-            move.StartMove(destination, duration, local, curve);
-
-            return move;
-        }
-    }
-
-    public static Move2D MoveOffset2D(Transform target, Vector3 offset, float duration, bool local, Curve curve)
-    {
-        Move2D move;
-
-        Vector3 destination;
-
-        if (local)
-        {
-            destination = target.localPosition + offset;
-
-            destination.z = target.localPosition.z;
-        }
-        else
-        {
-            destination = target.position + offset;
-
-            destination.z = target.position.z;
-        }
-
-        if (MoveDic2D.TryGetValue(target, out move))
-        {
-            move.StartMove(destination, duration, local, curve);
-
-            return move;
-        }
-        else
-        {
-            move = CreateMove2D(target);
-
-            move.StartMove(destination, duration, local, curve);
-
-            return move;
-        }
-    }
-
-    public static Move3D MoveOffset3D(Transform target, Vector3 offset, float duration, bool local, Curve curve)
-    {
-        Move3D move;
-
-        Vector3 destination;
-
-        if (local)
-        {
-            destination = target.localPosition + offset;
-        }
-        else
-        {
-            destination = target.position + offset;
-        }
-
-        if (MoveDic3D.TryGetValue(target, out move))
-        {
-            move.StartMove(destination, duration, local, curve);
-
-            return move;
-        }
-        else
-        {
-            move = CreateMove3D(target);
-
-            move.StartMove(destination, duration, local, curve);
-
-            return move;
-        }
-    }
-
-
-    public static Zoom2D Zoom2D(Transform target, float origin, float destination, float duration, float stay, Transform zoom, Curve curve)
-    {
-        Zoom2D move;
-
-        if (ZoomDic2D.TryGetValue(target, out move))
-        {
-            move.StartZoom(origin, destination, duration, stay, zoom, curve);
-        }
-        else
-        {
-            move = CreateZoom2D(target);
-
-            move.StartZoom(origin, destination, duration, stay, zoom, curve);
-        }
-
-        return move;
-    }
-
-    public static Zoom2D Zoom2D(Transform target, float destination, float duration, float stay, Transform zoom, Curve curve)
-    {
-        Zoom2D move;
-
-        Camera camera = target.GetComponent<Camera>();
-
-        if (ZoomDic2D.TryGetValue(target, out move))
-        {
-            move.StartZoom(camera.orthographicSize, destination, duration, stay, zoom, curve);
-        }
-        else
-        {
-            move = CreateZoom2D(target);
-
-            move.StartZoom(camera.orthographicSize, destination, duration, stay, zoom, curve);
-        }
-
-        return move;
-    }
-
-
-    public static StreamScale StreamForScale(Transform target)
-    {
-        StreamScale stream;
-
-        if (StreamScaleDic.TryGetValue(target, out stream))
-        {
-            stream.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return stream;
-    }
-
-    public static StreamScale StreamBacScale(Transform target)
-    {
-        StreamScale stream;
-
-        if (StreamScaleDic.TryGetValue(target, out stream))
-        {
-            stream.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return stream;
-    }
-
-    public static StreamScale StreamReForScale(Transform target)
-    {
-        StreamScale stream;
-
-        if (StreamScaleDic.TryGetValue(target, out stream))
-        {
-            stream.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return stream;
-    }
-
-    public static StreamScale StreamReBacScale(Transform target)
-    {
-        StreamScale stream;
-
-        if (StreamScaleDic.TryGetValue(target, out stream))
-        {
-            stream.ReBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return stream;
-    }
-
-
-    public static TweenSr TweenForSr(Transform target)
-    {
-        TweenSr tween;
-
-        if (TweenSrDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenRenderer TweenForRenderer(Renderer target)
-    {
-        TweenRenderer tween;
-
-        if (TweenRendererDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenCG TweenForCG(Transform target)
-    {
-        TweenCG tween;
-
-        if (TweenCgDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenGra TweenForGra(Transform target)
-    {
-        TweenGra tween;
-
-        if (TweenGraDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenEuler TweenForEuler(Transform target)
-    {
-        TweenEuler tween;
-
-        if (TweenEulerDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenVec TweenForVec(Transform target)
-    {
-        TweenVec tween;
-
-        if (TweenVecDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenFont TweenForFont(Transform target)
-    {
-        TweenFont tween;
-
-        if (TweenFontDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenRect TweenForRect(Transform target)
-    {
-        TweenRect tween;
-
-        if (TweenRectDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenScale TweenForScale(Transform target)
-    {
-        TweenScale tween;
-
-        if (TweenScaleDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenAudio TweenForAudio(Transform target)
-    {
-        TweenAudio tween;
-        AudioSource audioSource = target.GetComponent<AudioSource>();
-
-        if (TweenAudioDic.TryGetValue(audioSource, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenAudio TweenForAudio(AudioSource audioSource)
-    {
-        TweenAudio tween;
-
-        if (TweenAudioDic.TryGetValue(audioSource, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenOutline TweenForOutline(Transform target)
-    {
-        TweenOutline tween;
-
-        if (TweenOutlineDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenNumber TweenForNumber(Transform target)
-    {
-        TweenNumber tween;
-
-        if (TweenNumberDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenMatFloat TweenForMatFloat(MaterialUnit target)
-    {
-        TweenMatFloat tween;
-
-        if (TweenMatFloatDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenMatColor TweenForMatColor(MaterialUnit target)
-    {
-        TweenMatColor tween;
-
-        if (TweenMatColorDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenGrayMesh TweenForGrayMesh(MeshFilter target)
-    {
-        TweenGrayMesh tween;
-
-        if (TweenGrayMeshDic.TryGetValue(target, out tween))
-        {
-            tween.StartForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-
-    public static TweenSr TweenBacSr(Transform target)
-    {
-        TweenSr tween;
-
-        if (TweenSrDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenRenderer TweenBacRenderer(Renderer target)
-    {
-        TweenRenderer tween;
-
-        if (TweenRendererDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenCG TweenBacCG(Transform target)
-    {
-        TweenCG tween;
-
-        if (TweenCgDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenGra TweenBacGra(Transform target)
-    {
-        TweenGra tween;
-
-        if (TweenGraDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception(target.name);
-        }
-
-        return tween;
-    }
-
-    public static TweenVec TweenBacVec(Transform target)
-    {
-        TweenVec tween;
-
-        if (TweenVecDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception(target.name);
-        }
-
-        return tween;
-    }
-
-    public static TweenEuler TweenBacEuler(Transform target)
-    {
-        TweenEuler tween;
-
-        if (TweenEulerDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception(target.name);
-        }
-
-        return tween;
-    }
-
-    public static TweenFont TweenBacFont(Transform target)
-    {
-        TweenFont tween;
-
-        if (TweenFontDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenRect TweenBacRect(Transform target)
-    {
-        TweenRect tween;
-
-        if (TweenRectDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenScale TweenBacScale(Transform target)
-    {
-        TweenScale tween;
-
-        if (TweenScaleDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenAudio TweenBacAudio(Transform target)
-    {
-        TweenAudio tween;
-        AudioSource audioSource = target.GetComponent<AudioSource>();
-
-        if (TweenAudioDic.TryGetValue(audioSource, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenAudio TweenBacAudio(AudioSource audioSource)
-    {
-        TweenAudio tween;
-
-        if (TweenAudioDic.TryGetValue(audioSource, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenOutline TweenBacOutline(Transform target)
-    {
-        TweenOutline tween;
-
-        if (TweenOutlineDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenNumber TweenBacNumber(Transform target)
-    {
-        TweenNumber tween;
-
-        if (TweenNumberDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenMatFloat TweenBacMatFloat(MaterialUnit target)
-    {
-        TweenMatFloat tween;
-
-        if (TweenMatFloatDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenMatColor TweenBacMatColor(MaterialUnit target)
-    {
-        TweenMatColor tween;
-
-        if (TweenMatColorDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenGrayMesh TweenBacGrayMesh(MeshFilter target)
-    {
-        TweenGrayMesh tween;
-
-        if (TweenGrayMeshDic.TryGetValue(target, out tween))
-        {
-            tween.StartBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-
-    public static TweenSr TweenReForSr(Transform target)
-    {
-        TweenSr tween;
-
-        if (TweenSrDic.TryGetValue(target, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenRenderer TweenReForRenderer(Renderer target)
-    {
-        TweenRenderer tween;
-
-        if (TweenRendererDic.TryGetValue(target, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenCG TweenReForCG(Transform target)
-    {
-        TweenCG tween;
-
-        if (TweenCgDic.TryGetValue(target, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenGra TweenReForGra(Transform target)
-    {
-        TweenGra tween;
-
-        if (TweenGraDic.TryGetValue(target, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenVec TweenReForVec(Transform target)
-    {
-        TweenVec tween;
-
-        if (TweenVecDic.TryGetValue(target, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenEuler TweenReForEuler(Transform target)
-    {
-        TweenEuler tween;
-
-        if (TweenEulerDic.TryGetValue(target, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenFont TweenReForFont(Transform target)
-    {
-        TweenFont tween;
-
-        if (TweenFontDic.TryGetValue(target, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenRect TweenReForRect(Transform target)
-    {
-        TweenRect tween;
-
-        if (TweenRectDic.TryGetValue(target, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenScale TweenReForScale(Transform target)
-    {
-        TweenScale tween;
-
-        if (TweenScaleDic.TryGetValue(target, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenAudio TweenReForAudio(Transform target)
-    {
-        TweenAudio tween;
-        AudioSource audioSource = target.GetComponent<AudioSource>();
-
-        if (TweenAudioDic.TryGetValue(audioSource, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenAudio TweenReForAudio(AudioSource audioSource)
-    {
-        TweenAudio tween;
-
-        if (TweenAudioDic.TryGetValue(audioSource, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenOutline TweenReForOutline(Transform target)
-    {
-        TweenOutline tween;
-
-        if (TweenOutlineDic.TryGetValue(target, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenNumber TweenReForNumber(Transform target)
-    {
-        TweenNumber tween;
-
-        if (TweenNumberDic.TryGetValue(target, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenMatFloat TweenReForMatFloat(MaterialUnit target)
-    {
-        TweenMatFloat tween;
-
-        if (TweenMatFloatDic.TryGetValue(target, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenMatColor TweenReForMatColor(MaterialUnit target)
-    {
-        TweenMatColor tween;
-
-        if (TweenMatColorDic.TryGetValue(target, out tween))
-        {
-            tween.ReForward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-
-    public static TweenSr TweenReBacSr(Transform target)
-    {
-        TweenSr tween;
-
-        if (TweenSrDic.TryGetValue(target, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenRenderer TweenReBacRenderer(Renderer target)
-    {
-        TweenRenderer tween;
-
-        if (TweenRendererDic.TryGetValue(target, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenCG TweenReBacCG(Transform target)
-    {
-        TweenCG tween;
-
-        if (TweenCgDic.TryGetValue(target, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenGra TweenReBacGra(Transform target)
-    {
-        TweenGra tween;
-
-        if (TweenGraDic.TryGetValue(target, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception(target.name);
-        }
-
-        return tween;
-    }
-
-    public static TweenVec TweenReBacVec(Transform target)
-    {
-        TweenVec tween;
-
-        if (TweenVecDic.TryGetValue(target, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception(target.name);
-        }
-
-        return tween;
-    }
-
-    public static TweenEuler TweenReBacEuler(Transform target)
-    {
-        TweenEuler tween;
-
-        if (TweenEulerDic.TryGetValue(target, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception(target.name);
-        }
-
-        return tween;
-    }
-
-    public static TweenFont TweenReBacFont(Transform target)
-    {
-        TweenFont tween;
-
-        if (TweenFontDic.TryGetValue(target, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenRect TweenReBacRect(Transform target)
-    {
-        TweenRect tween;
-
-        if (TweenRectDic.TryGetValue(target, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenScale TweenReBacScale(Transform target)
-    {
-        TweenScale tween;
-
-        if (TweenScaleDic.TryGetValue(target, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenAudio TweenReBacAudio(Transform target)
-    {
-        TweenAudio tween;
-        AudioSource audioSource = target.GetComponent<AudioSource>();
-
-        if (TweenAudioDic.TryGetValue(audioSource, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenAudio TweenReBacAudio(AudioSource audioSource)
-    {
-        TweenAudio tween;
-
-        if (TweenAudioDic.TryGetValue(audioSource, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenOutline TweenReBacOutline(Transform target)
-    {
-        TweenOutline tween;
-
-        if (TweenOutlineDic.TryGetValue(target, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenNumber TweenReBacNumber(Transform target)
-    {
-        TweenNumber tween;
-
-        if (TweenNumberDic.TryGetValue(target, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenMatFloat TweenReBacMatFloat(MaterialUnit target)
-    {
-        TweenMatFloat tween;
-
-        if (TweenMatFloatDic.TryGetValue(target, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    public static TweenMatColor TweenReBacMatColor(MaterialUnit target)
-    {
-        TweenMatColor tween;
-
-        if (TweenMatColorDic.TryGetValue(target, out tween))
-        {
-            tween.ReBackward();
-        }
-        else
-        {
-            throw new Exception();
-        }
-
-        return tween;
-    }
-
-    #endregion
-
-    #region 获取动画
-
-    public static float GetTimerVec(Vector3 value, float duration, Vector3 start, Vector3 delta, Curve curve)
-    {
-        if (!delta.x.Equal(0))
-        {
-            return TimerFunctionDic[curve](value.x, duration, start.x, delta.x);
-        }
-        else if (!delta.y.Equal(0))
-        {
-            return TimerFunctionDic[curve](value.y, duration, start.y, delta.y);
-        }
-        else if (!delta.z.Equal(0))
-        {
-            return TimerFunctionDic[curve](value.z, duration, start.z, delta.z);
-        }
-        else
-        {
-            throw new Exception();
-        }
-    }
-
-    public static float GetTimerFloat(float value, float duration, float start, float delta, Curve curve)
-    {
-        return TimerFunctionDic[curve](value, duration, start, delta);
-    }
-
-    public static float GetTimerColor(Color value, float duration, Color start, Color delta, Curve curve)
-    {
-        if (!delta.r.Equal(0))
-        {
-            return TimerFunctionDic[curve](value.r, duration, start.r, delta.r);
-        }
-        else if (!delta.g.Equal(0))
-        {
-            return TimerFunctionDic[curve](value.g, duration, start.g, delta.g);
-        }
-        else if (!delta.b.Equal(0))
-        {
-            return TimerFunctionDic[curve](value.b, duration, start.b, delta.b);
-        }
-        else if (!delta.a.Equal(0))
-        {
-            return TimerFunctionDic[curve](value.a, duration, start.a, delta.a);
-        }
-        else
-        {
-            throw new Exception();
-        }
-    }
-
-
-    public static Shake GetShake(Transform target)
-    {
-        Shake move;
-
-        if (ShakeDic.TryGetValue(target, out move))
-        {
-            return move;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static Move2D GetMove2D(Transform target)
-    {
-        Move2D move;
-
-        if (MoveDic2D.TryGetValue(target, out move))
-        {
-            return move;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static Move3D GetMove3D(Transform target)
-    {
-        Move3D move;
-
-        if (MoveDic3D.TryGetValue(target, out move))
-        {
-            return move;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static Zoom2D GetZoom2D(Transform target)
-    {
-        Zoom2D move;
-
-        if (ZoomDic2D.TryGetValue(target, out move))
-        {
-            return move;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-
-    public static StreamScale GetStreamScale(Transform target)
-    {
-        StreamScale stream;
-
-        if (StreamScaleDic.TryGetValue(target, out stream))
-        {
-            return stream;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-
-    public static TweenSr GetTweenSr(Transform target)
-    {
-        TweenSr tween;
-
-        if (TweenSrDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenRenderer GetTweenRenderer(Renderer target)
-    {
-        TweenRenderer tween;
-
-        if (TweenRendererDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenCG GetTweenCG(Transform target)
-    {
-        TweenCG tween;
-
-        if (TweenCgDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenGra GetTweenGra(Transform target)
-    {
-        TweenGra tween;
-
-        if (TweenGraDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenVec GetTweenVec(Transform target)
-    {
-        TweenVec tween;
-
-        if (TweenVecDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenEuler GetTweenEuler(Transform target)
-    {
-        TweenEuler tween;
-
-        if (TweenEulerDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenFont GetTweenFont(Transform target)
-    {
-        TweenFont tween;
-
-        if (TweenFontDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenRect GetTweenRect(Transform target)
-    {
-        TweenRect tween;
-
-        if (TweenRectDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenScale GetTweenScale(Transform target)
-    {
-        TweenScale tween;
-
-        if (TweenScaleDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenAudio GetTweenAudio(Transform target)
-    {
-        TweenAudio tween;
-        AudioSource audioSource = target.GetComponent<AudioSource>();
-
-        if (TweenAudioDic.TryGetValue(audioSource, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenAudio GetTweenAudio(AudioSource audioSource)
-    {
-        TweenAudio tween;
-
-        if (TweenAudioDic.TryGetValue(audioSource, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenOutline GetTweenOutline(Transform target)
-    {
-        TweenOutline tween;
-
-        if (TweenOutlineDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenNumber GetTweenNumber(Transform target)
-    {
-        TweenNumber tween;
-
-        if (TweenNumberDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenMatFloat GetTweenMatFloat(MaterialUnit target)
-    {
-        TweenMatFloat tween;
-
-        if (TweenMatFloatDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenMatColor GetTweenMatColor(MaterialUnit target)
-    {
-        TweenMatColor tween;
-
-        if (TweenMatColorDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    public static TweenGrayMesh GetTweenGrayMesh(MeshFilter target)
-    {
-        TweenGrayMesh tween;
-
-        if (TweenGrayMeshDic.TryGetValue(target, out tween))
-        {
-            return tween;
-        }
-        else
-        {
-            return null;
-        }
-    }
-
-    #endregion
-
-    #region 创建动画
-
-    public static Shake CreateShake(Transform target)
-    {
-        if (ShakeDic.ContainsKey(target))
-        {
-            Shake shake = ShakeDic[target];
-
-            shake.Pause();
-
-            ShakeDic[target] = new Shake(target);
-
-            return ShakeDic[target];
-        }
-        else
-        {
-            Shake shake = new Shake(target);
-
-            ShakeDic.Add(target, shake);
-
-            return shake;
-        }
-    }
-
-    public static Move2D CreateMove2D(Transform target)
-    {
-        if (MoveDic2D.ContainsKey(target))
-        {
-            Move2D move2D = MoveDic2D[target];
-
-            move2D.Pause();
-
-            MoveDic2D[target] = new Move2D(target);
-
-            return MoveDic2D[target];
-        }
-        else
-        {
-            Move2D move2D = new Move2D(target);
-
-            MoveDic2D.Add(target, move2D);
-
-            return move2D;
-        }
-    }
-
-    public static Move3D CreateMove3D(Transform target)
-    {
-        if (MoveDic3D.ContainsKey(target))
-        {
-            Move3D move3D = MoveDic3D[target];
-
-            move3D.Pause();
-
-            MoveDic3D[target] = new Move3D(target);
-
-            return MoveDic3D[target];
-        }
-        else
-        {
-            Move3D move3D = new Move3D(target);
-
-            MoveDic3D.Add(target, move3D);
-
-            return move3D;
-        }
-    }
-
-    public static Zoom2D CreateZoom2D(Transform target)
-    {
-        if (ZoomDic2D.ContainsKey(target))
-        {
-            Zoom2D zoom2D = ZoomDic2D[target];
-
-            zoom2D.Pause();
-
-            ZoomDic2D[target] = new Zoom2D(target.GetComponent<Camera>());
-
-            return ZoomDic2D[target];
-        }
-        else
-        {
-            Zoom2D zoom2D = new Zoom2D(target.GetComponent<Camera>());
-
-            ZoomDic2D.Add(target, zoom2D);
-
-            return zoom2D;
-        }
-    }
-
-
-    public static StreamScale CreateStreamScale(Transform target, List<float> delayList, List<float> durationList, List<VecPair> destKvList, bool originActive, bool destActive, Curve curve, bool cg = false, List<UnityAction> startActionList = null, List<UnityAction> finishActionList = null)
-    {
-        StreamScale streamScale;
-
-        if (StreamScaleDic.ContainsKey(target))
-        {
-            streamScale = StreamScaleDic[target];
-
-            streamScale.Pause();
-
-            StreamScaleDic[target] = new StreamScale(target, delayList, durationList, destKvList, originActive, destActive, curve, cg, startActionList, finishActionList);
-
-            return StreamScaleDic[target];
-        }
-        else
-        {
-            streamScale = new StreamScale(target, delayList, durationList, destKvList, originActive, destActive, curve, cg, startActionList, finishActionList);
-
-            StreamScaleDic.Add(target, streamScale);
-
-            return streamScale;
-        }
-    }
-
-    public static StreamScale CreateStreamScale(Transform target, List<float> delayList, List<float> durationList, List<Vector3> destList, bool originActive, bool destActive, Curve curve, bool cg = false, List<UnityAction> startActionList = null, List<UnityAction> finishActionList = null)
-    {
-        StreamScale streamScale;
-
-        if (StreamScaleDic.ContainsKey(target))
-        {
-            streamScale = StreamScaleDic[target];
-
-            streamScale.Pause();
-
-            StreamScaleDic[target] = new StreamScale(target, delayList, durationList, destList, originActive, destActive, curve, cg, startActionList, finishActionList);
-
-            return StreamScaleDic[target];
-        }
-        else
-        {
-            streamScale = new StreamScale(target, delayList, durationList, destList, originActive, destActive, curve, cg, startActionList, finishActionList);
-
-            StreamScaleDic.Add(target, streamScale);
-
-            return streamScale;
-        }
-    }
-
-
-    public static TweenSr CreateTweenSr(Transform target, float originAlpha, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
-    {
-        TweenSr tweenSr;
-        SpriteRenderer sr = target.GetComponent<SpriteRenderer>();
-
-        Color origin = sr.color;
-        Color destination = sr.color;
-
-        origin.a = originAlpha;
-        destination.a = destAlpha;
-
-        if (TweenSrDic.ContainsKey(target))
-        {
-            tweenSr = TweenSrDic[target];
-
-            tweenSr.Pause();
-
-            TweenSrDic[target] = new TweenSr(sr, origin, destination, duration, originActive, destActive, curve, cg, group);
-
-            return TweenSrDic[target];
-        }
-        else
-        {
-            tweenSr = new TweenSr(sr, origin, destination, duration, originActive, destActive, curve, cg, group);
-
-            TweenSrDic.Add(target, tweenSr);
-
-            return tweenSr;
-        }
-    }
-
-    public static TweenSr CreateTweenSr(Transform target, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
-    {
-        TweenSr tweenSr;
-        SpriteRenderer sr = target.GetComponent<SpriteRenderer>();
-
-        Color destination = sr.color;
-
-        destination.a = destAlpha;
-
-        if (TweenSrDic.ContainsKey(target))
-        {
-            tweenSr = TweenSrDic[target];
-
-            tweenSr.Pause();
-
-            TweenSrDic[target] = new TweenSr(sr, sr.color, destination, duration, originActive, destActive, curve, cg, group);
-
-            return TweenSrDic[target];
-        }
-        else
-        {
-            tweenSr = new TweenSr(sr, sr.color, destination, duration, originActive, destActive, curve, cg, group);
-
-            TweenSrDic.Add(target, tweenSr);
-
-            return tweenSr;
-        }
-    }
-
-    public static TweenSr CreateTweenSr(Transform target, Color origin, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
-    {
-        TweenSr tweenSr;
-        SpriteRenderer sr = target.GetComponent<SpriteRenderer>();
-
-        if (TweenSrDic.ContainsKey(target))
-        {
-            tweenSr = TweenSrDic[target];
-
-            tweenSr.Pause();
-
-            TweenSrDic[target] = new TweenSr(sr, origin, destination, duration, originActive, destActive, curve, cg, group);
-
-            return TweenSrDic[target];
-        }
-        else
-        {
-            tweenSr = new TweenSr(sr, origin, destination, duration, originActive, destActive, curve, cg, group);
-
-            TweenSrDic.Add(target, tweenSr);
-
-            return tweenSr;
-        }
-    }
-
-    public static TweenSr CreateTweenSr(Transform target, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
-    {
-        TweenSr tweenSr;
-        SpriteRenderer sr = target.GetComponent<SpriteRenderer>();
-
-        if (TweenSrDic.ContainsKey(target))
-        {
-            tweenSr = TweenSrDic[target];
-
-            tweenSr.Pause();
-
-            TweenSrDic[target] = new TweenSr(sr, sr.color, destination, duration, originActive, destActive, curve, cg, group);
-
-            return TweenSrDic[target];
-        }
-        else
-        {
-            tweenSr = new TweenSr(sr, sr.color, destination, duration, originActive, destActive, curve, cg, group);
-
-            TweenSrDic.Add(target, tweenSr);
-
-            return tweenSr;
-        }
-    }
-
-
-    public static TweenRenderer CreateTweenRenderer(Renderer target, float originAlpha, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
-    {
-        TweenRenderer tweenSr;
-        Color origin = target.sharedMaterial.GetColor("_Color");
-        Color destination = target.sharedMaterial.GetColor("_Color");
-
-        origin.a = originAlpha;
-        destination.a = destAlpha;
-
-        if (TweenRendererDic.ContainsKey(target))
-        {
-            tweenSr = TweenRendererDic[target];
-
-            tweenSr.Pause();
-
-            TweenRendererDic[target] = new TweenRenderer(target, origin, destination, duration, originActive, destActive, curve, cg, group);
-            tweenSr.AlphaOnly = true;
-            return TweenRendererDic[target];
-        }
-        else
-        {
-            tweenSr = new TweenRenderer(target, origin, destination, duration, originActive, destActive, curve, cg, group);
-
-            TweenRendererDic.Add(target, tweenSr);
-            tweenSr.AlphaOnly = true;
-            return tweenSr;
-        }
-    }
-
-    public static TweenRenderer CreateTweenRenderer(Renderer target, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
-    {
-        TweenRenderer tweenSr;
-        Renderer sr = target.GetComponent<Renderer>();
-
-        Color destination = sr.material.GetColor("_Color");
-
-        destination.a = destAlpha;
-
-        if (TweenRendererDic.ContainsKey(target))
-        {
-            tweenSr = TweenRendererDic[target];
-
-            tweenSr.Pause();
-
-            TweenRendererDic[target] = new TweenRenderer(sr, sr.material.GetColor("_Color"), destination, duration, originActive, destActive, curve, cg, group);
-
-            return TweenRendererDic[target];
-        }
-        else
-        {
-            tweenSr = new TweenRenderer(sr, sr.material.GetColor("_Color"), destination, duration, originActive, destActive, curve, cg, group);
-
-            TweenRendererDic.Add(target, tweenSr);
-
-            return tweenSr;
-        }
-    }
-
-    public static TweenRenderer CreateTweenRenderer(Renderer target, Color origin, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
-    {
-        TweenRenderer tweenSr;
-        Renderer sr = target.GetComponent<Renderer>();
-
-        if (TweenRendererDic.ContainsKey(target))
-        {
-            tweenSr = TweenRendererDic[target];
-
-            tweenSr.Pause();
-
-            TweenRendererDic[target] = new TweenRenderer(sr, origin, destination, duration, originActive, destActive, curve, cg, group);
-
-            return TweenRendererDic[target];
-        }
-        else
-        {
-            tweenSr = new TweenRenderer(sr, origin, destination, duration, originActive, destActive, curve, cg, group);
-
-            TweenRendererDic.Add(target, tweenSr);
-
-            return tweenSr;
-        }
-    }
-
-    public static TweenRenderer CreateTweenRenderer(Renderer target, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
-    {
-        TweenRenderer tweenSr;
-        Renderer sr = target.GetComponent<Renderer>();
-
-        if (TweenRendererDic.ContainsKey(target))
-        {
-            tweenSr = TweenRendererDic[target];
-
-            tweenSr.Pause();
-
-            TweenRendererDic[target] = new TweenRenderer(sr, sr.material.GetColor("_Color"), destination, duration, originActive, destActive, curve, cg, group);
-
-            return TweenRendererDic[target];
-        }
-        else
-        {
-            tweenSr = new TweenRenderer(sr, sr.material.GetColor("_Color"), destination, duration, originActive, destActive, curve, cg, group);
-
-            TweenRendererDic.Add(target, tweenSr);
-
-            return tweenSr;
-        }
-    }
-
-
-    public static TweenCG CreateTweenCG(Transform target, float origin, float destination, float duration, bool originActive, bool destActive, Curve curve)
-    {
-        TweenCG tweenCg;
-        CanvasGroup cg = target.GetComponent<CanvasGroup>();
-
-        if (TweenCgDic.ContainsKey(target))
-        {
-            tweenCg = TweenCgDic[target];
-
-            tweenCg.Pause();
-
-            TweenCgDic[target] = new TweenCG(cg, origin, destination, duration, originActive, destActive, curve);
-
-            return TweenCgDic[target];
-        }
-        else
-        {
-            tweenCg = new TweenCG(cg, origin, destination, duration, originActive, destActive, curve);
-
-            TweenCgDic.Add(target, tweenCg);
-
-            return tweenCg;
-        }
-    }
-
-    public static TweenCG CreateTweenCG(Transform target, float destination, float duration, bool originActive, bool destActive, Curve curve)
-    {
-        TweenCG tweenCg;
-        CanvasGroup cg = target.GetComponent<CanvasGroup>();
-
-        if (TweenCgDic.ContainsKey(target))
-        {
-            tweenCg = TweenCgDic[target];
-
-            tweenCg.Pause();
-
-            TweenCgDic[target] = new TweenCG(cg, cg.alpha, destination, duration, originActive, destActive, curve);
-
-            return TweenCgDic[target];
-        }
-        else
-        {
-            tweenCg = new TweenCG(cg, cg.alpha, destination, duration, originActive, destActive, curve);
-
-            TweenCgDic.Add(target, tweenCg);
-
-            return tweenCg;
-        }
-    }
-
-
-    public static TweenGra CreateTweenGra(Transform target, float originAlpha, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Graphic graphic = target.GetComponent<Graphic>();
-        TweenGra tweenGra;
-
-        Color origin = graphic.color;
-        Color destination = graphic.color;
-
-        origin.a = originAlpha;
-        destination.a = destAlpha;
-
-        if (TweenGraDic.ContainsKey(target))
-        {
-            tweenGra = TweenGraDic[target];
-
-            tweenGra.Pause();
-
-            TweenGraDic[target] = new TweenGra(graphic, origin, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenGraDic[target];
-        }
-        else
-        {
-            tweenGra = new TweenGra(graphic, origin, destination, duration, originActive, destActive, curve, cg);
-
-            TweenGraDic.Add(target, tweenGra);
-
-            return tweenGra;
-        }
-    }
-
-    public static TweenGra CreateTweenGra(Transform target, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Graphic graphic = target.GetComponent<Graphic>();
-        TweenGra tweenGra;
-
-        Color destination = graphic.color;
-
-        destination.a = destAlpha;
-
-        if (TweenGraDic.ContainsKey(target))
-        {
-            tweenGra = TweenGraDic[target];
-
-            tweenGra.Pause();
-
-            TweenGraDic[target] = new TweenGra(graphic, graphic.color, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenGraDic[target];
-        }
-        else
-        {
-            tweenGra = new TweenGra(graphic, graphic.color, destination, duration, originActive, destActive, curve, cg);
-
-            TweenGraDic.Add(target, tweenGra);
-
-            return tweenGra;
-        }
-    }
-
-    public static TweenGra CreateTweenGra(Transform target, Color origin, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Graphic graphic = target.GetComponent<Graphic>();
-        TweenGra tweenGra;
-
-        if (TweenGraDic.ContainsKey(target))
-        {
-            tweenGra = TweenGraDic[target];
-
-            tweenGra.Pause();
-
-            TweenGraDic[target] = new TweenGra(graphic, origin, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenGraDic[target];
-        }
-        else
-        {
-            tweenGra = new TweenGra(graphic, origin, destination, duration, originActive, destActive, curve, cg);
-
-            TweenGraDic.Add(target, tweenGra);
-
-            return tweenGra;
-        }
-    }
-
-    public static TweenGra CreateTweenGra(Transform target, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Graphic graphic = target.GetComponent<Graphic>();
-        TweenGra tweenGra;
-
-        if (TweenGraDic.ContainsKey(target))
-        {
-            tweenGra = TweenGraDic[target];
-
-            tweenGra.Pause();
-
-            TweenGraDic[target] = new TweenGra(graphic, graphic.color, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenGraDic[target];
-        }
-        else
-        {
-            tweenGra = new TweenGra(graphic, graphic.color, destination, duration, originActive, destActive, curve, cg);
-
-            TweenGraDic.Add(target, tweenGra);
-
-            return tweenGra;
-        }
-    }
-
-
-    public static TweenVec CreateTweenVec2D(Transform target, Vector3 origin, Vector3 destination, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenVec tweenVec2D;
-
-        if (local)
-        {
-            origin.z = target.localPosition.z;
-            destination.z = target.localPosition.z;
-        }
-        else
-        {
-            origin.z = target.position.z;
-            destination.z = target.position.z;
-        }
-
-        if (TweenVecDic.ContainsKey(target))
-        {
-            tweenVec2D = TweenVecDic[target];
-
-            tweenVec2D.Pause();
-
-            TweenVecDic[target] = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            return TweenVecDic[target];
-        }
-        else
-        {
-            tweenVec2D = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            TweenVecDic.Add(target, tweenVec2D);
-
-            return tweenVec2D;
-        }
-    }
-
-    public static TweenVec CreateTweenVec2D(Transform target, Vector3 destination, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenVec tweenVec2D;
-
-        Vector3 origin;
-
-        if (local)
-        {
-            origin = target.localPosition;
-
-            destination.z = target.localPosition.z;
-        }
-        else
-        {
-            origin = target.position;
-
-            destination.z = target.position.z;
-        }
-
-
-        if (TweenVecDic.ContainsKey(target))
-        {
-            tweenVec2D = TweenVecDic[target];
-
-            tweenVec2D.Pause();
-
-            TweenVecDic[target] = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            return TweenVecDic[target];
-        }
-        else
-        {
-            tweenVec2D = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            TweenVecDic.Add(target, tweenVec2D);
-
-            return tweenVec2D;
-        }
-    }
-
-    public static TweenVec CreateTweenVecOffset2D(Transform target, Vector3 offset, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenVec tweenVec2D;
-
-        Vector3 origin;
-        Vector3 destination;
-
-        if (local)
-        {
-            origin = target.localPosition;
-            destination = target.localPosition + offset;
-
-            destination.z = target.localPosition.z;
-        }
-        else
-        {
-            origin = target.position;
-            destination = target.position + offset;
-
-            destination.z = target.position.z;
-        }
-
-        if (TweenVecDic.ContainsKey(target))
-        {
-            tweenVec2D = TweenVecDic[target];
-
-            tweenVec2D.Pause();
-
-            TweenVecDic[target] = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            return TweenVecDic[target];
-        }
-        else
-        {
-            tweenVec2D = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            TweenVecDic.Add(target, tweenVec2D);
-
-            return tweenVec2D;
-        }
-    }
-
-
-    public static TweenVec CreateTweenVec3D(Transform target, Vector3 origin, Vector3 destination, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenVec tweenVec3D;
-
-        if (TweenVecDic.ContainsKey(target))
-        {
-            tweenVec3D = TweenVecDic[target];
-
-            tweenVec3D.Pause();
-
-            TweenVecDic[target] = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            return TweenVecDic[target];
-        }
-        else
-        {
-            tweenVec3D = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            TweenVecDic.Add(target, tweenVec3D);
-
-            return tweenVec3D;
-        }
-    }
-
-    public static TweenVec CreateTweenVec3D(Transform target, Vector3 destination, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenVec tweenVec3D;
-
-        Vector3 origin;
-
-        if (local)
-        {
-            origin = target.localPosition;
-        }
-        else
-        {
-            origin = target.position;
-        }
-
-        if (TweenVecDic.ContainsKey(target))
-        {
-            tweenVec3D = TweenVecDic[target];
-
-            tweenVec3D.Pause();
-
-            TweenVecDic[target] = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            return TweenVecDic[target];
-        }
-        else
-        {
-            tweenVec3D = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            TweenVecDic.Add(target, tweenVec3D);
-
-            return tweenVec3D;
-        }
-    }
-
-    public static TweenVec CreateTweenVecOffset3D(Transform target, Vector3 offset, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenVec tweenVec3D;
-
-        Vector3 origin;
-        Vector3 destination;
-
-        if (local)
-        {
-            origin = target.localPosition;
-            destination = target.localPosition + offset;
-        }
-        else
-        {
-            origin = target.position;
-            destination = target.position + offset;
-        }
-
-        if (TweenVecDic.ContainsKey(target))
-        {
-            tweenVec3D = TweenVecDic[target];
-
-            tweenVec3D.Pause();
-
-            TweenVecDic[target] = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            return TweenVecDic[target];
-        }
-        else
-        {
-            tweenVec3D = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            TweenVecDic.Add(target, tweenVec3D);
-
-            return tweenVec3D;
-        }
-    }
-
-
-    public static TweenEuler CreateTweenEuler(Transform target, Vector3 origin, Vector3 destination, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenEuler tweenEuler;
-
-        if (TweenEulerDic.ContainsKey(target))
-        {
-            tweenEuler = TweenEulerDic[target];
-
-            tweenEuler.Pause();
-
-            TweenEulerDic[target] = new TweenEuler(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            return TweenEulerDic[target];
-        }
-        else
-        {
-            tweenEuler = new TweenEuler(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            TweenEulerDic.Add(target, tweenEuler);
-
-            return tweenEuler;
-        }
-    }
-
-    public static TweenEuler CreateTweenEuler(Transform target, Vector3 destination, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenEuler tweenEuler;
-
-        Vector3 origin;
-
-        if (local)
-        {
-            origin = target.localEulerAngles;
-        }
-        else
-        {
-            origin = target.eulerAngles;
-        }
-
-        if (TweenEulerDic.ContainsKey(target))
-        {
-            tweenEuler = TweenEulerDic[target];
-
-            tweenEuler.Pause();
-
-            TweenEulerDic[target] = new TweenEuler(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            return TweenEulerDic[target];
-        }
-        else
-        {
-            tweenEuler = new TweenEuler(target, origin, destination, duration, local, originActive, destActive, curve, cg);
-
-            TweenEulerDic.Add(target, tweenEuler);
-
-            return tweenEuler;
-        }
-    }
-
-
-    public static TweenFont CreateTweenFont(Transform target, int origin, int destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Text text = target.GetComponent<Text>();
-        TweenFont tweenFont;
-
-        if (TweenRectDic.ContainsKey(target))
-        {
-            tweenFont = TweenFontDic[target];
-
-            tweenFont.Pause();
-
-            TweenFontDic[target] = new TweenFont(text, origin, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenFontDic[target];
-        }
-        else
-        {
-            tweenFont = new TweenFont(text, origin, destination, duration, originActive, destActive, curve, cg);
-
-            TweenFontDic.Add(target, tweenFont);
-
-            return tweenFont;
-        }
-    }
-
-    public static TweenFont CreateTweenFont(Transform target, int destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Text text = target.GetComponent<Text>();
-        TweenFont tweenFont;
-
-        if (TweenRectDic.ContainsKey(target))
-        {
-            tweenFont = TweenFontDic[target];
-
-            tweenFont.Pause();
-
-            TweenFontDic[target] = new TweenFont(text, text.fontSize, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenFontDic[target];
-        }
-        else
-        {
-            tweenFont = new TweenFont(text, text.fontSize, destination, duration, originActive, destActive, curve, cg);
-
-            TweenFontDic.Add(target, tweenFont);
-
-            return tweenFont;
-        }
-    }
-
-
-    public static TweenRect CreateTweenRect(Transform target, Vector2 origin, Vector2 destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenRect tweenRect;
-        RectTransform rectTra = target.GetComponent<RectTransform>();
-
-        if (TweenRectDic.ContainsKey(target))
-        {
-            tweenRect = TweenRectDic[target];
-
-            tweenRect.Pause();
-
-            TweenRectDic[target] = new TweenRect(rectTra, origin, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenRectDic[target];
-        }
-        else
-        {
-            tweenRect = new TweenRect(rectTra, origin, destination, duration, originActive, destActive, curve, cg);
-
-            TweenRectDic.Add(target, tweenRect);
-
-            return tweenRect;
-        }
-    }
-
-    public static TweenRect CreateTweenRect(Transform target, Vector2 destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenRect tweenRect;
-        RectTransform rectTra = target.GetComponent<RectTransform>();
-
-        if (TweenRectDic.ContainsKey(target))
-        {
-            tweenRect = TweenRectDic[target];
-
-            tweenRect.Pause();
-
-            TweenRectDic[target] = new TweenRect(rectTra, rectTra.rect.size, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenRectDic[target];
-        }
-        else
-        {
-            tweenRect = new TweenRect(rectTra, rectTra.rect.size, destination, duration, originActive, destActive, curve, cg);
-
-            TweenRectDic.Add(target, tweenRect);
-
-            return tweenRect;
-        }
-    }
-
-
-    public static TweenScale CreateTweenScale(Transform target, float origin, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Vector3 destScale = new Vector3(destination, destination, destination);
-        Vector3 originScale = new Vector3(origin, origin, origin);
-
-
-        TweenScale tweenScale;
-
-        if (TweenScaleDic.ContainsKey(target))
-        {
-            tweenScale = TweenScaleDic[target];
-
-            tweenScale.Pause();
-
-            TweenScaleDic[target] = new TweenScale(target, originScale, destScale, duration, originActive, destActive, curve, cg);
-
-            return TweenScaleDic[target];
-        }
-        else
-        {
-            tweenScale = new TweenScale(target, originScale, destScale, duration, originActive, destActive, curve, cg);
-
-            TweenScaleDic.Add(target, tweenScale);
-
-            return tweenScale;
-        }
-    }
-
-    public static TweenScale CreateTweenScale(Transform target, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Vector3 destScale = new Vector3(destination, destination, destination);
-
-
-        TweenScale tweenScale;
-
-        if (TweenScaleDic.ContainsKey(target))
-        {
-            tweenScale = TweenScaleDic[target];
-
-            tweenScale.Pause();
-
-            TweenScaleDic[target] = new TweenScale(target, target.localScale, destScale, duration, originActive, destActive, curve, cg);
-
-            return TweenScaleDic[target];
-        }
-        else
-        {
-            tweenScale = new TweenScale(target, target.localScale, destScale, duration, originActive, destActive, curve, cg);
-
-            TweenScaleDic.Add(target, tweenScale);
-
-            return tweenScale;
-        }
-    }
-
-    public static TweenScale CreateTweenScale(Transform target, Vector3 origin, Vector3 destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenScale tweenScale;
-
-        if (TweenScaleDic.ContainsKey(target))
-        {
-            tweenScale = TweenScaleDic[target];
-
-            tweenScale.Pause();
-
-            TweenScaleDic[target] = new TweenScale(target, origin, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenScaleDic[target];
-        }
-        else
-        {
-            tweenScale = new TweenScale(target, origin, destination, duration, originActive, destActive, curve, cg);
-
-            TweenScaleDic.Add(target, tweenScale);
-
-            return tweenScale;
-        }
-    }
-
-    public static TweenScale CreateTweenScale(Transform target, Vector3 destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenScale tweenScale;
-
-        if (TweenScaleDic.ContainsKey(target))
-        {
-            tweenScale = TweenScaleDic[target];
-
-            tweenScale.Pause();
-
-            TweenScaleDic[target] = new TweenScale(target, target.localScale, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenScaleDic[target];
-        }
-        else
-        {
-            tweenScale = new TweenScale(target, target.localScale, destination, duration, originActive, destActive, curve, cg);
-
-            TweenScaleDic.Add(target, tweenScale);
-
-            return tweenScale;
-        }
-    }
-
-
-    public static TweenAudio CreateTweenAudio(Transform target, float origin, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenAudio tweenAudio;
-        AudioSource audio = target.GetComponent<AudioSource>();
-
-        if (TweenAudioDic.ContainsKey(audio))
-        {
-            tweenAudio = TweenAudioDic[audio];
-
-            tweenAudio.Pause();
-
-            TweenAudioDic[audio] = new TweenAudio(audio, origin, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenAudioDic[audio];
-        }
-        else
-        {
-            tweenAudio = new TweenAudio(audio, origin, destination, duration, originActive, destActive, curve, cg);
-
-            TweenAudioDic.Add(audio, tweenAudio);
-
-            return tweenAudio;
-        }
-    }
-
-    public static TweenAudio CreateTweenAudio(Transform target, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenAudio tweenAudio;
-        AudioSource audio = target.GetComponent<AudioSource>();
-
-        if (TweenAudioDic.ContainsKey(audio))
-        {
-            tweenAudio = TweenAudioDic[audio];
-
-            tweenAudio.Pause();
-
-            TweenAudioDic[audio] = new TweenAudio(audio, audio.volume, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenAudioDic[audio];
-        }
-        else
-        {
-            tweenAudio = new TweenAudio(audio, audio.volume, destination, duration, originActive, destActive, curve, cg);
-
-            TweenAudioDic.Add(audio, tweenAudio);
-
-            return tweenAudio;
-        }
-    }
-
-    public static TweenAudio CreateTweenAudio(AudioSource audioSource, float origin, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenAudio tweenAudio;
-
-        if (TweenAudioDic.ContainsKey(audioSource))
-        {
-            tweenAudio = TweenAudioDic[audioSource];
-
-            tweenAudio.Pause();
-
-            TweenAudioDic[audioSource] = new TweenAudio(audioSource, origin, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenAudioDic[audioSource];
-        }
-        else
-        {
-            tweenAudio = new TweenAudio(audioSource, origin, destination, duration, originActive, destActive, curve, cg);
-
-            TweenAudioDic.Add(audioSource, tweenAudio);
-
-            return tweenAudio;
-        }
-    }
-
-    public static TweenAudio CreateTweenAudio(AudioSource audioSource, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenAudio tweenAudio;
-
-        if (TweenAudioDic.ContainsKey(audioSource))
-        {
-            tweenAudio = TweenAudioDic[audioSource];
-
-            tweenAudio.Pause();
-
-            TweenAudioDic[audioSource] = new TweenAudio(audioSource, audioSource.volume, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenAudioDic[audioSource];
-        }
-        else
-        {
-            tweenAudio = new TweenAudio(audioSource, audioSource.volume, destination, duration, originActive, destActive, curve, cg);
-            
-            TweenAudioDic.Add(audioSource, tweenAudio);
-
-            return tweenAudio;
-        }
-    }
-
-
-    public static TweenOutline CreateTweenOutline(Transform target, float originAlpha, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Outline outline = target.GetComponent<Outline>();
-        TweenOutline tweenOutline;
-
-        Color origin = outline.effectColor;
-        Color destination = outline.effectColor;
-
-        origin.a = originAlpha;
-        destination.a = destAlpha;
-
-        if (TweenOutlineDic.ContainsKey(target))
-        {
-            tweenOutline = TweenOutlineDic[target];
-
-            tweenOutline.Pause();
-
-            TweenOutlineDic[target] = new TweenOutline(outline, origin, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenOutlineDic[target];
-        }
-        else
-        {
-            tweenOutline = new TweenOutline(outline, origin, destination, duration, originActive, destActive, curve, cg);
-
-            TweenOutlineDic.Add(target, tweenOutline);
-
-            return tweenOutline;
-        }
-    }
-
-    public static TweenOutline CreateTweenOutline(Transform target, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Outline graphic = target.GetComponent<Outline>();
-        TweenOutline tweenOutline;
-
-        Color destination = graphic.effectColor;
-
-        destination.a = destAlpha;
-
-        if (TweenOutlineDic.ContainsKey(target))
-        {
-            tweenOutline = TweenOutlineDic[target];
-
-            tweenOutline.Pause();
-
-            TweenOutlineDic[target] = new TweenOutline(graphic, graphic.effectColor, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenOutlineDic[target];
-        }
-        else
-        {
-            tweenOutline = new TweenOutline(graphic, graphic.effectColor, destination, duration, originActive, destActive, curve, cg);
-
-            TweenOutlineDic.Add(target, tweenOutline);
-
-            return tweenOutline;
-        }
-    }
-
-    public static TweenOutline CreateTweenOutline(Transform target, Color origin, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Outline outline = target.GetComponent<Outline>();
-        TweenOutline tweenOutline;
-
-        if (TweenOutlineDic.ContainsKey(target))
-        {
-            tweenOutline = TweenOutlineDic[target];
-
-            tweenOutline.Pause();
-
-            TweenOutlineDic[target] = new TweenOutline(outline, origin, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenOutlineDic[target];
-        }
-        else
-        {
-            tweenOutline = new TweenOutline(outline, origin, destination, duration, originActive, destActive, curve, cg);
-
-            TweenOutlineDic.Add(target, tweenOutline);
-
-            return tweenOutline;
-        }
-    }
-
-    public static TweenOutline CreateTweenOutline(Transform target, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Outline graphic = target.GetComponent<Outline>();
-        TweenOutline tweenOutline;
-
-        if (TweenOutlineDic.ContainsKey(target))
-        {
-            tweenOutline = TweenOutlineDic[target];
-
-            tweenOutline.Pause();
-
-            TweenOutlineDic[target] = new TweenOutline(graphic, graphic.effectColor, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenOutlineDic[target];
-        }
-        else
-        {
-            tweenOutline = new TweenOutline(graphic, graphic.effectColor, destination, duration, originActive, destActive, curve, cg);
-
-            TweenOutlineDic.Add(target, tweenOutline);
-
-            return tweenOutline;
-        }
-    }
-
-
-    public static TweenNumber CreateTweenNumber(Transform target, int origin, int destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Text text = target.GetComponent<Text>();
-        TweenNumber tweenNumber;
-
-        if (TweenNumberDic.ContainsKey(target))
-        {
-            tweenNumber = TweenNumberDic[target];
-
-            tweenNumber.Pause();
-
-            TweenNumberDic[target] = new TweenNumber(text, origin, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenNumberDic[target];
-        }
-        else
-        {
-            tweenNumber = new TweenNumber(text, origin, destination, duration, originActive, destActive, curve, cg);
-
-            TweenNumberDic.Add(target, tweenNumber);
-
-            return tweenNumber;
-        }
-    }
-
-    public static TweenNumber CreateTweenNumber(Transform target, int destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        Text text = target.GetComponent<Text>();
-        TweenNumber tweenNumber;
-
-        if (TweenNumberDic.ContainsKey(target))
-        {
-            tweenNumber = TweenNumberDic[target];
-
-            tweenNumber.Pause();
-
-            TweenNumberDic[target] = new TweenNumber(text, int.Parse(text.text), destination, duration, originActive, destActive, curve, cg);
-
-            return TweenNumberDic[target];
-        }
-        else
-        {
-            tweenNumber = new TweenNumber(text, int.Parse(text.text), destination, duration, originActive, destActive, curve, cg);
-
-            TweenNumberDic.Add(target, tweenNumber);
-
-            return tweenNumber;
-        }
-    }
-
-
-    public static TweenMatColor CreateTweenMatColor(MaterialUnit target, Color origin, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenMatColor tweenMatColor;
-
-        if (TweenMatColorDic.ContainsKey(target))
-        {
-            tweenMatColor = TweenMatColorDic[target];
-
-            tweenMatColor.Pause();
-
-            TweenMatColorDic[target] = new TweenMatColor(target, origin, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenMatColorDic[target];
-        }
-        else
-        {
-            tweenMatColor = new TweenMatColor(target, origin, destination, duration, originActive, destActive, curve, cg);
-
-            TweenMatColorDic.Add(target, tweenMatColor);
-
-            return tweenMatColor;
-        }
-    }
-
-    public static TweenMatColor CreateTweenMatColor(MaterialUnit target, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenMatColor tweenMatColor;
-
-        if (TweenMatColorDic.ContainsKey(target))
-        {
-            tweenMatColor = TweenMatColorDic[target];
-
-            tweenMatColor.Pause();
-
-            TweenMatColorDic[target] = new TweenMatColor(target, target.GetColor(), destination, duration, originActive, destActive, curve, cg);
-
-            return TweenMatColorDic[target];
-        }
-        else
-        {
-            tweenMatColor = new TweenMatColor(target, target.GetColor(), destination, duration, originActive, destActive, curve, cg);
-
-            TweenMatColorDic.Add(target, tweenMatColor);
-
-            return tweenMatColor;
-        }
-    }
-
-    public static TweenMatFloat CreateTweenMatFloat(MaterialUnit target, float origin, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenMatFloat tweenMatFloat;
-
-        if (TweenMatFloatDic.ContainsKey(target))
-        {
-            tweenMatFloat = TweenMatFloatDic[target];
-
-            tweenMatFloat.Pause();
-
-            TweenMatFloatDic[target] = new TweenMatFloat(target, origin, destination, duration, originActive, destActive, curve, cg);
-
-            return TweenMatFloatDic[target];
-        }
-        else
-        {
-            tweenMatFloat = new TweenMatFloat(target, origin, destination, duration, originActive, destActive, curve, cg);
-
-            TweenMatFloatDic.Add(target, tweenMatFloat);
-
-            return tweenMatFloat;
-        }
-    }
-
-    public static TweenMatFloat CreateTweenMatFloat(MaterialUnit target, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
-    {
-        TweenMatFloat tweenMatFloat;
-
-        if (TweenMatFloatDic.ContainsKey(target))
-        {
-            tweenMatFloat = TweenMatFloatDic[target];
-
-            tweenMatFloat.Pause();
-
-            TweenMatFloatDic[target] = new TweenMatFloat(target, target.GetFloat(), destination, duration, originActive, destActive, curve, cg);
-
-            return TweenMatFloatDic[target];
-        }
-        else
-        {
-            tweenMatFloat = new TweenMatFloat(target, target.GetFloat(), destination, duration, originActive, destActive, curve, cg);
-
-            TweenMatFloatDic.Add(target, tweenMatFloat);
-
-            return tweenMatFloat;
-        }
-    }
-
-
-    public static TweenGrayMesh CreateTweenGrayMesh(MeshFilter target, float origin, float destination, float duration, bool originActive, bool destActive, Curve curve)
-    {
-        TweenGrayMesh tweenGrayMesh;
-
-        if (TweenGrayMeshDic.ContainsKey(target))
-        {
-            tweenGrayMesh = TweenGrayMeshDic[target];
-
-            tweenGrayMesh.Pause();
-
-            TweenGrayMeshDic[target] = new TweenGrayMesh(target, origin, destination, duration, originActive, destActive, curve);
-
-            return TweenGrayMeshDic[target];
-        }
-        else
-        {
-            tweenGrayMesh = new TweenGrayMesh(target, origin, destination, duration, originActive, destActive, curve);
-
-            TweenGrayMeshDic.Add(target, tweenGrayMesh);
-
-            return tweenGrayMesh;
-        }
-    }
-
-    #endregion
+using UnityEngine;
+using UnityEngine.UI;
+using UnityEngine.Events;
+
+using System;
+using System.Collections;
+using System.Collections.Generic;
+
+public enum Curve
+{
+    Linear,
+    EaseOutQuad,
+}
+
+public enum EventType
+{
+    ForwardStart,
+    BackwardStart,
+    ForwardFinish,
+    BackwardFinish,
+}
+
+
+public delegate float TimerFunction(float value, float duration, float start, float delta);
+
+
+public delegate float ShakeFunctionF(float timer, float duration, int repeat, float start, float strength);
+
+public delegate Color ShakeFunctionC(float timer, float duration, int repeat, Color start, Color strength);
+
+public delegate Vector3 ShakeFunctionV(float timer, float duration, int repeat, Vector3 start, Vector3 strength);
+
+
+public delegate float CurveFunctionF(float timer, float duration, float start, float delta);
+
+public delegate Color CurveFunctionC(float timer, float duration, Color start, Color delta);
+
+public delegate Vector3 CurveFunctionV(float timer, float duration, Vector3 start, Vector3 delta);
+
+
+public class MaterialUnit
+{
+    public Material Material;
+    public Transform Transform;
+
+    public List<string> PropertyList;
+
+    public MaterialUnit(Material material, Transform transform, List<string> propertyList)
+    {
+        Material = material;
+        Transform = transform;
+        PropertyList = propertyList;
+    }
+
+
+    public void SetFloat(float value)
+    {
+        for (int i = 0; i < PropertyList.Count; i++)
+        {
+            Material.SetFloat(PropertyList[i], value);
+        }
+    }
+
+    public void SetColor(Color value)
+    {
+        for (int i = 0; i < PropertyList.Count; i++)
+        {
+            Material.SetColor(PropertyList[i], value);
+        }
+    }
+
+    public float GetFloat()
+    {
+        return Material.GetFloat(PropertyList[0]);
+    }
+
+    public Color GetColor()
+    {
+        return Material.GetColor(PropertyList[0]);
+    }
+}
+
+public class AnimManager : Regist
+{
+    #region 变量
+
+    public static List<MoveRoot> MoveForList = new List<MoveRoot>();
+    public static List<MoveRoot> MoveBacList = new List<MoveRoot>();
+
+    public static Dictionary<Curve, TimerFunction> TimerFunctionDic = new Dictionary<Curve, TimerFunction>();
+
+    public static Dictionary<Curve, ShakeFunctionF> ShakeFuncDicF = new Dictionary<Curve, ShakeFunctionF>();
+    public static Dictionary<Curve, ShakeFunctionC> ShakeFuncDicC = new Dictionary<Curve, ShakeFunctionC>();
+    public static Dictionary<Curve, ShakeFunctionV> ShakeFuncDicV = new Dictionary<Curve, ShakeFunctionV>();
+
+    public static Dictionary<Curve, CurveFunctionF> CurveFuncDicF = new Dictionary<Curve, CurveFunctionF>();
+    public static Dictionary<Curve, CurveFunctionC> CurveFuncDicC = new Dictionary<Curve, CurveFunctionC>();
+    public static Dictionary<Curve, CurveFunctionV> CurveFuncDicV = new Dictionary<Curve, CurveFunctionV>();
+
+    public static Dictionary<Transform, Shake> ShakeDic = new Dictionary<Transform, Shake>();
+    public static Dictionary<Transform, Move2D> MoveDic2D = new Dictionary<Transform, Move2D>();
+    public static Dictionary<Transform, Move3D> MoveDic3D = new Dictionary<Transform, Move3D>();
+    public static Dictionary<Transform, Zoom2D> ZoomDic2D = new Dictionary<Transform, Zoom2D>();
+
+    public static Dictionary<Transform, TweenSr> TweenSrDic = new Dictionary<Transform, TweenSr>();
+    public static Dictionary<Transform, TweenCG> TweenCgDic = new Dictionary<Transform, TweenCG>();
+    public static Dictionary<Transform, TweenGra> TweenGraDic = new Dictionary<Transform, TweenGra>();
+    public static Dictionary<Transform, TweenVec> TweenVecDic = new Dictionary<Transform, TweenVec>();
+    public static Dictionary<Transform, TweenEuler> TweenEulerDic = new Dictionary<Transform, TweenEuler>();
+    public static Dictionary<Transform, TweenFont> TweenFontDic = new Dictionary<Transform, TweenFont>();
+    public static Dictionary<Transform, TweenRect> TweenRectDic = new Dictionary<Transform, TweenRect>();
+    public static Dictionary<Transform, TweenScale> TweenScaleDic = new Dictionary<Transform, TweenScale>();
+    public static Dictionary<Transform, TweenOutline> TweenOutlineDic = new Dictionary<Transform, TweenOutline>();
+    public static Dictionary<Transform, TweenNumber> TweenNumberDic = new Dictionary<Transform, TweenNumber>();
+    public static Dictionary<Renderer, TweenRenderer> TweenRendererDic = new Dictionary<Renderer, TweenRenderer>();
+    public static Dictionary<AudioSource, TweenAudio> TweenAudioDic = new Dictionary<AudioSource, TweenAudio>();
+
+    public static Dictionary<MaterialUnit, TweenMatColor> TweenMatColorDic = new Dictionary<MaterialUnit, TweenMatColor>();
+    public static Dictionary<MaterialUnit, TweenMatFloat> TweenMatFloatDic = new Dictionary<MaterialUnit, TweenMatFloat>();
+    public static Dictionary<MeshFilter, TweenGrayMesh> TweenGrayMeshDic = new Dictionary<MeshFilter, TweenGrayMesh>();
+
+    public static Dictionary<Transform, StreamScale> StreamScaleDic = new Dictionary<Transform, StreamScale>();
+
+    #endregion
+
+    public void Update()
+    {
+        for (int i = 0; i < MoveForList.Count; i++)
+        {
+            MoveRoot move = MoveForList[i];
+
+            if (move.DoForward())
+            {
+                if (MoveForList.Remove(move))
+                {
+                    i--;
+                }
+            }
+        }
+
+        for (int i = 0; i < MoveBacList.Count; i++)
+        {
+            MoveRoot move = MoveBacList[i];
+
+            if (move.DoBackward())
+            {
+                if (MoveBacList.Remove(move))
+                {
+                    i--;
+                }
+            }
+        }
+    }
+
+
+    public override bool InitAtOnce()
+    {
+        if (base.InitAtOnce())
+        {
+            return true;
+        }
+
+        TimerFunctionDic.Add(Curve.Linear, LinearTimer);
+        TimerFunctionDic.Add(Curve.EaseOutQuad, EaseOutQuadTimer);
+
+        ShakeFuncDicF.Add(Curve.Linear, ShakeLinear);
+        ShakeFuncDicF.Add(Curve.EaseOutQuad, ShakeEaseOutQuad);
+
+        ShakeFuncDicC.Add(Curve.Linear, ShakeLinear);
+        ShakeFuncDicC.Add(Curve.EaseOutQuad, ShakeEaseOutQuad);
+
+        ShakeFuncDicV.Add(Curve.Linear, ShakeLinear);
+        ShakeFuncDicV.Add(Curve.EaseOutQuad, ShakeEaseOutQuad);
+
+        CurveFuncDicF.Add(Curve.Linear, Linear);
+        CurveFuncDicF.Add(Curve.EaseOutQuad, EaseOutQuad);
+
+        CurveFuncDicC.Add(Curve.Linear, Linear);
+        CurveFuncDicC.Add(Curve.EaseOutQuad, EaseOutQuad);
+
+        CurveFuncDicV.Add(Curve.Linear, Linear);
+        CurveFuncDicV.Add(Curve.EaseOutQuad, EaseOutQuad);
+
+        enabled = true;
+
+        return false;
+    }
+
+
+    #region 曲线
+
+    public static float LinearTimer(float value, float duration, float start, float delta)
+    {
+        return (value - start)*duration/delta;
+    }
+
+    public static float EaseOutQuadTimer(float value, float duration, float start, float delta)
+    {
+        return ((2 - Mathf.Sqrt(4 - 4*(value - start)/delta))/2)*duration;
+    }
+
+
+    public static float ShakeLinear(float timer, float duration, int repeat, float start, float strength)
+    {
+        float sliceTime = duration/(4*repeat);
+
+        for (int i = 0; i < repeat*4; i += 4)
+        {
+            if (timer > duration)
+            {
+                return start;
+            }
+
+            if (timer <= (i + 1)*sliceTime)
+            {
+                timer -= (i)*sliceTime;
+
+                return Linear(timer, sliceTime, start, strength/(i/4 + 1));
+            }
+            else if (timer <= (i + 3)*sliceTime)
+            {
+                timer -= (i + 1)*sliceTime;
+
+                return Linear(timer, 2*sliceTime, start + strength/(i/4 + 1), -2*strength/(i/4 + 1));
+            }
+            else if (timer <= (i + 4)*sliceTime)
+            {
+                timer -= (i + 3)*sliceTime;
+
+                return Linear(timer, sliceTime, start - strength/(i/4 + 1), strength/(i/4 + 1));
+            }
+        }
+
+        throw new Exception();
+    }
+
+    public static Color ShakeLinear(float timer, float duration, int repeat, Color start, Color strength)
+    {
+        float sliceTime = duration/(4*repeat);
+
+        for (int i = 0; i < repeat*4; i += 4)
+        {
+            if (timer > duration)
+            {
+                return start;
+            }
+
+            if (timer <= (i + 1)*sliceTime)
+            {
+                timer -= (i)*sliceTime;
+
+                return Linear(timer, sliceTime, start, strength/(i/4 + 1));
+            }
+            else if (timer <= (i + 3)*sliceTime)
+            {
+                timer -= (i + 1)*sliceTime;
+
+                return Linear(timer, 2*sliceTime, start + strength/(i/4 + 1), -2*strength/(i/4 + 1));
+            }
+            else if (timer <= (i + 4)*sliceTime)
+            {
+                timer -= (i + 3)*sliceTime;
+
+                return Linear(timer, sliceTime, start - strength/(i/4 + 1), strength/(i/4 + 1));
+            }
+        }
+
+        throw new Exception();
+    }
+
+    public static Vector3 ShakeLinear(float timer, float duration, int repeat, Vector3 start, Vector3 strength)
+    {
+        float sliceTime = duration/(4*repeat);
+
+        for (int i = 0; i < repeat*4; i += 4)
+        {
+            if (timer > duration)
+            {
+                return start;
+            }
+
+            if (timer <= (i + 1)*sliceTime)
+            {
+                timer -= (i)*sliceTime;
+
+                return Linear(timer, sliceTime, start, strength/(i/4 + 1));
+            }
+            else if (timer <= (i + 3)*sliceTime)
+            {
+                timer -= (i + 1)*sliceTime;
+
+                return Linear(timer, 2*sliceTime, start + strength/(i/4 + 1), -2*strength/(i/4 + 1));
+            }
+            else if (timer <= (i + 4)*sliceTime)
+            {
+                timer -= (i + 3)*sliceTime;
+
+                return Linear(timer, sliceTime, start - strength/(i/4 + 1), strength/(i/4 + 1));
+            }
+        }
+
+        throw new Exception();
+    }
+
+
+    public static float ShakeEaseOutQuad(float timer, float duration, int repeat, float start, float strength)
+    {
+        float sliceTime = duration/(4*repeat);
+
+        for (int i = 0; i < repeat*4; i += 4)
+        {
+            if (timer > duration)
+            {
+                return start;
+            }
+
+            if (timer <= (i + 1)*sliceTime)
+            {
+                timer -= (i)*sliceTime;
+
+                return EaseOutQuad(timer, sliceTime, start, strength/(i/4 + 1));
+            }
+            else if (timer <= (i + 3)*sliceTime)
+            {
+                timer -= (i + 1)*sliceTime;
+
+                return EaseOutQuad(timer, 2*sliceTime, start + strength/(i/4 + 1), -2*strength/(i/4 + 1));
+            }
+            else if (timer <= (i + 4)*sliceTime)
+            {
+                timer -= (i + 3)*sliceTime;
+
+                return EaseOutQuad(timer, sliceTime, start - strength/(i/4 + 1), strength/(i/4 + 1));
+            }
+        }
+
+        throw new Exception();
+    }
+
+    public static Color ShakeEaseOutQuad(float timer, float duration, int repeat, Color start, Color strength)
+    {
+        float sliceTime = duration/(4*repeat);
+
+        for (int i = 0; i < repeat*4; i += 4)
+        {
+            if (timer > duration)
+            {
+                return start;
+            }
+
+            if (timer <= (i + 1)*sliceTime)
+            {
+                timer -= (i)*sliceTime;
+
+                return EaseOutQuad(timer, sliceTime, start, strength/(i/4 + 1));
+            }
+            else if (timer <= (i + 3)*sliceTime)
+            {
+                timer -= (i + 1)*sliceTime;
+
+                return EaseOutQuad(timer, 2*sliceTime, start + strength/(i/4 + 1), -2*strength/(i/4 + 1));
+            }
+            else if (timer <= (i + 4)*sliceTime)
+            {
+                timer -= (i + 3)*sliceTime;
+
+                return EaseOutQuad(timer, sliceTime, start - strength/(i/4 + 1), strength/(i/4 + 1));
+            }
+        }
+
+        throw new Exception();
+    }
+
+    public static Vector3 ShakeEaseOutQuad(float timer, float duration, int repeat, Vector3 start, Vector3 strength)
+    {
+        float sliceTime = duration/(4*repeat);
+
+        for (int i = 0; i < repeat*4; i += 4)
+        {
+            if (timer > duration)
+            {
+                return start;
+            }
+
+            if (timer <= (i + 1)*sliceTime)
+            {
+                timer -= (i)*sliceTime;
+
+                return EaseOutQuad(timer, sliceTime, start, strength/(i/4 + 1));
+            }
+            else if (timer <= (i + 3)*sliceTime)
+            {
+                timer -= (i + 1)*sliceTime;
+
+                return EaseOutQuad(timer, 2*sliceTime, start + strength/(i/4 + 1), -2*strength/(i/4 + 1));
+            }
+            else if (timer <= (i + 4)*sliceTime)
+            {
+                timer -= (i + 3)*sliceTime;
+
+                return EaseOutQuad(timer, sliceTime, start - strength/(i/4 + 1), strength/(i/4 + 1));
+            }
+        }
+
+        throw new Exception();
+    }
+
+
+    public static float Linear(float timer, float duration, float start, float delta)
+    {
+        if (timer >= duration)
+        {
+            return start + delta;
+        }
+
+        if (duration.Equal(0))
+        {
+            return delta + start;
+        }
+        else
+        {
+            return delta*timer/duration + start;
+        }
+    }
+
+    public static Color Linear(float timer, float duration, Color start, Color delta)
+    {
+        return new Color(Linear(timer, duration, start.r, delta.r), Linear(timer, duration, start.g, delta.g), Linear(timer, duration, start.b, delta.b), Linear(timer, duration, start.a, delta.a));
+    }
+
+    public static Vector3 Linear(float timer, float duration, Vector3 start, Vector3 delta)
+    {
+        return new Vector3(Linear(timer, duration, start.x, delta.x), Linear(timer, duration, start.y, delta.y), Linear(timer, duration, start.z, delta.z));
+    }
+
+
+    public static float EaseOutQuad(float timer, float duration, float start, float delta)
+    {
+        if (timer >= duration)
+        {
+            return start + delta;
+        }
+
+        if (duration.Equal(0))
+        {
+            return delta + start;
+        }
+        else
+        {
+            timer /= duration;
+            
+            return -delta*timer*(timer - 2) + start;
+        }
+    }
+
+    public static Color EaseOutQuad(float timer, float duration, Color start, Color delta)
+    {
+        return new Color(EaseOutQuad(timer, duration, start.r, delta.r), EaseOutQuad(timer, duration, start.g, delta.g), EaseOutQuad(timer, duration, start.b, delta.b), EaseOutQuad(timer, duration, start.a, delta.a));
+    }
+
+    public static Vector3 EaseOutQuad(float timer, float duration, Vector3 start, Vector3 delta)
+    {
+        return new Vector3(EaseOutQuad(timer, duration, start.x, delta.x), EaseOutQuad(timer, duration, start.y, delta.y), EaseOutQuad(timer, duration, start.z, delta.z));
+    }
+
+    #endregion
+
+    #region 播放动画
+
+    public static Shake Shake(Transform target, float duration, int repeat, Vector3 strength, Curve curve)
+    {
+        Shake move;
+
+        if (ShakeDic.TryGetValue(target, out move))
+        {
+            move.StartShake(repeat, duration, strength, curve);
+        }
+        else
+        {
+            move = CreateShake(target);
+
+            move.StartShake(repeat, duration, strength, curve);
+        }
+
+        return move;
+    }
+
+
+    public static Move2D Move2D(Transform target, Vector3 destination, float duration, bool local, Curve curve)
+    {
+        Move2D move;
+
+        if (local)
+        {
+            destination.z = target.localPosition.z;
+        }
+        else
+        {
+            destination.z = target.position.z;
+        }
+
+        if (MoveDic2D.TryGetValue(target, out move))
+        {
+            move.StartMove(destination, duration, local, curve);
+
+            return move;
+        }
+        else
+        {
+            move = CreateMove2D(target);
+
+            move.StartMove(destination, duration, local, curve);
+
+            return move;
+        }
+    }
+
+    public static Move3D Move3D(Transform target, Vector3 destination, float duration, bool local, Curve curve)
+    {
+        Move3D move;
+
+        if (MoveDic3D.TryGetValue(target, out move))
+        {
+            move.StartMove(destination, duration, local, curve);
+
+            return move;
+        }
+        else
+        {
+            move = CreateMove3D(target);
+
+            move.StartMove(destination, duration, local, curve);
+
+            return move;
+        }
+    }
+
+    public static Move2D MoveOffset2D(Transform target, Vector3 offset, float duration, bool local, Curve curve)
+    {
+        Move2D move;
+
+        Vector3 destination;
+
+        if (local)
+        {
+            destination = target.localPosition + offset;
+
+            destination.z = target.localPosition.z;
+        }
+        else
+        {
+            destination = target.position + offset;
+
+            destination.z = target.position.z;
+        }
+
+        if (MoveDic2D.TryGetValue(target, out move))
+        {
+            move.StartMove(destination, duration, local, curve);
+
+            return move;
+        }
+        else
+        {
+            move = CreateMove2D(target);
+
+            move.StartMove(destination, duration, local, curve);
+
+            return move;
+        }
+    }
+
+    public static Move3D MoveOffset3D(Transform target, Vector3 offset, float duration, bool local, Curve curve)
+    {
+        Move3D move;
+
+        Vector3 destination;
+
+        if (local)
+        {
+            destination = target.localPosition + offset;
+        }
+        else
+        {
+            destination = target.position + offset;
+        }
+
+        if (MoveDic3D.TryGetValue(target, out move))
+        {
+            move.StartMove(destination, duration, local, curve);
+
+            return move;
+        }
+        else
+        {
+            move = CreateMove3D(target);
+
+            move.StartMove(destination, duration, local, curve);
+
+            return move;
+        }
+    }
+
+
+    public static Zoom2D Zoom2D(Transform target, float origin, float destination, float duration, float stay, Transform zoom, Curve curve)
+    {
+        Zoom2D move;
+
+        if (ZoomDic2D.TryGetValue(target, out move))
+        {
+            move.StartZoom(origin, destination, duration, stay, zoom, curve);
+        }
+        else
+        {
+            move = CreateZoom2D(target);
+
+            move.StartZoom(origin, destination, duration, stay, zoom, curve);
+        }
+
+        return move;
+    }
+
+    public static Zoom2D Zoom2D(Transform target, float destination, float duration, float stay, Transform zoom, Curve curve)
+    {
+        Zoom2D move;
+
+        Camera camera = target.GetComponent<Camera>();
+
+        if (ZoomDic2D.TryGetValue(target, out move))
+        {
+            move.StartZoom(camera.orthographicSize, destination, duration, stay, zoom, curve);
+        }
+        else
+        {
+            move = CreateZoom2D(target);
+
+            move.StartZoom(camera.orthographicSize, destination, duration, stay, zoom, curve);
+        }
+
+        return move;
+    }
+
+
+    public static StreamScale StreamForScale(Transform target)
+    {
+        StreamScale stream;
+
+        if (StreamScaleDic.TryGetValue(target, out stream))
+        {
+            stream.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return stream;
+    }
+
+    public static StreamScale StreamBacScale(Transform target)
+    {
+        StreamScale stream;
+
+        if (StreamScaleDic.TryGetValue(target, out stream))
+        {
+            stream.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return stream;
+    }
+
+    public static StreamScale StreamReForScale(Transform target)
+    {
+        StreamScale stream;
+
+        if (StreamScaleDic.TryGetValue(target, out stream))
+        {
+            stream.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return stream;
+    }
+
+    public static StreamScale StreamReBacScale(Transform target)
+    {
+        StreamScale stream;
+
+        if (StreamScaleDic.TryGetValue(target, out stream))
+        {
+            stream.ReBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return stream;
+    }
+
+
+    public static TweenSr TweenForSr(Transform target)
+    {
+        TweenSr tween;
+
+        if (TweenSrDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenRenderer TweenForRenderer(Renderer target)
+    {
+        TweenRenderer tween;
+
+        if (TweenRendererDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenCG TweenForCG(Transform target)
+    {
+        TweenCG tween;
+
+        if (TweenCgDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenGra TweenForGra(Transform target)
+    {
+        TweenGra tween;
+
+        if (TweenGraDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenEuler TweenForEuler(Transform target)
+    {
+        TweenEuler tween;
+
+        if (TweenEulerDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenVec TweenForVec(Transform target)
+    {
+        TweenVec tween;
+
+        if (TweenVecDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenFont TweenForFont(Transform target)
+    {
+        TweenFont tween;
+
+        if (TweenFontDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenRect TweenForRect(Transform target)
+    {
+        TweenRect tween;
+
+        if (TweenRectDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenScale TweenForScale(Transform target)
+    {
+        TweenScale tween;
+
+        if (TweenScaleDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenAudio TweenForAudio(Transform target)
+    {
+        TweenAudio tween;
+        AudioSource audioSource = target.GetComponent<AudioSource>();
+
+        if (TweenAudioDic.TryGetValue(audioSource, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenAudio TweenForAudio(AudioSource audioSource)
+    {
+        TweenAudio tween;
+
+        if (TweenAudioDic.TryGetValue(audioSource, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenOutline TweenForOutline(Transform target)
+    {
+        TweenOutline tween;
+
+        if (TweenOutlineDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenNumber TweenForNumber(Transform target)
+    {
+        TweenNumber tween;
+
+        if (TweenNumberDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenMatFloat TweenForMatFloat(MaterialUnit target)
+    {
+        TweenMatFloat tween;
+
+        if (TweenMatFloatDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenMatColor TweenForMatColor(MaterialUnit target)
+    {
+        TweenMatColor tween;
+
+        if (TweenMatColorDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenGrayMesh TweenForGrayMesh(MeshFilter target)
+    {
+        TweenGrayMesh tween;
+
+        if (TweenGrayMeshDic.TryGetValue(target, out tween))
+        {
+            tween.StartForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+
+    public static TweenSr TweenBacSr(Transform target)
+    {
+        TweenSr tween;
+
+        if (TweenSrDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenRenderer TweenBacRenderer(Renderer target)
+    {
+        TweenRenderer tween;
+
+        if (TweenRendererDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenCG TweenBacCG(Transform target)
+    {
+        TweenCG tween;
+
+        if (TweenCgDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenGra TweenBacGra(Transform target)
+    {
+        TweenGra tween;
+
+        if (TweenGraDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception(target.name);
+        }
+
+        return tween;
+    }
+
+    public static TweenVec TweenBacVec(Transform target)
+    {
+        TweenVec tween;
+
+        if (TweenVecDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception(target.name);
+        }
+
+        return tween;
+    }
+
+    public static TweenEuler TweenBacEuler(Transform target)
+    {
+        TweenEuler tween;
+
+        if (TweenEulerDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception(target.name);
+        }
+
+        return tween;
+    }
+
+    public static TweenFont TweenBacFont(Transform target)
+    {
+        TweenFont tween;
+
+        if (TweenFontDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenRect TweenBacRect(Transform target)
+    {
+        TweenRect tween;
+
+        if (TweenRectDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenScale TweenBacScale(Transform target)
+    {
+        TweenScale tween;
+
+        if (TweenScaleDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenAudio TweenBacAudio(Transform target)
+    {
+        TweenAudio tween;
+        AudioSource audioSource = target.GetComponent<AudioSource>();
+
+        if (TweenAudioDic.TryGetValue(audioSource, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenAudio TweenBacAudio(AudioSource audioSource)
+    {
+        TweenAudio tween;
+
+        if (TweenAudioDic.TryGetValue(audioSource, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenOutline TweenBacOutline(Transform target)
+    {
+        TweenOutline tween;
+
+        if (TweenOutlineDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenNumber TweenBacNumber(Transform target)
+    {
+        TweenNumber tween;
+
+        if (TweenNumberDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenMatFloat TweenBacMatFloat(MaterialUnit target)
+    {
+        TweenMatFloat tween;
+
+        if (TweenMatFloatDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenMatColor TweenBacMatColor(MaterialUnit target)
+    {
+        TweenMatColor tween;
+
+        if (TweenMatColorDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenGrayMesh TweenBacGrayMesh(MeshFilter target)
+    {
+        TweenGrayMesh tween;
+
+        if (TweenGrayMeshDic.TryGetValue(target, out tween))
+        {
+            tween.StartBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+
+    public static TweenSr TweenReForSr(Transform target)
+    {
+        TweenSr tween;
+
+        if (TweenSrDic.TryGetValue(target, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenRenderer TweenReForRenderer(Renderer target)
+    {
+        TweenRenderer tween;
+
+        if (TweenRendererDic.TryGetValue(target, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenCG TweenReForCG(Transform target)
+    {
+        TweenCG tween;
+
+        if (TweenCgDic.TryGetValue(target, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenGra TweenReForGra(Transform target)
+    {
+        TweenGra tween;
+
+        if (TweenGraDic.TryGetValue(target, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenVec TweenReForVec(Transform target)
+    {
+        TweenVec tween;
+
+        if (TweenVecDic.TryGetValue(target, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenEuler TweenReForEuler(Transform target)
+    {
+        TweenEuler tween;
+
+        if (TweenEulerDic.TryGetValue(target, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenFont TweenReForFont(Transform target)
+    {
+        TweenFont tween;
+
+        if (TweenFontDic.TryGetValue(target, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenRect TweenReForRect(Transform target)
+    {
+        TweenRect tween;
+
+        if (TweenRectDic.TryGetValue(target, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenScale TweenReForScale(Transform target)
+    {
+        TweenScale tween;
+
+        if (TweenScaleDic.TryGetValue(target, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenAudio TweenReForAudio(Transform target)
+    {
+        TweenAudio tween;
+        AudioSource audioSource = target.GetComponent<AudioSource>();
+
+        if (TweenAudioDic.TryGetValue(audioSource, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenAudio TweenReForAudio(AudioSource audioSource)
+    {
+        TweenAudio tween;
+
+        if (TweenAudioDic.TryGetValue(audioSource, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenOutline TweenReForOutline(Transform target)
+    {
+        TweenOutline tween;
+
+        if (TweenOutlineDic.TryGetValue(target, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenNumber TweenReForNumber(Transform target)
+    {
+        TweenNumber tween;
+
+        if (TweenNumberDic.TryGetValue(target, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenMatFloat TweenReForMatFloat(MaterialUnit target)
+    {
+        TweenMatFloat tween;
+
+        if (TweenMatFloatDic.TryGetValue(target, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenMatColor TweenReForMatColor(MaterialUnit target)
+    {
+        TweenMatColor tween;
+
+        if (TweenMatColorDic.TryGetValue(target, out tween))
+        {
+            tween.ReForward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+
+    public static TweenSr TweenReBacSr(Transform target)
+    {
+        TweenSr tween;
+
+        if (TweenSrDic.TryGetValue(target, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenRenderer TweenReBacRenderer(Renderer target)
+    {
+        TweenRenderer tween;
+
+        if (TweenRendererDic.TryGetValue(target, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenCG TweenReBacCG(Transform target)
+    {
+        TweenCG tween;
+
+        if (TweenCgDic.TryGetValue(target, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenGra TweenReBacGra(Transform target)
+    {
+        TweenGra tween;
+
+        if (TweenGraDic.TryGetValue(target, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception(target.name);
+        }
+
+        return tween;
+    }
+
+    public static TweenVec TweenReBacVec(Transform target)
+    {
+        TweenVec tween;
+
+        if (TweenVecDic.TryGetValue(target, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception(target.name);
+        }
+
+        return tween;
+    }
+
+    public static TweenEuler TweenReBacEuler(Transform target)
+    {
+        TweenEuler tween;
+
+        if (TweenEulerDic.TryGetValue(target, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception(target.name);
+        }
+
+        return tween;
+    }
+
+    public static TweenFont TweenReBacFont(Transform target)
+    {
+        TweenFont tween;
+
+        if (TweenFontDic.TryGetValue(target, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenRect TweenReBacRect(Transform target)
+    {
+        TweenRect tween;
+
+        if (TweenRectDic.TryGetValue(target, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenScale TweenReBacScale(Transform target)
+    {
+        TweenScale tween;
+
+        if (TweenScaleDic.TryGetValue(target, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenAudio TweenReBacAudio(Transform target)
+    {
+        TweenAudio tween;
+        AudioSource audioSource = target.GetComponent<AudioSource>();
+
+        if (TweenAudioDic.TryGetValue(audioSource, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenAudio TweenReBacAudio(AudioSource audioSource)
+    {
+        TweenAudio tween;
+
+        if (TweenAudioDic.TryGetValue(audioSource, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenOutline TweenReBacOutline(Transform target)
+    {
+        TweenOutline tween;
+
+        if (TweenOutlineDic.TryGetValue(target, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenNumber TweenReBacNumber(Transform target)
+    {
+        TweenNumber tween;
+
+        if (TweenNumberDic.TryGetValue(target, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenMatFloat TweenReBacMatFloat(MaterialUnit target)
+    {
+        TweenMatFloat tween;
+
+        if (TweenMatFloatDic.TryGetValue(target, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    public static TweenMatColor TweenReBacMatColor(MaterialUnit target)
+    {
+        TweenMatColor tween;
+
+        if (TweenMatColorDic.TryGetValue(target, out tween))
+        {
+            tween.ReBackward();
+        }
+        else
+        {
+            throw new Exception();
+        }
+
+        return tween;
+    }
+
+    #endregion
+
+    #region 获取动画
+
+    public static float GetTimerVec(Vector3 value, float duration, Vector3 start, Vector3 delta, Curve curve)
+    {
+        if (!delta.x.Equal(0))
+        {
+            return TimerFunctionDic[curve](value.x, duration, start.x, delta.x);
+        }
+        else if (!delta.y.Equal(0))
+        {
+            return TimerFunctionDic[curve](value.y, duration, start.y, delta.y);
+        }
+        else if (!delta.z.Equal(0))
+        {
+            return TimerFunctionDic[curve](value.z, duration, start.z, delta.z);
+        }
+        else
+        {
+            throw new Exception();
+        }
+    }
+
+    public static float GetTimerFloat(float value, float duration, float start, float delta, Curve curve)
+    {
+        return TimerFunctionDic[curve](value, duration, start, delta);
+    }
+
+    public static float GetTimerColor(Color value, float duration, Color start, Color delta, Curve curve)
+    {
+        if (!delta.r.Equal(0))
+        {
+            return TimerFunctionDic[curve](value.r, duration, start.r, delta.r);
+        }
+        else if (!delta.g.Equal(0))
+        {
+            return TimerFunctionDic[curve](value.g, duration, start.g, delta.g);
+        }
+        else if (!delta.b.Equal(0))
+        {
+            return TimerFunctionDic[curve](value.b, duration, start.b, delta.b);
+        }
+        else if (!delta.a.Equal(0))
+        {
+            return TimerFunctionDic[curve](value.a, duration, start.a, delta.a);
+        }
+        else
+        {
+            throw new Exception();
+        }
+    }
+
+
+    public static Shake GetShake(Transform target)
+    {
+        Shake move;
+
+        if (ShakeDic.TryGetValue(target, out move))
+        {
+            return move;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static Move2D GetMove2D(Transform target)
+    {
+        Move2D move;
+
+        if (MoveDic2D.TryGetValue(target, out move))
+        {
+            return move;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static Move3D GetMove3D(Transform target)
+    {
+        Move3D move;
+
+        if (MoveDic3D.TryGetValue(target, out move))
+        {
+            return move;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static Zoom2D GetZoom2D(Transform target)
+    {
+        Zoom2D move;
+
+        if (ZoomDic2D.TryGetValue(target, out move))
+        {
+            return move;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+
+    public static StreamScale GetStreamScale(Transform target)
+    {
+        StreamScale stream;
+
+        if (StreamScaleDic.TryGetValue(target, out stream))
+        {
+            return stream;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+
+    public static TweenSr GetTweenSr(Transform target)
+    {
+        TweenSr tween;
+
+        if (TweenSrDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenRenderer GetTweenRenderer(Renderer target)
+    {
+        TweenRenderer tween;
+
+        if (TweenRendererDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenCG GetTweenCG(Transform target)
+    {
+        TweenCG tween;
+
+        if (TweenCgDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenGra GetTweenGra(Transform target)
+    {
+        TweenGra tween;
+
+        if (TweenGraDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenVec GetTweenVec(Transform target)
+    {
+        TweenVec tween;
+
+        if (TweenVecDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenEuler GetTweenEuler(Transform target)
+    {
+        TweenEuler tween;
+
+        if (TweenEulerDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenFont GetTweenFont(Transform target)
+    {
+        TweenFont tween;
+
+        if (TweenFontDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenRect GetTweenRect(Transform target)
+    {
+        TweenRect tween;
+
+        if (TweenRectDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenScale GetTweenScale(Transform target)
+    {
+        TweenScale tween;
+
+        if (TweenScaleDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenAudio GetTweenAudio(Transform target)
+    {
+        TweenAudio tween;
+        AudioSource audioSource = target.GetComponent<AudioSource>();
+
+        if (TweenAudioDic.TryGetValue(audioSource, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenAudio GetTweenAudio(AudioSource audioSource)
+    {
+        TweenAudio tween;
+
+        if (TweenAudioDic.TryGetValue(audioSource, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenOutline GetTweenOutline(Transform target)
+    {
+        TweenOutline tween;
+
+        if (TweenOutlineDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenNumber GetTweenNumber(Transform target)
+    {
+        TweenNumber tween;
+
+        if (TweenNumberDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenMatFloat GetTweenMatFloat(MaterialUnit target)
+    {
+        TweenMatFloat tween;
+
+        if (TweenMatFloatDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenMatColor GetTweenMatColor(MaterialUnit target)
+    {
+        TweenMatColor tween;
+
+        if (TweenMatColorDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    public static TweenGrayMesh GetTweenGrayMesh(MeshFilter target)
+    {
+        TweenGrayMesh tween;
+
+        if (TweenGrayMeshDic.TryGetValue(target, out tween))
+        {
+            return tween;
+        }
+        else
+        {
+            return null;
+        }
+    }
+
+    #endregion
+
+    #region 创建动画
+
+    public static Shake CreateShake(Transform target)
+    {
+        if (ShakeDic.ContainsKey(target))
+        {
+            Shake shake = ShakeDic[target];
+
+            shake.Pause();
+
+            ShakeDic[target] = new Shake(target);
+
+            return ShakeDic[target];
+        }
+        else
+        {
+            Shake shake = new Shake(target);
+
+            ShakeDic.Add(target, shake);
+
+            return shake;
+        }
+    }
+
+    public static Move2D CreateMove2D(Transform target)
+    {
+        if (MoveDic2D.ContainsKey(target))
+        {
+            Move2D move2D = MoveDic2D[target];
+
+            move2D.Pause();
+
+            MoveDic2D[target] = new Move2D(target);
+
+            return MoveDic2D[target];
+        }
+        else
+        {
+            Move2D move2D = new Move2D(target);
+
+            MoveDic2D.Add(target, move2D);
+
+            return move2D;
+        }
+    }
+
+    public static Move3D CreateMove3D(Transform target)
+    {
+        if (MoveDic3D.ContainsKey(target))
+        {
+            Move3D move3D = MoveDic3D[target];
+
+            move3D.Pause();
+
+            MoveDic3D[target] = new Move3D(target);
+
+            return MoveDic3D[target];
+        }
+        else
+        {
+            Move3D move3D = new Move3D(target);
+
+            MoveDic3D.Add(target, move3D);
+
+            return move3D;
+        }
+    }
+
+    public static Zoom2D CreateZoom2D(Transform target)
+    {
+        if (ZoomDic2D.ContainsKey(target))
+        {
+            Zoom2D zoom2D = ZoomDic2D[target];
+
+            zoom2D.Pause();
+
+            ZoomDic2D[target] = new Zoom2D(target.GetComponent<Camera>());
+
+            return ZoomDic2D[target];
+        }
+        else
+        {
+            Zoom2D zoom2D = new Zoom2D(target.GetComponent<Camera>());
+
+            ZoomDic2D.Add(target, zoom2D);
+
+            return zoom2D;
+        }
+    }
+
+
+    public static StreamScale CreateStreamScale(Transform target, List<float> delayList, List<float> durationList, List<VecPair> destKvList, bool originActive, bool destActive, Curve curve, bool cg = false, List<UnityAction> startActionList = null, List<UnityAction> finishActionList = null)
+    {
+        StreamScale streamScale;
+
+        if (StreamScaleDic.ContainsKey(target))
+        {
+            streamScale = StreamScaleDic[target];
+
+            streamScale.Pause();
+
+            StreamScaleDic[target] = new StreamScale(target, delayList, durationList, destKvList, originActive, destActive, curve, cg, startActionList, finishActionList);
+
+            return StreamScaleDic[target];
+        }
+        else
+        {
+            streamScale = new StreamScale(target, delayList, durationList, destKvList, originActive, destActive, curve, cg, startActionList, finishActionList);
+
+            StreamScaleDic.Add(target, streamScale);
+
+            return streamScale;
+        }
+    }
+
+    public static StreamScale CreateStreamScale(Transform target, List<float> delayList, List<float> durationList, List<Vector3> destList, bool originActive, bool destActive, Curve curve, bool cg = false, List<UnityAction> startActionList = null, List<UnityAction> finishActionList = null)
+    {
+        StreamScale streamScale;
+
+        if (StreamScaleDic.ContainsKey(target))
+        {
+            streamScale = StreamScaleDic[target];
+
+            streamScale.Pause();
+
+            StreamScaleDic[target] = new StreamScale(target, delayList, durationList, destList, originActive, destActive, curve, cg, startActionList, finishActionList);
+
+            return StreamScaleDic[target];
+        }
+        else
+        {
+            streamScale = new StreamScale(target, delayList, durationList, destList, originActive, destActive, curve, cg, startActionList, finishActionList);
+
+            StreamScaleDic.Add(target, streamScale);
+
+            return streamScale;
+        }
+    }
+
+
+    public static TweenSr CreateTweenSr(Transform target, float originAlpha, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
+    {
+        TweenSr tweenSr;
+        SpriteRenderer sr = target.GetComponent<SpriteRenderer>();
+
+        Color origin = sr.color;
+        Color destination = sr.color;
+
+        origin.a = originAlpha;
+        destination.a = destAlpha;
+
+        if (TweenSrDic.ContainsKey(target))
+        {
+            tweenSr = TweenSrDic[target];
+
+            tweenSr.Pause();
+
+            TweenSrDic[target] = new TweenSr(sr, origin, destination, duration, originActive, destActive, curve, cg, group);
+
+            return TweenSrDic[target];
+        }
+        else
+        {
+            tweenSr = new TweenSr(sr, origin, destination, duration, originActive, destActive, curve, cg, group);
+
+            TweenSrDic.Add(target, tweenSr);
+
+            return tweenSr;
+        }
+    }
+
+    public static TweenSr CreateTweenSr(Transform target, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
+    {
+        TweenSr tweenSr;
+        SpriteRenderer sr = target.GetComponent<SpriteRenderer>();
+
+        Color destination = sr.color;
+
+        destination.a = destAlpha;
+
+        if (TweenSrDic.ContainsKey(target))
+        {
+            tweenSr = TweenSrDic[target];
+
+            tweenSr.Pause();
+
+            TweenSrDic[target] = new TweenSr(sr, sr.color, destination, duration, originActive, destActive, curve, cg, group);
+
+            return TweenSrDic[target];
+        }
+        else
+        {
+            tweenSr = new TweenSr(sr, sr.color, destination, duration, originActive, destActive, curve, cg, group);
+
+            TweenSrDic.Add(target, tweenSr);
+
+            return tweenSr;
+        }
+    }
+
+    public static TweenSr CreateTweenSr(Transform target, Color origin, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
+    {
+        TweenSr tweenSr;
+        SpriteRenderer sr = target.GetComponent<SpriteRenderer>();
+
+        if (TweenSrDic.ContainsKey(target))
+        {
+            tweenSr = TweenSrDic[target];
+
+            tweenSr.Pause();
+
+            TweenSrDic[target] = new TweenSr(sr, origin, destination, duration, originActive, destActive, curve, cg, group);
+
+            return TweenSrDic[target];
+        }
+        else
+        {
+            tweenSr = new TweenSr(sr, origin, destination, duration, originActive, destActive, curve, cg, group);
+
+            TweenSrDic.Add(target, tweenSr);
+
+            return tweenSr;
+        }
+    }
+
+    public static TweenSr CreateTweenSr(Transform target, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
+    {
+        TweenSr tweenSr;
+        SpriteRenderer sr = target.GetComponent<SpriteRenderer>();
+
+        if (TweenSrDic.ContainsKey(target))
+        {
+            tweenSr = TweenSrDic[target];
+
+            tweenSr.Pause();
+
+            TweenSrDic[target] = new TweenSr(sr, sr.color, destination, duration, originActive, destActive, curve, cg, group);
+
+            return TweenSrDic[target];
+        }
+        else
+        {
+            tweenSr = new TweenSr(sr, sr.color, destination, duration, originActive, destActive, curve, cg, group);
+
+            TweenSrDic.Add(target, tweenSr);
+
+            return tweenSr;
+        }
+    }
+
+
+    public static TweenRenderer CreateTweenRenderer(Renderer target, float originAlpha, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
+    {
+        TweenRenderer tweenSr;
+        Color origin = target.sharedMaterial.GetColor("_Color");
+        Color destination = target.sharedMaterial.GetColor("_Color");
+
+        origin.a = originAlpha;
+        destination.a = destAlpha;
+
+        if (TweenRendererDic.ContainsKey(target))
+        {
+            tweenSr = TweenRendererDic[target];
+
+            tweenSr.Pause();
+
+            TweenRendererDic[target] = new TweenRenderer(target, origin, destination, duration, originActive, destActive, curve, cg, group);
+            tweenSr.AlphaOnly = true;
+            return TweenRendererDic[target];
+        }
+        else
+        {
+            tweenSr = new TweenRenderer(target, origin, destination, duration, originActive, destActive, curve, cg, group);
+
+            TweenRendererDic.Add(target, tweenSr);
+            tweenSr.AlphaOnly = true;
+            return tweenSr;
+        }
+    }
+
+    public static TweenRenderer CreateTweenRenderer(Renderer target, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
+    {
+        TweenRenderer tweenSr;
+        Renderer sr = target.GetComponent<Renderer>();
+
+        Color destination = sr.material.GetColor("_Color");
+
+        destination.a = destAlpha;
+
+        if (TweenRendererDic.ContainsKey(target))
+        {
+            tweenSr = TweenRendererDic[target];
+
+            tweenSr.Pause();
+
+            TweenRendererDic[target] = new TweenRenderer(sr, sr.material.GetColor("_Color"), destination, duration, originActive, destActive, curve, cg, group);
+
+            return TweenRendererDic[target];
+        }
+        else
+        {
+            tweenSr = new TweenRenderer(sr, sr.material.GetColor("_Color"), destination, duration, originActive, destActive, curve, cg, group);
+
+            TweenRendererDic.Add(target, tweenSr);
+
+            return tweenSr;
+        }
+    }
+
+    public static TweenRenderer CreateTweenRenderer(Renderer target, Color origin, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
+    {
+        TweenRenderer tweenSr;
+        Renderer sr = target.GetComponent<Renderer>();
+
+        if (TweenRendererDic.ContainsKey(target))
+        {
+            tweenSr = TweenRendererDic[target];
+
+            tweenSr.Pause();
+
+            TweenRendererDic[target] = new TweenRenderer(sr, origin, destination, duration, originActive, destActive, curve, cg, group);
+
+            return TweenRendererDic[target];
+        }
+        else
+        {
+            tweenSr = new TweenRenderer(sr, origin, destination, duration, originActive, destActive, curve, cg, group);
+
+            TweenRendererDic.Add(target, tweenSr);
+
+            return tweenSr;
+        }
+    }
+
+    public static TweenRenderer CreateTweenRenderer(Renderer target, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false, bool group = false)
+    {
+        TweenRenderer tweenSr;
+        Renderer sr = target.GetComponent<Renderer>();
+
+        if (TweenRendererDic.ContainsKey(target))
+        {
+            tweenSr = TweenRendererDic[target];
+
+            tweenSr.Pause();
+
+            TweenRendererDic[target] = new TweenRenderer(sr, sr.material.GetColor("_Color"), destination, duration, originActive, destActive, curve, cg, group);
+
+            return TweenRendererDic[target];
+        }
+        else
+        {
+            tweenSr = new TweenRenderer(sr, sr.material.GetColor("_Color"), destination, duration, originActive, destActive, curve, cg, group);
+
+            TweenRendererDic.Add(target, tweenSr);
+
+            return tweenSr;
+        }
+    }
+
+
+    public static TweenCG CreateTweenCG(Transform target, float origin, float destination, float duration, bool originActive, bool destActive, Curve curve)
+    {
+        TweenCG tweenCg;
+        CanvasGroup cg = target.GetComponent<CanvasGroup>();
+
+        if (TweenCgDic.ContainsKey(target))
+        {
+            tweenCg = TweenCgDic[target];
+
+            tweenCg.Pause();
+
+            TweenCgDic[target] = new TweenCG(cg, origin, destination, duration, originActive, destActive, curve);
+
+            return TweenCgDic[target];
+        }
+        else
+        {
+            tweenCg = new TweenCG(cg, origin, destination, duration, originActive, destActive, curve);
+
+            TweenCgDic.Add(target, tweenCg);
+
+            return tweenCg;
+        }
+    }
+
+    public static TweenCG CreateTweenCG(Transform target, float destination, float duration, bool originActive, bool destActive, Curve curve)
+    {
+        TweenCG tweenCg;
+        CanvasGroup cg = target.GetComponent<CanvasGroup>();
+
+        if (TweenCgDic.ContainsKey(target))
+        {
+            tweenCg = TweenCgDic[target];
+
+            tweenCg.Pause();
+
+            TweenCgDic[target] = new TweenCG(cg, cg.alpha, destination, duration, originActive, destActive, curve);
+
+            return TweenCgDic[target];
+        }
+        else
+        {
+            tweenCg = new TweenCG(cg, cg.alpha, destination, duration, originActive, destActive, curve);
+
+            TweenCgDic.Add(target, tweenCg);
+
+            return tweenCg;
+        }
+    }
+
+
+    public static TweenGra CreateTweenGra(Transform target, float originAlpha, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Graphic graphic = target.GetComponent<Graphic>();
+        TweenGra tweenGra;
+
+        Color origin = graphic.color;
+        Color destination = graphic.color;
+
+        origin.a = originAlpha;
+        destination.a = destAlpha;
+
+        if (TweenGraDic.ContainsKey(target))
+        {
+            tweenGra = TweenGraDic[target];
+
+            tweenGra.Pause();
+
+            TweenGraDic[target] = new TweenGra(graphic, origin, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenGraDic[target];
+        }
+        else
+        {
+            tweenGra = new TweenGra(graphic, origin, destination, duration, originActive, destActive, curve, cg);
+
+            TweenGraDic.Add(target, tweenGra);
+
+            return tweenGra;
+        }
+    }
+
+    public static TweenGra CreateTweenGra(Transform target, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Graphic graphic = target.GetComponent<Graphic>();
+        TweenGra tweenGra;
+
+        Color destination = graphic.color;
+
+        destination.a = destAlpha;
+
+        if (TweenGraDic.ContainsKey(target))
+        {
+            tweenGra = TweenGraDic[target];
+
+            tweenGra.Pause();
+
+            TweenGraDic[target] = new TweenGra(graphic, graphic.color, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenGraDic[target];
+        }
+        else
+        {
+            tweenGra = new TweenGra(graphic, graphic.color, destination, duration, originActive, destActive, curve, cg);
+
+            TweenGraDic.Add(target, tweenGra);
+
+            return tweenGra;
+        }
+    }
+
+    public static TweenGra CreateTweenGra(Transform target, Color origin, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Graphic graphic = target.GetComponent<Graphic>();
+        TweenGra tweenGra;
+
+        if (TweenGraDic.ContainsKey(target))
+        {
+            tweenGra = TweenGraDic[target];
+
+            tweenGra.Pause();
+
+            TweenGraDic[target] = new TweenGra(graphic, origin, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenGraDic[target];
+        }
+        else
+        {
+            tweenGra = new TweenGra(graphic, origin, destination, duration, originActive, destActive, curve, cg);
+
+            TweenGraDic.Add(target, tweenGra);
+
+            return tweenGra;
+        }
+    }
+
+    public static TweenGra CreateTweenGra(Transform target, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Graphic graphic = target.GetComponent<Graphic>();
+        TweenGra tweenGra;
+
+        if (TweenGraDic.ContainsKey(target))
+        {
+            tweenGra = TweenGraDic[target];
+
+            tweenGra.Pause();
+
+            TweenGraDic[target] = new TweenGra(graphic, graphic.color, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenGraDic[target];
+        }
+        else
+        {
+            tweenGra = new TweenGra(graphic, graphic.color, destination, duration, originActive, destActive, curve, cg);
+
+            TweenGraDic.Add(target, tweenGra);
+
+            return tweenGra;
+        }
+    }
+
+
+    public static TweenVec CreateTweenVec2D(Transform target, Vector3 origin, Vector3 destination, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenVec tweenVec2D;
+
+        if (local)
+        {
+            origin.z = target.localPosition.z;
+            destination.z = target.localPosition.z;
+        }
+        else
+        {
+            origin.z = target.position.z;
+            destination.z = target.position.z;
+        }
+
+        if (TweenVecDic.ContainsKey(target))
+        {
+            tweenVec2D = TweenVecDic[target];
+
+            tweenVec2D.Pause();
+
+            TweenVecDic[target] = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            return TweenVecDic[target];
+        }
+        else
+        {
+            tweenVec2D = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            TweenVecDic.Add(target, tweenVec2D);
+
+            return tweenVec2D;
+        }
+    }
+
+    public static TweenVec CreateTweenVec2D(Transform target, Vector3 destination, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenVec tweenVec2D;
+
+        Vector3 origin;
+
+        if (local)
+        {
+            origin = target.localPosition;
+
+            destination.z = target.localPosition.z;
+        }
+        else
+        {
+            origin = target.position;
+
+            destination.z = target.position.z;
+        }
+
+
+        if (TweenVecDic.ContainsKey(target))
+        {
+            tweenVec2D = TweenVecDic[target];
+
+            tweenVec2D.Pause();
+
+            TweenVecDic[target] = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            return TweenVecDic[target];
+        }
+        else
+        {
+            tweenVec2D = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            TweenVecDic.Add(target, tweenVec2D);
+
+            return tweenVec2D;
+        }
+    }
+
+    public static TweenVec CreateTweenVecOffset2D(Transform target, Vector3 offset, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenVec tweenVec2D;
+
+        Vector3 origin;
+        Vector3 destination;
+
+        if (local)
+        {
+            origin = target.localPosition;
+            destination = target.localPosition + offset;
+
+            destination.z = target.localPosition.z;
+        }
+        else
+        {
+            origin = target.position;
+            destination = target.position + offset;
+
+            destination.z = target.position.z;
+        }
+
+        if (TweenVecDic.ContainsKey(target))
+        {
+            tweenVec2D = TweenVecDic[target];
+
+            tweenVec2D.Pause();
+
+            TweenVecDic[target] = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            return TweenVecDic[target];
+        }
+        else
+        {
+            tweenVec2D = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            TweenVecDic.Add(target, tweenVec2D);
+
+            return tweenVec2D;
+        }
+    }
+
+
+    public static TweenVec CreateTweenVec3D(Transform target, Vector3 origin, Vector3 destination, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenVec tweenVec3D;
+
+        if (TweenVecDic.ContainsKey(target))
+        {
+            tweenVec3D = TweenVecDic[target];
+
+            tweenVec3D.Pause();
+
+            TweenVecDic[target] = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            return TweenVecDic[target];
+        }
+        else
+        {
+            tweenVec3D = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            TweenVecDic.Add(target, tweenVec3D);
+
+            return tweenVec3D;
+        }
+    }
+
+    public static TweenVec CreateTweenVec3D(Transform target, Vector3 destination, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenVec tweenVec3D;
+
+        Vector3 origin;
+
+        if (local)
+        {
+            origin = target.localPosition;
+        }
+        else
+        {
+            origin = target.position;
+        }
+
+        if (TweenVecDic.ContainsKey(target))
+        {
+            tweenVec3D = TweenVecDic[target];
+
+            tweenVec3D.Pause();
+
+            TweenVecDic[target] = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            return TweenVecDic[target];
+        }
+        else
+        {
+            tweenVec3D = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            TweenVecDic.Add(target, tweenVec3D);
+
+            return tweenVec3D;
+        }
+    }
+
+    public static TweenVec CreateTweenVecOffset3D(Transform target, Vector3 offset, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenVec tweenVec3D;
+
+        Vector3 origin;
+        Vector3 destination;
+
+        if (local)
+        {
+            origin = target.localPosition;
+            destination = target.localPosition + offset;
+        }
+        else
+        {
+            origin = target.position;
+            destination = target.position + offset;
+        }
+
+        if (TweenVecDic.ContainsKey(target))
+        {
+            tweenVec3D = TweenVecDic[target];
+
+            tweenVec3D.Pause();
+
+            TweenVecDic[target] = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            return TweenVecDic[target];
+        }
+        else
+        {
+            tweenVec3D = new TweenVec(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            TweenVecDic.Add(target, tweenVec3D);
+
+            return tweenVec3D;
+        }
+    }
+
+
+    public static TweenEuler CreateTweenEuler(Transform target, Vector3 origin, Vector3 destination, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenEuler tweenEuler;
+
+        if (TweenEulerDic.ContainsKey(target))
+        {
+            tweenEuler = TweenEulerDic[target];
+
+            tweenEuler.Pause();
+
+            TweenEulerDic[target] = new TweenEuler(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            return TweenEulerDic[target];
+        }
+        else
+        {
+            tweenEuler = new TweenEuler(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            TweenEulerDic.Add(target, tweenEuler);
+
+            return tweenEuler;
+        }
+    }
+
+    public static TweenEuler CreateTweenEuler(Transform target, Vector3 destination, float duration, bool local, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenEuler tweenEuler;
+
+        Vector3 origin;
+
+        if (local)
+        {
+            origin = target.localEulerAngles;
+        }
+        else
+        {
+            origin = target.eulerAngles;
+        }
+
+        if (TweenEulerDic.ContainsKey(target))
+        {
+            tweenEuler = TweenEulerDic[target];
+
+            tweenEuler.Pause();
+
+            TweenEulerDic[target] = new TweenEuler(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            return TweenEulerDic[target];
+        }
+        else
+        {
+            tweenEuler = new TweenEuler(target, origin, destination, duration, local, originActive, destActive, curve, cg);
+
+            TweenEulerDic.Add(target, tweenEuler);
+
+            return tweenEuler;
+        }
+    }
+
+
+    public static TweenFont CreateTweenFont(Transform target, int origin, int destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Text text = target.GetComponent<Text>();
+        TweenFont tweenFont;
+
+        if (TweenRectDic.ContainsKey(target))
+        {
+            tweenFont = TweenFontDic[target];
+
+            tweenFont.Pause();
+
+            TweenFontDic[target] = new TweenFont(text, origin, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenFontDic[target];
+        }
+        else
+        {
+            tweenFont = new TweenFont(text, origin, destination, duration, originActive, destActive, curve, cg);
+
+            TweenFontDic.Add(target, tweenFont);
+
+            return tweenFont;
+        }
+    }
+
+    public static TweenFont CreateTweenFont(Transform target, int destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Text text = target.GetComponent<Text>();
+        TweenFont tweenFont;
+
+        if (TweenRectDic.ContainsKey(target))
+        {
+            tweenFont = TweenFontDic[target];
+
+            tweenFont.Pause();
+
+            TweenFontDic[target] = new TweenFont(text, text.fontSize, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenFontDic[target];
+        }
+        else
+        {
+            tweenFont = new TweenFont(text, text.fontSize, destination, duration, originActive, destActive, curve, cg);
+
+            TweenFontDic.Add(target, tweenFont);
+
+            return tweenFont;
+        }
+    }
+
+
+    public static TweenRect CreateTweenRect(Transform target, Vector2 origin, Vector2 destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenRect tweenRect;
+        RectTransform rectTra = target.GetComponent<RectTransform>();
+
+        if (TweenRectDic.ContainsKey(target))
+        {
+            tweenRect = TweenRectDic[target];
+
+            tweenRect.Pause();
+
+            TweenRectDic[target] = new TweenRect(rectTra, origin, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenRectDic[target];
+        }
+        else
+        {
+            tweenRect = new TweenRect(rectTra, origin, destination, duration, originActive, destActive, curve, cg);
+
+            TweenRectDic.Add(target, tweenRect);
+
+            return tweenRect;
+        }
+    }
+
+    public static TweenRect CreateTweenRect(Transform target, Vector2 destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenRect tweenRect;
+        RectTransform rectTra = target.GetComponent<RectTransform>();
+
+        if (TweenRectDic.ContainsKey(target))
+        {
+            tweenRect = TweenRectDic[target];
+
+            tweenRect.Pause();
+
+            TweenRectDic[target] = new TweenRect(rectTra, rectTra.rect.size, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenRectDic[target];
+        }
+        else
+        {
+            tweenRect = new TweenRect(rectTra, rectTra.rect.size, destination, duration, originActive, destActive, curve, cg);
+
+            TweenRectDic.Add(target, tweenRect);
+
+            return tweenRect;
+        }
+    }
+
+
+    public static TweenScale CreateTweenScale(Transform target, float origin, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Vector3 destScale = new Vector3(destination, destination, destination);
+        Vector3 originScale = new Vector3(origin, origin, origin);
+
+
+        TweenScale tweenScale;
+
+        if (TweenScaleDic.ContainsKey(target))
+        {
+            tweenScale = TweenScaleDic[target];
+
+            tweenScale.Pause();
+
+            TweenScaleDic[target] = new TweenScale(target, originScale, destScale, duration, originActive, destActive, curve, cg);
+
+            return TweenScaleDic[target];
+        }
+        else
+        {
+            tweenScale = new TweenScale(target, originScale, destScale, duration, originActive, destActive, curve, cg);
+
+            TweenScaleDic.Add(target, tweenScale);
+
+            return tweenScale;
+        }
+    }
+
+    public static TweenScale CreateTweenScale(Transform target, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Vector3 destScale = new Vector3(destination, destination, destination);
+
+
+        TweenScale tweenScale;
+
+        if (TweenScaleDic.ContainsKey(target))
+        {
+            tweenScale = TweenScaleDic[target];
+
+            tweenScale.Pause();
+
+            TweenScaleDic[target] = new TweenScale(target, target.localScale, destScale, duration, originActive, destActive, curve, cg);
+
+            return TweenScaleDic[target];
+        }
+        else
+        {
+            tweenScale = new TweenScale(target, target.localScale, destScale, duration, originActive, destActive, curve, cg);
+
+            TweenScaleDic.Add(target, tweenScale);
+
+            return tweenScale;
+        }
+    }
+
+    public static TweenScale CreateTweenScale(Transform target, Vector3 origin, Vector3 destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenScale tweenScale;
+
+        if (TweenScaleDic.ContainsKey(target))
+        {
+            tweenScale = TweenScaleDic[target];
+
+            tweenScale.Pause();
+
+            TweenScaleDic[target] = new TweenScale(target, origin, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenScaleDic[target];
+        }
+        else
+        {
+            tweenScale = new TweenScale(target, origin, destination, duration, originActive, destActive, curve, cg);
+
+            TweenScaleDic.Add(target, tweenScale);
+
+            return tweenScale;
+        }
+    }
+
+    public static TweenScale CreateTweenScale(Transform target, Vector3 destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenScale tweenScale;
+
+        if (TweenScaleDic.ContainsKey(target))
+        {
+            tweenScale = TweenScaleDic[target];
+
+            tweenScale.Pause();
+
+            TweenScaleDic[target] = new TweenScale(target, target.localScale, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenScaleDic[target];
+        }
+        else
+        {
+            tweenScale = new TweenScale(target, target.localScale, destination, duration, originActive, destActive, curve, cg);
+
+            TweenScaleDic.Add(target, tweenScale);
+
+            return tweenScale;
+        }
+    }
+
+
+    public static TweenAudio CreateTweenAudio(Transform target, float origin, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenAudio tweenAudio;
+        AudioSource audio = target.GetComponent<AudioSource>();
+
+        if (TweenAudioDic.ContainsKey(audio))
+        {
+            tweenAudio = TweenAudioDic[audio];
+
+            tweenAudio.Pause();
+
+            TweenAudioDic[audio] = new TweenAudio(audio, origin, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenAudioDic[audio];
+        }
+        else
+        {
+            tweenAudio = new TweenAudio(audio, origin, destination, duration, originActive, destActive, curve, cg);
+
+            TweenAudioDic.Add(audio, tweenAudio);
+
+            return tweenAudio;
+        }
+    }
+
+    public static TweenAudio CreateTweenAudio(Transform target, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenAudio tweenAudio;
+        AudioSource audio = target.GetComponent<AudioSource>();
+
+        if (TweenAudioDic.ContainsKey(audio))
+        {
+            tweenAudio = TweenAudioDic[audio];
+
+            tweenAudio.Pause();
+
+            TweenAudioDic[audio] = new TweenAudio(audio, audio.volume, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenAudioDic[audio];
+        }
+        else
+        {
+            tweenAudio = new TweenAudio(audio, audio.volume, destination, duration, originActive, destActive, curve, cg);
+
+            TweenAudioDic.Add(audio, tweenAudio);
+
+            return tweenAudio;
+        }
+    }
+
+    public static TweenAudio CreateTweenAudio(AudioSource audioSource, float origin, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenAudio tweenAudio;
+
+        if (TweenAudioDic.ContainsKey(audioSource))
+        {
+            tweenAudio = TweenAudioDic[audioSource];
+
+            tweenAudio.Pause();
+
+            TweenAudioDic[audioSource] = new TweenAudio(audioSource, origin, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenAudioDic[audioSource];
+        }
+        else
+        {
+            tweenAudio = new TweenAudio(audioSource, origin, destination, duration, originActive, destActive, curve, cg);
+
+            TweenAudioDic.Add(audioSource, tweenAudio);
+
+            return tweenAudio;
+        }
+    }
+
+    public static TweenAudio CreateTweenAudio(AudioSource audioSource, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenAudio tweenAudio;
+
+        if (TweenAudioDic.ContainsKey(audioSource))
+        {
+            tweenAudio = TweenAudioDic[audioSource];
+
+            tweenAudio.Pause();
+
+            TweenAudioDic[audioSource] = new TweenAudio(audioSource, audioSource.volume, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenAudioDic[audioSource];
+        }
+        else
+        {
+            tweenAudio = new TweenAudio(audioSource, audioSource.volume, destination, duration, originActive, destActive, curve, cg);
+            
+            TweenAudioDic.Add(audioSource, tweenAudio);
+
+            return tweenAudio;
+        }
+    }
+
+
+    public static TweenOutline CreateTweenOutline(Transform target, float originAlpha, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Outline outline = target.GetComponent<Outline>();
+        TweenOutline tweenOutline;
+
+        Color origin = outline.effectColor;
+        Color destination = outline.effectColor;
+
+        origin.a = originAlpha;
+        destination.a = destAlpha;
+
+        if (TweenOutlineDic.ContainsKey(target))
+        {
+            tweenOutline = TweenOutlineDic[target];
+
+            tweenOutline.Pause();
+
+            TweenOutlineDic[target] = new TweenOutline(outline, origin, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenOutlineDic[target];
+        }
+        else
+        {
+            tweenOutline = new TweenOutline(outline, origin, destination, duration, originActive, destActive, curve, cg);
+
+            TweenOutlineDic.Add(target, tweenOutline);
+
+            return tweenOutline;
+        }
+    }
+
+    public static TweenOutline CreateTweenOutline(Transform target, float destAlpha, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Outline graphic = target.GetComponent<Outline>();
+        TweenOutline tweenOutline;
+
+        Color destination = graphic.effectColor;
+
+        destination.a = destAlpha;
+
+        if (TweenOutlineDic.ContainsKey(target))
+        {
+            tweenOutline = TweenOutlineDic[target];
+
+            tweenOutline.Pause();
+
+            TweenOutlineDic[target] = new TweenOutline(graphic, graphic.effectColor, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenOutlineDic[target];
+        }
+        else
+        {
+            tweenOutline = new TweenOutline(graphic, graphic.effectColor, destination, duration, originActive, destActive, curve, cg);
+
+            TweenOutlineDic.Add(target, tweenOutline);
+
+            return tweenOutline;
+        }
+    }
+
+    public static TweenOutline CreateTweenOutline(Transform target, Color origin, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Outline outline = target.GetComponent<Outline>();
+        TweenOutline tweenOutline;
+
+        if (TweenOutlineDic.ContainsKey(target))
+        {
+            tweenOutline = TweenOutlineDic[target];
+
+            tweenOutline.Pause();
+
+            TweenOutlineDic[target] = new TweenOutline(outline, origin, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenOutlineDic[target];
+        }
+        else
+        {
+            tweenOutline = new TweenOutline(outline, origin, destination, duration, originActive, destActive, curve, cg);
+
+            TweenOutlineDic.Add(target, tweenOutline);
+
+            return tweenOutline;
+        }
+    }
+
+    public static TweenOutline CreateTweenOutline(Transform target, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Outline graphic = target.GetComponent<Outline>();
+        TweenOutline tweenOutline;
+
+        if (TweenOutlineDic.ContainsKey(target))
+        {
+            tweenOutline = TweenOutlineDic[target];
+
+            tweenOutline.Pause();
+
+            TweenOutlineDic[target] = new TweenOutline(graphic, graphic.effectColor, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenOutlineDic[target];
+        }
+        else
+        {
+            tweenOutline = new TweenOutline(graphic, graphic.effectColor, destination, duration, originActive, destActive, curve, cg);
+
+            TweenOutlineDic.Add(target, tweenOutline);
+
+            return tweenOutline;
+        }
+    }
+
+
+    public static TweenNumber CreateTweenNumber(Transform target, int origin, int destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Text text = target.GetComponent<Text>();
+        TweenNumber tweenNumber;
+
+        if (TweenNumberDic.ContainsKey(target))
+        {
+            tweenNumber = TweenNumberDic[target];
+
+            tweenNumber.Pause();
+
+            TweenNumberDic[target] = new TweenNumber(text, origin, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenNumberDic[target];
+        }
+        else
+        {
+            tweenNumber = new TweenNumber(text, origin, destination, duration, originActive, destActive, curve, cg);
+
+            TweenNumberDic.Add(target, tweenNumber);
+
+            return tweenNumber;
+        }
+    }
+
+    public static TweenNumber CreateTweenNumber(Transform target, int destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        Text text = target.GetComponent<Text>();
+        TweenNumber tweenNumber;
+
+        if (TweenNumberDic.ContainsKey(target))
+        {
+            tweenNumber = TweenNumberDic[target];
+
+            tweenNumber.Pause();
+
+            TweenNumberDic[target] = new TweenNumber(text, int.Parse(text.text), destination, duration, originActive, destActive, curve, cg);
+
+            return TweenNumberDic[target];
+        }
+        else
+        {
+            tweenNumber = new TweenNumber(text, int.Parse(text.text), destination, duration, originActive, destActive, curve, cg);
+
+            TweenNumberDic.Add(target, tweenNumber);
+
+            return tweenNumber;
+        }
+    }
+
+
+    public static TweenMatColor CreateTweenMatColor(MaterialUnit target, Color origin, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenMatColor tweenMatColor;
+
+        if (TweenMatColorDic.ContainsKey(target))
+        {
+            tweenMatColor = TweenMatColorDic[target];
+
+            tweenMatColor.Pause();
+
+            TweenMatColorDic[target] = new TweenMatColor(target, origin, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenMatColorDic[target];
+        }
+        else
+        {
+            tweenMatColor = new TweenMatColor(target, origin, destination, duration, originActive, destActive, curve, cg);
+
+            TweenMatColorDic.Add(target, tweenMatColor);
+
+            return tweenMatColor;
+        }
+    }
+
+    public static TweenMatColor CreateTweenMatColor(MaterialUnit target, Color destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenMatColor tweenMatColor;
+
+        if (TweenMatColorDic.ContainsKey(target))
+        {
+            tweenMatColor = TweenMatColorDic[target];
+
+            tweenMatColor.Pause();
+
+            TweenMatColorDic[target] = new TweenMatColor(target, target.GetColor(), destination, duration, originActive, destActive, curve, cg);
+
+            return TweenMatColorDic[target];
+        }
+        else
+        {
+            tweenMatColor = new TweenMatColor(target, target.GetColor(), destination, duration, originActive, destActive, curve, cg);
+
+            TweenMatColorDic.Add(target, tweenMatColor);
+
+            return tweenMatColor;
+        }
+    }
+
+    public static TweenMatFloat CreateTweenMatFloat(MaterialUnit target, float origin, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenMatFloat tweenMatFloat;
+
+        if (TweenMatFloatDic.ContainsKey(target))
+        {
+            tweenMatFloat = TweenMatFloatDic[target];
+
+            tweenMatFloat.Pause();
+
+            TweenMatFloatDic[target] = new TweenMatFloat(target, origin, destination, duration, originActive, destActive, curve, cg);
+
+            return TweenMatFloatDic[target];
+        }
+        else
+        {
+            tweenMatFloat = new TweenMatFloat(target, origin, destination, duration, originActive, destActive, curve, cg);
+
+            TweenMatFloatDic.Add(target, tweenMatFloat);
+
+            return tweenMatFloat;
+        }
+    }
+
+    public static TweenMatFloat CreateTweenMatFloat(MaterialUnit target, float destination, float duration, bool originActive, bool destActive, Curve curve, bool cg = false)
+    {
+        TweenMatFloat tweenMatFloat;
+
+        if (TweenMatFloatDic.ContainsKey(target))
+        {
+            tweenMatFloat = TweenMatFloatDic[target];
+
+            tweenMatFloat.Pause();
+
+            TweenMatFloatDic[target] = new TweenMatFloat(target, target.GetFloat(), destination, duration, originActive, destActive, curve, cg);
+
+            return TweenMatFloatDic[target];
+        }
+        else
+        {
+            tweenMatFloat = new TweenMatFloat(target, target.GetFloat(), destination, duration, originActive, destActive, curve, cg);
+
+            TweenMatFloatDic.Add(target, tweenMatFloat);
+
+            return tweenMatFloat;
+        }
+    }
+
+
+    public static TweenGrayMesh CreateTweenGrayMesh(MeshFilter target, float origin, float destination, float duration, bool originActive, bool destActive, Curve curve)
+    {
+        TweenGrayMesh tweenGrayMesh;
+
+        if (TweenGrayMeshDic.ContainsKey(target))
+        {
+            tweenGrayMesh = TweenGrayMeshDic[target];
+
+            tweenGrayMesh.Pause();
+
+            TweenGrayMeshDic[target] = new TweenGrayMesh(target, origin, destination, duration, originActive, destActive, curve);
+
+            return TweenGrayMeshDic[target];
+        }
+        else
+        {
+            tweenGrayMesh = new TweenGrayMesh(target, origin, destination, duration, originActive, destActive, curve);
+
+            TweenGrayMeshDic.Add(target, tweenGrayMesh);
+
+            return tweenGrayMesh;
+        }
+    }
+
+    #endregion
 }

+ 128 - 21
Assets/Script/Manage/ConfigManager.cs

@@ -104,16 +104,27 @@ public class ConfigManager : Regist
             }
             catch (Exception)
             {
-                Debug.LogWarning("Download Archive : MD5 doesn't match");
-                //ManaDebug.Log("Download Archive");
+                string cacheStr = PlayerPrefManager.GetStr(PlayerPrefManager.PLAYER_CONFIG, null);
+                if (cacheStr == null)
+                {
+                    Debug.LogWarning("Download Archive : MD5 doesn't match");
+                    //ManaDebug.Log("Download Archive");
 
-                PlayerDocumentDamageFlag = true;
-                SerialNumberRequestFlag = false;
+                    PlayerDocumentDamageFlag = true;
+                    SerialNumberRequestFlag = false;
 
-                return;
+                    return;
+                }
+                else
+                {
+                    Debug.LogWarning("Recover Archive From PlayerPref : MD5 doesn't match");
+
+                    nativeDoc.LoadXml(cacheStr);
+                }
             }
 
 
+
             TextAsset textAsset = ResourceManager.Load<TextAsset>(ResourceLabel.PlayerConfig, Folder.Default);
 
             DefaultConfigDocument.LoadXml(textAsset.text);
@@ -160,13 +171,30 @@ public class ConfigManager : Regist
 
                     if (PlayerPrefs.GetString(Lib.ConfigPrefs) != UnvalidConfigMD5 && PlayerPrefs.GetString(Lib.ConfigPrefs) != Auxiliary.ToString(md5.ComputeHash(bytes)))
                     {
-                        Debug.LogWarning("Download Archive : MD5 doesn't match");
-                        //ManaDebug.Log("Download Archive");
 
-                        PlayerDocumentDamageFlag = true;
-                        SerialNumberRequestFlag = false;
 
-                        return;
+                        string cacheStr = PlayerPrefManager.GetStr(PlayerPrefManager.PLAYER_CONFIG, null);
+                        if (cacheStr == null)
+                        {
+                            Debug.LogWarning("Download Archive : MD5 doesn't match");
+                            //ManaDebug.Log("Download Archive");
+
+                            PlayerDocumentDamageFlag = true;
+                            SerialNumberRequestFlag = false;
+
+                            return;
+                        }
+                        else
+                        {
+                            Debug.LogWarning("Recover Archive From PlayerPref : MD5 doesn't match");
+
+                            nativeDoc.LoadXml(cacheStr);
+
+                            configDocument = UpdateConfigDocument(nativeVersion, nativeDoc, DefaultConfigDocument);
+                        }
+
+
+
                     }
                     else
                     {
@@ -177,7 +205,7 @@ public class ConfigManager : Regist
                 }
                 else if (nativeVersion > defaultVersion)
                 {
-                    //configDocument = DefaultConfigDocument;
+                    configDocument = nativeDoc;
                 }
                 else
                 {
@@ -187,13 +215,29 @@ public class ConfigManager : Regist
 
                     if (PlayerPrefs.GetString(Lib.ConfigPrefs) != UnvalidConfigMD5 && PlayerPrefs.GetString(Lib.ConfigPrefs) != Auxiliary.ToString(md5.ComputeHash(bytes)))
                     {
-                        Debug.LogWarning("Download Archive : MD5 doesn't match");
-                        //ManaDebug.Log("Download Archive");
 
-                        PlayerDocumentDamageFlag = true;
-                        SerialNumberRequestFlag = false;
 
-                        return;
+
+                        string cacheStr = PlayerPrefManager.GetStr(PlayerPrefManager.PLAYER_CONFIG, null);
+                        if (cacheStr == null)
+                        {
+                            Debug.LogWarning("Download Archive : MD5 doesn't match");
+                            //ManaDebug.Log("Download Archive");
+
+                            PlayerDocumentDamageFlag = true;
+                            SerialNumberRequestFlag = false;
+
+                            return;
+                        }
+                        else
+                        {
+                            Debug.LogWarning("Recover Archive From PlayerPref : MD5 doesn't match");
+
+                            nativeDoc.LoadXml(cacheStr);
+                        }
+
+
+
                     }
 
                     configDocument = nativeDoc;
@@ -206,13 +250,34 @@ public class ConfigManager : Regist
 
             DefaultConfigDocument.LoadXml(textAsset.text);
 
-            Debug.LogWarning("Download Archive");
-            //ManaDebug.Log("Download Archive");
 
-            PlayerDocumentDamageFlag = true;
-            SerialNumberRequestFlag = false;
 
-            return;
+            string cacheStr = PlayerPrefManager.GetStr(PlayerPrefManager.PLAYER_CONFIG, null);
+            if (cacheStr == null)
+            {
+                Debug.LogWarning("Download Archive");
+                //ManaDebug.Log("Download Archive");
+
+                PlayerDocumentDamageFlag = true;
+                SerialNumberRequestFlag = false;
+
+                return;
+            }
+            else
+            {
+                Debug.LogWarning("Recover Archive From PlayerPref : file doesn't exist");
+
+                nativeDoc.LoadXml(cacheStr);
+
+                node = nativeDoc.SelectSingleNode(PlayerConfigLabel.RootNode).SelectSingleNode(PlayerConfigLabel.Version);
+
+                nativeVersion = int.Parse(node.Attributes[0].Value);
+
+                configDocument = UpdateConfigDocument(nativeVersion, nativeDoc, DefaultConfigDocument);
+            }
+
+
+
         }
     }
 
@@ -623,6 +688,8 @@ public class ConfigManager : Regist
     {
         if (Initializer.Inited)
         {
+            PlayerPrefManager.SaveStr(PlayerPrefManager.PLAYER_CONFIG, ConfigDocument.OuterXml);
+
             XmlDocument doc = new XmlDocument();
 
             doc.LoadXml(ConfigDocument.OuterXml);
@@ -1562,6 +1629,20 @@ public class ConfigManager : Regist
             ToVersion39(nativeDoc, defaultDoc);
         }
 
+        if (nativeVersion < 40)
+        {
+            Debug.LogWarning("UpdateArchive to 40");
+
+            ToVersion40(nativeDoc, defaultDoc);
+        }
+
+        if (nativeVersion < 41)
+        {
+            Debug.LogWarning("UpdateArchive to 41");
+
+            ToVersion41(nativeDoc, defaultDoc);
+        }
+
         return nativeDoc;
     }
 
@@ -2120,4 +2201,30 @@ public class ConfigManager : Regist
 
         return nativeDoc;
     }
+
+    public static XmlDocument ToVersion40(XmlDocument nativeDoc, XmlDocument defaultDoc)
+    {
+        nativeDoc.SelectSingleNode(PlayerConfigLabel.RootNode).SelectSingleNode(PlayerConfigLabel.Version).Attributes[0].Value = 40.ToString();
+
+        string persistentFolderPath = string.Format("{0}{1}HotUpdate", Application.persistentDataPath, Path.DirectorySeparatorChar);
+        if (Directory.Exists(persistentFolderPath))
+        {
+            Directory.Delete(persistentFolderPath, true);
+        }
+
+        return nativeDoc;
+    }
+
+    public static XmlDocument ToVersion41(XmlDocument nativeDoc, XmlDocument defaultDoc)
+    {
+        nativeDoc.SelectSingleNode(PlayerConfigLabel.RootNode).SelectSingleNode(PlayerConfigLabel.Version).Attributes[0].Value = 41.ToString();
+
+        string persistentFolderPath = string.Format("{0}{1}HotUpdate", Application.persistentDataPath, Path.DirectorySeparatorChar);
+        if (Directory.Exists(persistentFolderPath))
+        {
+            Directory.Delete(persistentFolderPath, true);
+        }
+
+        return nativeDoc;
+    }
 }

+ 14 - 0
Assets/Script/Manage/HttpManager.cs

@@ -1979,6 +1979,20 @@ public class HttpManager : Regist
         }
     }
 
+    public static void SendEmail(string mainAddress, string content)
+    {
+        MailMessage mailMessage = new MailMessage();
+        mailMessage.To.Add(new MailAddress(mainAddress));
+        mailMessage.From = new MailAddress(ReporterMailAccount);
+        mailMessage.Body = content;
+        mailMessage.Subject = "MyLovelyGargen backup";
+
+        SmtpClient smtpClient = new SmtpClient(SmtpHost);
+
+        smtpClient.Credentials = new MyCredentials(ReporterMailAccount, ReporterMailPassword);
+        smtpClient.SendAsync(mailMessage, "Async");
+    }
+
     public static string GetSystemInfo()
     {
         StringBuilder sb = new StringBuilder();

+ 3 - 0
Assets/Script/Manage/Initializer.cs

@@ -248,6 +248,9 @@ public class Initializer : MonoBehaviour
         gameObject.AddScript<FashionShowHomePage>();
 
         InitScriptProgress = index++.ToString();
+        gameObject.AddScript<BackupIDPanel>();
+
+        InitScriptProgress = index++.ToString();
 
         StartCoroutine(WaitToInit());
     }

+ 112 - 0
Assets/Script/Manage/Panel/BackupIDPanel.cs

@@ -0,0 +1,112 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Net.Mail;
+using System.Text;
+using UnityEngine;
+using UnityEngine.UI;
+
+public class BackupIDPanel : Regist
+{
+    public static Text panelTxt;
+    public static Transform panel;
+
+    public static Text backupTxt;
+    public static Button backupBtn;
+
+    public static Text cancelTxt;
+    public static Button cancelBtn;
+
+    public static Text confirmTxt;
+    public static Button confirmBtn;
+
+    public static Text mailTxt;
+    public static InputField mailInput;
+
+    public static Text contentTxt;
+    public static InputField contentInput;
+
+    public override void RegistReference()
+    {
+        panelTxt = ResourceManager.Get<Text>(CanvasLabel.Ld_Tit);
+        panel = ResourceManager.Get(CanvasLabel.Ld_Info);
+
+        backupTxt = ResourceManager.Get<Text>(CanvasLabel.L_BackupLab);
+        backupBtn = ResourceManager.Get<Button>(CanvasLabel.L_BackupBtn);
+
+        cancelTxt = ResourceManager.Get<Text>(CanvasLabel.Ld_CancelLab);
+        cancelBtn = ResourceManager.Get<Button>(CanvasLabel.Ld_Cancel);
+
+        confirmTxt = ResourceManager.Get<Text>(CanvasLabel.Ld_ConfirmLab);
+        confirmBtn = ResourceManager.Get<Button>(CanvasLabel.Ld_Confirm);
+
+        mailTxt = ResourceManager.Get<Text>(CanvasLabel.Ld_Placeholder0);
+        mailInput = ResourceManager.Get<InputField>(CanvasLabel.Ld_InputField0);
+
+        contentTxt = ResourceManager.Get<Text>(CanvasLabel.Ld_Placeholder);
+        contentInput = ResourceManager.Get<InputField>(CanvasLabel.Ld_InputField);
+    }
+
+    public override void ThirdInit()
+    {
+        panel.CreateTweenCG(0, 1, 0.25f, false, true, Curve.EaseOutQuad);
+
+        LanguageManager.Add(panelTxt, Language.GetStr(LanguageLabel.UI__Ld_Title));
+        LanguageManager.Add(backupTxt, Language.GetStr(LanguageLabel.UI__Ld_Title));
+        LanguageManager.Add(cancelTxt, Language.GetStr(LanguageLabel.Common__Cancel));
+        LanguageManager.Add(confirmTxt, Language.GetStr(LanguageLabel.Common__Confirm));
+
+        backupBtn.onClick.AddListener(Open);
+        cancelBtn.onClick.AddListener(OnCancelClick);
+        confirmBtn.onClick.AddListener(OnConfirmClick);
+    }
+
+    public static void Open()
+    {
+        AudioManager.PlayClip(ResourceLabel.BtnClip);
+
+        panel.TweenForCG();
+
+        mailInput.text = "";
+
+        mailTxt.text = Language.GetStr(LanguageLabel.UI__Lb_Placeholder0);
+        contentInput.text = Language.GetStr(LanguageLabel.UI__Ld_PlaceHolder).Replace("%NUM%", HttpManager.ID);
+    }
+
+    public static void Close()
+    {
+        AudioManager.PlayClip(ResourceLabel.BtnClip);
+
+        panel.TweenBacCG();
+    }
+
+    public static void OnCancelClick()
+    {
+        Close();
+    }
+
+    public static void OnConfirmClick()
+    {
+        string emailAddress = mailInput.text;
+
+        if (string.IsNullOrEmpty(emailAddress) || !emailAddress.Contains("@"))
+        {
+            Bubble.Show(null, Language.GetStr(LanguageLabel.UI__Lb_Send3));
+            return;
+        }
+
+        string content = contentInput.text;
+
+        if (string.IsNullOrEmpty(content))
+        {
+            Bubble.Show(null, Language.GetStr(LanguageLabel.UI__Lb_Send2));
+            return;
+        }
+
+        HttpManager.SendEmail(emailAddress, content);
+
+        Bubble.Show(null, Language.GetStr(LanguageLabel.UI__Lb_Send0));
+
+        Close();
+    }
+}

+ 13 - 0
Assets/Script/Manage/Panel/BackupIDPanel.cs.meta

@@ -0,0 +1,13 @@
+fileFormatVersion: 2
+guid: f689f7d46596b5c4098087446d6d8ab3
+timeCreated: 1525929445
+licenseType: Pro
+MonoImporter:
+  externalObjects: {}
+  serializedVersion: 2
+  defaultReferences: []
+  executionOrder: 0
+  icon: {instanceID: 0}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 

+ 34 - 0
Assets/Script/Manage/PhotoShopCamera.cs

@@ -0,0 +1,34 @@
+using System;
+using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+public class PhotoShopCamera : MonoBehaviour 
+{
+    public Camera shotCam;
+    public Action<Texture2D> onRenderFinish;
+
+    public void Awake()
+    {
+        shotCam = GetComponent<Camera>();
+    }
+
+    public void OnPostRender()
+    {
+        //设定当前RenderTexture为快照相机的targetTexture
+        RenderTexture rt = shotCam.targetTexture;
+        RenderTexture.active = rt;
+        Texture2D tex = new Texture2D(rt.width, rt.height);
+        
+        //读取缓冲区像素信息
+        tex.ReadPixels(new Rect(0, 0, rt.width, rt.height), 0, 0);
+        tex.Apply();
+
+        if (onRenderFinish != null)
+        {
+            onRenderFinish.Invoke(tex);
+        }
+
+        Destroy(tex);
+    }
+}

+ 13 - 0
Assets/Script/Manage/PhotoShopCamera.cs.meta

@@ -0,0 +1,13 @@
+fileFormatVersion: 2
+guid: cdc646dba158d0946b7bcd8d6c0c57c5
+timeCreated: 1525922907
+licenseType: Pro
+MonoImporter:
+  externalObjects: {}
+  serializedVersion: 2
+  defaultReferences: []
+  executionOrder: 0
+  icon: {instanceID: 0}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 

+ 12 - 0
Assets/Script/Manage/PlayerManager.cs

@@ -184,6 +184,18 @@ public class PlayerManager : Regist
                 else if (i == 4)
                 {
                     DressData[4] = "上衣-缺失";
+                    DressData[8] = "Empty";
+                    DressData[9] = "Empty";
+                    DressData[10] = "Empty";
+                    DressData[11] = "Empty";
+                }
+                else if (i == 5)
+                {
+                    DressData[5] = "眼睛1";
+                }
+                else if (i == 6)
+                {
+                    DressData[6] = "嘴巴1";
                 }
                 else if (i == 7)
                 {

+ 55 - 38
Assets/Script/Manage/PlayerPrefManager.cs

@@ -1,39 +1,56 @@
-using System.Collections;
-using System.Collections.Generic;
-
-using UnityEngine;
-
-public class PlayerPrefManager
-{
-    public const string INTERACT_CONFIG = "Interact_Config";
-
-    public static bool GetBool(string label, bool defaultValue)
-    {
-        int i = PlayerPrefs.GetInt(label, -1);
-        if (i == -1)
-        {
-            return defaultValue;
-        }
-        if (i == 0)
-        {
-            return false;
-        }
-        else
-        {
-            return true;
-        }
-    }
-
-    public static void SaveBool(string label, bool value)
-    {
-        if (value)
-        {
-            PlayerPrefs.SetInt(label, 1);
-        }
-        else
-        {
-            PlayerPrefs.SetInt(label, 0);
-        }
-        PlayerPrefs.Save();
-    }
+using System.Collections;
+using System.Collections.Generic;
+
+using UnityEngine;
+
+public class PlayerPrefManager
+{
+    public const string INTERACT_CONFIG = "Interact_Config";
+    public const string PLAYER_CONFIG = "Player_Config";
+
+    public static bool GetBool(string label, bool defaultValue)
+    {
+        int i = PlayerPrefs.GetInt(label, -1);
+        if (i == -1)
+        {
+            return defaultValue;
+        }
+        if (i == 0)
+        {
+            return false;
+        }
+        else
+        {
+            return true;
+        }
+    }
+
+    public static void SaveBool(string label, bool value)
+    {
+        if (value)
+        {
+            PlayerPrefs.SetInt(label, 1);
+        }
+        else
+        {
+            PlayerPrefs.SetInt(label, 0);
+        }
+        PlayerPrefs.Save();
+    }
+
+    public static string GetStr(string label, string defaultValue)
+    {
+        string str = PlayerPrefs.GetString(label, "null");
+        if (str == "null")
+        {
+            return defaultValue;
+        }
+        return str;
+    }
+
+    public static void SaveStr(string label, string value)
+    {
+        PlayerPrefs.SetString(label, value);
+        PlayerPrefs.Save();
+    }
 }

+ 2 - 2
Assets/Script/Manage/UIManager.cs

@@ -2210,7 +2210,7 @@ public class UIManager : Regist
         #region L_CreditsContent
 
         ResourceManager.Get(CanvasLabel.Lc_CreditsContent).CreateTweenCG(0, 1, 0.25f, false, true, Curve.EaseOutQuad);
-        ResourceManager.Get(CanvasLabel.Lc_CreditsContent).CreateTweenVec2D(ResourceManager.Get(CanvasLabel.Lc_Pos).position, 10f, false, false, true, Curve.Linear);
+        //ResourceManager.Get(CanvasLabel.Lc_CreditsContent).CreateTweenVec2D(ResourceManager.Get(CanvasLabel.Lc_Pos).position, 10f, false, false, true, Curve.Linear);
 
         #endregion
 
@@ -3672,7 +3672,7 @@ public class UIManager : Regist
     {
         ResourceManager.Get(CanvasLabel.Lc_CreditsMask).TweenForCG();
         ResourceManager.Get(CanvasLabel.Lc_CreditsContent).TweenForCG();
-        ResourceManager.Get(CanvasLabel.Lc_CreditsContent).TweenReForVec();
+        //ResourceManager.Get(CanvasLabel.Lc_CreditsContent).TweenReForVec();
 
         StopPlayCreditsRoutine = Auxiliary.Instance.DelayCall
         (

+ 20 - 1
Assets/Script/Object/Player.cs

@@ -1245,6 +1245,25 @@ public class Player : Regist , IPointerClickHandler
         return names;
     }
 
+    public List<string> GetAllDressNames()
+    {
+        List<string> names = new List<string>();
+        names.Add(Head);
+        names.Add(Dress);
+        names.Add(Shoe);
+        names.Add(HeadWear);
+        names.Add(Top);
+        if (PlayAnimFlag1) names.Add(TempClose);
+        else names.Add(Eye);
+        names.Add(Mouse);
+        names.Add(Wing);
+        names.Add(LeftLongSleeve);
+        names.Add(LeftShortSleeve);
+        names.Add(RightLongSleeve);
+        names.Add(RightShortSleeve);
+        return names;
+    }
+
     public void BuyDressNavigate(List<CloseItem> closeUnitList)
     {
         for (int i = 0; i < closeUnitList.Count; i++)
@@ -1498,7 +1517,7 @@ public class Player : Regist , IPointerClickHandler
     }
 
 
-    private List<UnityUGUIDisplay> uguiDisplays;
+    public List<UnityUGUIDisplay> uguiDisplays;
     public void DisplayInUI(float scale, bool adjustScale)
     {
         uguiDisplays = new List<UnityUGUIDisplay>();

+ 66 - 6
Assets/Script/Social/FashionShowCloseBox.cs

@@ -1,4 +1,7 @@
+using System.Collections;
 using System.Collections.Generic;
+using System.IO;
+using repeatCallUtility;
 using UnityEngine;
 using UnityEngine.UI;
 
@@ -8,6 +11,7 @@ public class FashionShowCloseCell
 
     //public bool Praised;
     public Text PraiseText;
+    public Image ShadowImg;
     public Button PraiseButton;
     public Button ShareButton;
     public Button DisplayButton;
@@ -16,9 +20,10 @@ public class FashionShowCloseCell
 
     #endregion
 
-    public FashionShowCloseCell(Text praiseText, Button praiseButton, Button shareButton, Button displayButton)
+    public FashionShowCloseCell(Text praiseText, Image shadowImg, Button praiseButton, Button shareButton, Button displayButton)
     {
         PraiseText = praiseText;
+        ShadowImg = shadowImg;
         PraiseButton = praiseButton;
         ShareButton = shareButton;
         DisplayButton = displayButton;
@@ -58,9 +63,54 @@ public class FashionShowCloseCell
         }
     }
 
+    public static Player photoShopPlayer;
+    public string path = Application.persistentDataPath + Path.DirectorySeparatorChar + "FashionShow.png";
     private void OnShareButtonClick()
     {
+        if (photoShopPlayer != null)
+        {
+            Object.Destroy(photoShopPlayer.gameObject);
+        }
+
         AudioManager.PlayClip(ResourceLabel.BtnClip);
+
+        ResourceManager.Get("PhotoShop").SetParent(null);
+        ResourceManager.Get("PhotoShop").SetActive(true);
+
+        photoShopPlayer = PlayerManager.Instance.GetRawPlayer();
+        PlayerManager.BuildPlayer(Player.GetAllDressNames(), photoShopPlayer);
+        photoShopPlayer.SetParent(ResourceManager.Get("PhotoShopPlayer"));
+        photoShopPlayer.transform.localPosition = new Vector3(0, 0, -1);
+        photoShopPlayer.ResetDepth();
+
+        Camera camera = ResourceManager.Get<Camera>("PhotoShopCamera");
+        PhotoShopCamera shopCamera = camera.GetComponent<PhotoShopCamera>();
+        if (shopCamera == null)
+        {
+            shopCamera = camera.AddComponent<PhotoShopCamera>();
+        }
+        shopCamera.onRenderFinish = null;
+        shopCamera.onRenderFinish += ScreenShot;
+    }
+
+    private void ScreenShot(Texture2D tex)
+    {
+        float left = 0.02f;
+        float right = 0.4f;
+        float top = 0.8f;
+        float bottom = 0.05f;
+        int width = (int)(tex.width * (right - left));
+        int height = (int)(tex.height * (top - bottom));
+        int leftOffset = (int)(tex.width * left);
+        int bottomOffset = (int)(tex.height * bottom);
+        Texture2D newTex = new Texture2D(width, height);
+        newTex.SetPixels(tex.GetPixels(leftOffset, bottomOffset, width, height));
+        newTex.Apply();
+        File.WriteAllBytes(path, newTex.EncodeToJPG());
+
+        ResourceManager.Get("PhotoShop").SetActive(false);
+
+        IAPManager.Share(path, Language.GetStr(LanguageLabel.Common__ScreenShotShareContent));
     }
 
     private void OnPraiseButtonClick()
@@ -114,6 +164,11 @@ public class FashionShowCloseBox : VirtualScrollRectItem
     private Text C_PraiseText;
     private Text D_PraiseText;
     private Text E_PraiseText;
+    private Image A_Img;
+    private Image B_Img;
+    private Image C_Img;
+    private Image D_Img;
+    private Image E_Img;
     private Button A_DisplayBackground;
     private Button A_PraiseButton;
     private Button A_ShareButton;
@@ -178,6 +233,11 @@ public class FashionShowCloseBox : VirtualScrollRectItem
         C_PraiseText = childDictionary[FashionShowCloseBoxLabel.C_PraiseText].GetComponent<Text>();
         D_PraiseText = childDictionary[FashionShowCloseBoxLabel.D_PraiseText].GetComponent<Text>();
         E_PraiseText = childDictionary[FashionShowCloseBoxLabel.E_PraiseText].GetComponent<Text>();
+        A_Img = childDictionary["A_Image"].GetComponent<Image>();
+        B_Img = childDictionary["A_Image"].GetComponent<Image>();
+        C_Img = childDictionary["A_Image"].GetComponent<Image>();
+        D_Img = childDictionary["A_Image"].GetComponent<Image>();
+        E_Img = childDictionary["A_Image"].GetComponent<Image>();
         A_DisplayBackground = childDictionary[FashionShowCloseBoxLabel.A_DisplayBackground].GetComponent<Button>();
         A_PraiseButton = childDictionary[FashionShowCloseBoxLabel.A_PraiseButton].GetComponent<Button>();
         A_ShareButton = childDictionary[FashionShowCloseBoxLabel.A_ShareButton].GetComponent<Button>();
@@ -195,11 +255,11 @@ public class FashionShowCloseBox : VirtualScrollRectItem
         E_ShareButton = childDictionary[FashionShowCloseBoxLabel.E_ShareButton].GetComponent<Button>();
         //RegistEndMark-Used by LabelUtility-Do not remove   
 
-        Cells.Add(new FashionShowCloseCell(A_PraiseText, A_PraiseButton, A_ShareButton, A_DisplayBackground));
-        Cells.Add(new FashionShowCloseCell(B_PraiseText, B_PraiseButton, B_ShareButton, B_DisplayBackground));
-        Cells.Add(new FashionShowCloseCell(C_PraiseText, C_PraiseButton, C_ShareButton, C_DisplayBackground));
-        Cells.Add(new FashionShowCloseCell(D_PraiseText, D_PraiseButton, D_ShareButton, D_DisplayBackground));
-        Cells.Add(new FashionShowCloseCell(E_PraiseText, E_PraiseButton, E_ShareButton, E_DisplayBackground));
+        Cells.Add(new FashionShowCloseCell(A_PraiseText, A_Img, A_PraiseButton, A_ShareButton, A_DisplayBackground));
+        Cells.Add(new FashionShowCloseCell(B_PraiseText, B_Img, B_PraiseButton, B_ShareButton, B_DisplayBackground));
+        Cells.Add(new FashionShowCloseCell(C_PraiseText, C_Img, C_PraiseButton, C_ShareButton, C_DisplayBackground));
+        Cells.Add(new FashionShowCloseCell(D_PraiseText, D_Img, D_PraiseButton, D_ShareButton, D_DisplayBackground));
+        Cells.Add(new FashionShowCloseCell(E_PraiseText, E_Img, E_PraiseButton, E_ShareButton, E_DisplayBackground));
         reset();
 
         return false;

+ 8 - 2
Assets/Script/Tool/Auxiliary.cs

@@ -155,15 +155,21 @@ public class Auxiliary : Regist
         //    RobotManager.DeactivateAllRobots(false);
         //}
 
+        if (Input.GetKey(KeyCode.Space))
+        {
+            Vector3 pos = ResourceManager.Get(CanvasLabel.Lc_CreditsContent).position;
+            ResourceManager.Get(CanvasLabel.Lc_CreditsContent).position = pos + new Vector3(0, 2f, 0);
+        }
+
         if (Input.GetKeyDown(KeyCode.Space))
         {
-            TutorialManager.changeMouseTutorial = true;
+            //TutorialManager.changeMouseTutorial = true;
             //PlayerManager.Player.UAC.anim.Stop();
             //Manager.Coin = 0;
             //Manager.Diamond = 0;
             //CommentRewardManager.GetReward();
             //Manager.AddCoin(1000000000000, StaticsManager.ItemID.None, StaticsManager.ConsumeModule.None);
-            DebugManager.ResetGardenLevel(38);
+            //DebugManager.ResetGardenLevel(38);
             //HttpManager.GetTargetConfig
             //(
             //    "1801134288353834791",

+ 66 - 61
Assets/Script/Tool/Test.cs

@@ -1,62 +1,67 @@
-using System;
-using UnityEngine;
-
-using System.Collections;
-using System.Collections.Generic;
-using System.IO;
-using cn.sharesdk.unity3d;
-using UnityEngine.UI;
-
-public class Test : MonoBehaviour
-{
-    public Text Text;
-    public Texture2D Texture2D;
-
-    private string FilePath;
-
-    public void Awake()
-    {
-        FilePath = string.Format("{0}/Test.png", Application.persistentDataPath);
-        if (!File.Exists(FilePath))
-        {
-            File.WriteAllBytes(FilePath, Texture2D.EncodeToPNG());
-        }
-        Text.text = FilePath;
-        ShareSDK = gameObject.AddComponent<ShareSDK>();
-        ShareSDK.Initialize();
-        ShareSDK.shareHandler = ShareCallback;
-    }
-
-    public static ShareSDK ShareSDK;
-    public void TestShare()
-    {
-        ShareContent shareContent = new ShareContent();
-        shareContent.SetText("content");
-        shareContent.SetTitle("title");
-        shareContent.SetTitleUrl("www.baidu.com");
-        shareContent.SetSite("www.baidu.com");
-        shareContent.SetSiteUrl("www.baidu.com");
-        shareContent.SetUrl("www.baidu.com");
-        shareContent.SetShareType(ContentType.App);
-        //shareContent.SetImageUrl("http://or5zgoeui.bkt.clouddn.com/game_icon.png");
-        shareContent.SetImagePath(FilePath);
-        ShareSDK.ShowPlatformList(null, shareContent, 100, 100);
-        Text.text = "¿ªÊ¼·ÖÏí";
-    }
-
-    public void ShareCallback(int reqID, ResponseState state, PlatformType type, Hashtable result)
-    {
-        if (state == ResponseState.Success)
-        {
-            Text.text = "Success";
-        }
-        else if (state == ResponseState.Fail)
-        {
-            Text.text = "Fail";
-        }
-        else if (state == ResponseState.Cancel)
-        {
-            Text.text = "Cancel";
-        }
-    }
+using System;
+using UnityEngine;
+
+using System.Collections;
+using System.Collections.Generic;
+using System.IO;
+using cn.sharesdk.unity3d;
+using UnityEngine.UI;
+
+public class Test : MonoBehaviour
+{
+    public Text Text;
+    public Texture2D Texture2D;
+
+    private string FilePath;
+
+    public void Awake()
+    {
+        //FilePath = string.Format("{0}/Test.png", Application.persistentDataPath);
+        //if (!File.Exists(FilePath))
+        //{
+        //    File.WriteAllBytes(FilePath, Texture2D.EncodeToPNG());
+        //}
+        //Text.text = FilePath;
+        //ShareSDK = gameObject.AddComponent<ShareSDK>();
+        //ShareSDK.Initialize();
+        //ShareSDK.shareHandler = ShareCallback;
+    }
+
+    public void Update()
+    {
+        GetComponent<RectTransform>().position += new Vector3(0, 100 *Time.deltaTime, 0);
+    }
+
+    public static ShareSDK ShareSDK;
+    public void TestShare()
+    {
+        ShareContent shareContent = new ShareContent();
+        shareContent.SetText("content");
+        shareContent.SetTitle("title");
+        shareContent.SetTitleUrl("www.baidu.com");
+        shareContent.SetSite("www.baidu.com");
+        shareContent.SetSiteUrl("www.baidu.com");
+        shareContent.SetUrl("www.baidu.com");
+        shareContent.SetShareType(ContentType.App);
+        //shareContent.SetImageUrl("http://or5zgoeui.bkt.clouddn.com/game_icon.png");
+        shareContent.SetImagePath(FilePath);
+        ShareSDK.ShowPlatformList(null, shareContent, 100, 100);
+        Text.text = "¿ªÊ¼·ÖÏí";
+    }
+
+    public void ShareCallback(int reqID, ResponseState state, PlatformType type, Hashtable result)
+    {
+        if (state == ResponseState.Success)
+        {
+            Text.text = "Success";
+        }
+        else if (state == ResponseState.Fail)
+        {
+            Text.text = "Fail";
+        }
+        else if (state == ResponseState.Cancel)
+        {
+            Text.text = "Cancel";
+        }
+    }
 }

+ 4 - 4
Assets/Tookits/LabelUtility/LabelUtility.prefab

@@ -148,7 +148,7 @@ MonoBehaviour:
         type: 2}
       Type: 4
   - Name: "\u6D4B\u8BD5"
-    UtilityType: 2
+    UtilityType: 1
     LabelScriptPath: Assets
     LabelScriptName: TestLabel
     LabePrefix: public static string
@@ -167,9 +167,9 @@ MonoBehaviour:
     Languages:
     - {fileID: 4900000, guid: 6bf784d003b5c104e94531afb827212a, type: 3}
     Prefabs:
-    - {fileID: 1338839275615992, guid: c32731d4b49fbd146ae54a3978501d8c, type: 2}
-    FoldOut: 1
-    TotalHeight: 756
+    - {fileID: 0}
+    FoldOut: 0
+    TotalHeight: 18
     RegistTypes: 010000000400000007000000
     RegistTargets:
     - Name: Title

+ 1 - 0
ProjectSettings/GraphicsSettings.asset

@@ -39,6 +39,7 @@ GraphicsSettings:
   - {fileID: 4800000, guid: ac390d8200b91bd419e2d7b9e580d07d, type: 3}
   - {fileID: 4800000, guid: e73e8e8cfe7b2344abcbf572918e22a1, type: 3}
   - {fileID: 16000, guid: 0000000000000000f000000000000000, type: 0}
+  - {fileID: 16002, guid: 0000000000000000f000000000000000, type: 0}
   m_PreloadedShaders: []
   m_SpritesDefaultMaterial: {fileID: 10754, guid: 0000000000000000f000000000000000,
     type: 0}

+ 12 - 0
ProjectSettings/QualitySettings.asset

@@ -17,6 +17,7 @@ QualitySettings:
     shadowNearPlaneOffset: 3
     shadowCascade2Split: 0.33333334
     shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667}
+    shadowmaskMode: 0
     blendWeights: 1
     textureQuality: 1
     anisotropicTextures: 0
@@ -31,6 +32,7 @@ QualitySettings:
     particleRaycastBudget: 4
     asyncUploadTimeSlice: 2
     asyncUploadBufferSize: 4
+    resolutionScalingFixedDPIFactor: 1
     excludedTargetPlatforms: []
   - serializedVersion: 2
     name: Fast
@@ -43,6 +45,7 @@ QualitySettings:
     shadowNearPlaneOffset: 3
     shadowCascade2Split: 0.33333334
     shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667}
+    shadowmaskMode: 0
     blendWeights: 2
     textureQuality: 0
     anisotropicTextures: 0
@@ -57,6 +60,7 @@ QualitySettings:
     particleRaycastBudget: 16
     asyncUploadTimeSlice: 2
     asyncUploadBufferSize: 4
+    resolutionScalingFixedDPIFactor: 1
     excludedTargetPlatforms: []
   - serializedVersion: 2
     name: Simple
@@ -69,6 +73,7 @@ QualitySettings:
     shadowNearPlaneOffset: 3
     shadowCascade2Split: 0.33333334
     shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667}
+    shadowmaskMode: 0
     blendWeights: 2
     textureQuality: 0
     anisotropicTextures: 1
@@ -83,6 +88,7 @@ QualitySettings:
     particleRaycastBudget: 64
     asyncUploadTimeSlice: 2
     asyncUploadBufferSize: 4
+    resolutionScalingFixedDPIFactor: 1
     excludedTargetPlatforms: []
   - serializedVersion: 2
     name: Good
@@ -95,6 +101,7 @@ QualitySettings:
     shadowNearPlaneOffset: 3
     shadowCascade2Split: 0.33333334
     shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667}
+    shadowmaskMode: 1
     blendWeights: 2
     textureQuality: 0
     anisotropicTextures: 1
@@ -109,6 +116,7 @@ QualitySettings:
     particleRaycastBudget: 256
     asyncUploadTimeSlice: 2
     asyncUploadBufferSize: 4
+    resolutionScalingFixedDPIFactor: 1
     excludedTargetPlatforms: []
   - serializedVersion: 2
     name: Beautiful
@@ -121,6 +129,7 @@ QualitySettings:
     shadowNearPlaneOffset: 3
     shadowCascade2Split: 0.33333334
     shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667}
+    shadowmaskMode: 1
     blendWeights: 4
     textureQuality: 0
     anisotropicTextures: 2
@@ -135,6 +144,7 @@ QualitySettings:
     particleRaycastBudget: 1024
     asyncUploadTimeSlice: 2
     asyncUploadBufferSize: 4
+    resolutionScalingFixedDPIFactor: 1
     excludedTargetPlatforms: []
   - serializedVersion: 2
     name: Fantastic
@@ -147,6 +157,7 @@ QualitySettings:
     shadowNearPlaneOffset: 3
     shadowCascade2Split: 0.33333334
     shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667}
+    shadowmaskMode: 1
     blendWeights: 4
     textureQuality: 0
     anisotropicTextures: 2
@@ -161,6 +172,7 @@ QualitySettings:
     particleRaycastBudget: 4096
     asyncUploadTimeSlice: 2
     asyncUploadBufferSize: 4
+    resolutionScalingFixedDPIFactor: 1
     excludedTargetPlatforms: []
   m_PerPlatformDefaultQuality:
     Android: 2

+ 1 - 1
ProjectSettings/UnityConnectSettings.asset

@@ -31,6 +31,6 @@ UnityConnectSettings:
     m_GameIds:
       AndroidPlayer: 1408493
       iPhonePlayer: 1408492
-    m_GameId: 
+    m_GameId: 1408493
   PerformanceReportingSettings:
     m_Enabled: 0

+ 0 - 4
第五期.txt

@@ -1,7 +1,3 @@
-换嘴巴教程似乎有Bug
-
-
-
 增加服装流程 骨骼位置 UI上的位置 语言文档 存档
 
 

Beberapa file tidak ditampilkan karena terlalu banyak file yang berubah dalam diff ini