暂无描述
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

SpriteEditorMenu.cs 23KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527
  1. using UnityEngine;
  2. using System;
  3. using System.Collections.Generic;
  4. using UnityEvent = UnityEngine.Event;
  5. namespace UnityEditor.U2D.Sprites
  6. {
  7. [Serializable]
  8. internal class SpriteEditorMenuSetting : ScriptableObject
  9. {
  10. public enum SlicingType
  11. {
  12. Automatic = 0,
  13. GridByCellSize = 1,
  14. GridByCellCount = 2,
  15. IsometricGrid = 3
  16. }
  17. [SerializeField]
  18. public Vector2 gridCellCount = new Vector2(1, 1);
  19. [SerializeField]
  20. public Vector2 gridSpriteSize = new Vector2(64, 64);
  21. [SerializeField]
  22. public Vector2 gridSpriteOffset = new Vector2(0, 0);
  23. [SerializeField]
  24. public Vector2 gridSpritePadding = new Vector2(0, 0);
  25. [SerializeField]
  26. public Vector2 pivot = Vector2.zero;
  27. [SerializeField]
  28. public int autoSlicingMethod = (int)SpriteFrameModule.AutoSlicingMethod.DeleteAll;
  29. [SerializeField]
  30. public int spriteAlignment;
  31. [SerializeField]
  32. public SlicingType slicingType;
  33. [SerializeField]
  34. public bool keepEmptyRects;
  35. [SerializeField]
  36. public bool isAlternate;
  37. }
  38. internal class SpriteEditorMenu : EditorWindow
  39. {
  40. private static Styles s_Styles;
  41. private static long s_LastClosedTime;
  42. private static SpriteEditorMenuSetting s_Setting;
  43. private ITextureDataProvider m_TextureDataProvider;
  44. private SpriteFrameModule m_SpriteFrameModule;
  45. private List<Rect> m_PotentialRects;
  46. private class Styles
  47. {
  48. public GUIStyle background = "grey_border";
  49. public GUIStyle notice;
  50. public Styles()
  51. {
  52. notice = new GUIStyle(GUI.skin.label);
  53. notice.alignment = TextAnchor.MiddleCenter;
  54. notice.wordWrap = true;
  55. }
  56. public readonly GUIContent[] spriteAlignmentOptions =
  57. {
  58. EditorGUIUtility.TrTextContent("Center"),
  59. EditorGUIUtility.TrTextContent("Top Left"),
  60. EditorGUIUtility.TrTextContent("Top"),
  61. EditorGUIUtility.TrTextContent("Top Right"),
  62. EditorGUIUtility.TrTextContent("Left"),
  63. EditorGUIUtility.TrTextContent("Right"),
  64. EditorGUIUtility.TrTextContent("Bottom Left"),
  65. EditorGUIUtility.TrTextContent("Bottom"),
  66. EditorGUIUtility.TrTextContent("Bottom Right"),
  67. EditorGUIUtility.TrTextContent("Custom")
  68. };
  69. public readonly GUIContent[] slicingMethodOptions =
  70. {
  71. EditorGUIUtility.TrTextContent("Delete Existing", "Delete all existing sprite assets before the slicing operation"),
  72. EditorGUIUtility.TrTextContent("Smart", "Try to match existing sprite rects to sliced rects from the slicing operation"),
  73. EditorGUIUtility.TrTextContent("Safe", "Keep existing sprite rects intact")
  74. };
  75. public readonly GUIContent methodLabel = EditorGUIUtility.TrTextContent("Method");
  76. public readonly GUIContent pivotLabel = EditorGUIUtility.TrTextContent("Pivot");
  77. public readonly GUIContent typeLabel = EditorGUIUtility.TrTextContent("Type");
  78. public readonly GUIContent sliceButtonLabel = EditorGUIUtility.TrTextContent("Slice");
  79. public readonly GUIContent columnAndRowLabel = EditorGUIUtility.TrTextContent("Column & Row");
  80. public readonly GUIContent columnLabel = EditorGUIUtility.TextContent("C");
  81. public readonly GUIContent rowLabel = EditorGUIUtility.TextContent("R");
  82. public readonly GUIContent pixelSizeLabel = EditorGUIUtility.TrTextContent("Pixel Size");
  83. public readonly GUIContent xLabel = EditorGUIUtility.TextContent("X");
  84. public readonly GUIContent yLabel = EditorGUIUtility.TextContent("Y");
  85. public readonly GUIContent offsetLabel = EditorGUIUtility.TrTextContent("Offset");
  86. public readonly GUIContent paddingLabel = EditorGUIUtility.TrTextContent("Padding");
  87. public readonly GUIContent automaticSlicingHintLabel = EditorGUIUtility.TrTextContent("To obtain more accurate slicing results, manual slicing is recommended!");
  88. public readonly GUIContent customPivotLabel = EditorGUIUtility.TrTextContent("Custom Pivot");
  89. public readonly GUIContent keepEmptyRectsLabel = EditorGUIUtility.TrTextContent("Keep Empty Rects");
  90. public readonly GUIContent isAlternateLabel = EditorGUIUtility.TrTextContent("Is Alternate");
  91. public readonly string deleteExistingMessage = L10n.Tr("The Delete Existing slicing method will destroy the current Sprites and recreate them from scratch, once you select Apply. This operation could cause the Sprite references to get lost. Consider using Smart or Safe slicing methods instead.");
  92. }
  93. internal List<Rect> GetPotentialRects()
  94. {
  95. if (m_PotentialRects == null)
  96. m_PotentialRects = new List<Rect>();
  97. m_PotentialRects.Clear();
  98. switch (s_Setting.slicingType)
  99. {
  100. case SpriteEditorMenuSetting.SlicingType.Automatic:
  101. // Do not show rects for Automatic
  102. break;
  103. case SpriteEditorMenuSetting.SlicingType.GridByCellCount:
  104. DetermineGridCellSizeWithCellCount(out var cellSize);
  105. m_PotentialRects.AddRange(m_SpriteFrameModule.GetGridRects(cellSize
  106. , s_Setting.gridSpriteOffset
  107. , s_Setting.gridSpritePadding
  108. , true));
  109. break;
  110. case SpriteEditorMenuSetting.SlicingType.GridByCellSize:
  111. m_PotentialRects.AddRange(m_SpriteFrameModule.GetGridRects(s_Setting.gridSpriteSize
  112. , s_Setting.gridSpriteOffset
  113. , s_Setting.gridSpritePadding
  114. , true));
  115. break;
  116. case SpriteEditorMenuSetting.SlicingType.IsometricGrid:
  117. m_PotentialRects.AddRange(m_SpriteFrameModule.GetIsometricRects(s_Setting.gridSpriteSize
  118. , s_Setting.gridSpriteOffset
  119. , s_Setting.isAlternate
  120. , true));
  121. break;
  122. }
  123. return m_PotentialRects;
  124. }
  125. private void Init(Rect buttonRect, SpriteFrameModule sf, ITextureDataProvider dataProvider)
  126. {
  127. // Create for once if setting was not created before.
  128. if (s_Setting == null)
  129. s_Setting = CreateInstance<SpriteEditorMenuSetting>();
  130. m_SpriteFrameModule = sf;
  131. m_TextureDataProvider = dataProvider;
  132. buttonRect = GUIUtility.GUIToScreenRect(buttonRect);
  133. const float windowHeight = 255;
  134. var windowSize = new Vector2(300, windowHeight);
  135. ShowAsDropDown(buttonRect, windowSize);
  136. Undo.undoRedoPerformed += UndoRedoPerformed;
  137. RectSettingsDirty();
  138. }
  139. private void UndoRedoPerformed()
  140. {
  141. Repaint();
  142. }
  143. void OnEnable()
  144. {
  145. AssemblyReloadEvents.beforeAssemblyReload += Close;
  146. }
  147. private void OnDisable()
  148. {
  149. AssemblyReloadEvents.beforeAssemblyReload -= Close;
  150. Undo.undoRedoPerformed -= UndoRedoPerformed;
  151. s_LastClosedTime = DateTime.Now.Ticks / TimeSpan.TicksPerMillisecond;
  152. m_SpriteFrameModule.potentialRects = null;
  153. m_SpriteFrameModule.spriteEditor.RequestRepaint();
  154. }
  155. private void RectSettingsDirty()
  156. {
  157. m_SpriteFrameModule.potentialRects = GetPotentialRects();
  158. m_SpriteFrameModule.spriteEditor.RequestRepaint();
  159. }
  160. internal static bool ShowAtPosition(Rect buttonRect, SpriteFrameModule sf, ITextureDataProvider textureProvider)
  161. {
  162. // We could not use realtimeSinceStartUp since it is set to 0 when entering/exitting playmode, we assume an increasing time when comparing time.
  163. long nowMilliSeconds = DateTime.Now.Ticks / TimeSpan.TicksPerMillisecond;
  164. bool justClosed = nowMilliSeconds < s_LastClosedTime + 50;
  165. if (!justClosed)
  166. {
  167. if (UnityEvent.current != null) // Event.current can be null during integration test
  168. UnityEvent.current.Use();
  169. SpriteEditorMenu spriteEditorMenu = CreateInstance<SpriteEditorMenu>();
  170. spriteEditorMenu.Init(buttonRect, sf, textureProvider);
  171. return true;
  172. }
  173. return false;
  174. }
  175. private void OnGUI()
  176. {
  177. if (s_Styles == null)
  178. s_Styles = new Styles();
  179. // Leave some space above the elements
  180. GUILayout.Space(4);
  181. EditorGUIUtility.labelWidth = 124f;
  182. EditorGUIUtility.wideMode = true;
  183. GUI.Label(new Rect(0, 0, position.width, position.height), GUIContent.none, s_Styles.background);
  184. EditorGUI.BeginChangeCheck();
  185. SpriteEditorMenuSetting.SlicingType slicingType = s_Setting.slicingType;
  186. slicingType = (SpriteEditorMenuSetting.SlicingType)EditorGUILayout.EnumPopup(s_Styles.typeLabel, slicingType);
  187. if (EditorGUI.EndChangeCheck())
  188. {
  189. Undo.RegisterCompleteObjectUndo(s_Setting, "Change slicing type");
  190. s_Setting.slicingType = slicingType;
  191. UpdateToDefaultAutoSliceMethod();
  192. RectSettingsDirty();
  193. }
  194. switch (slicingType)
  195. {
  196. case SpriteEditorMenuSetting.SlicingType.GridByCellSize:
  197. case SpriteEditorMenuSetting.SlicingType.GridByCellCount:
  198. OnGridGUI();
  199. break;
  200. case SpriteEditorMenuSetting.SlicingType.Automatic:
  201. OnAutomaticGUI();
  202. break;
  203. case SpriteEditorMenuSetting.SlicingType.IsometricGrid:
  204. OnIsometricGridGUI();
  205. break;
  206. }
  207. DoPivotGUI();
  208. GUILayout.Space(2f);
  209. EditorGUI.BeginChangeCheck();
  210. int slicingMethod = s_Setting.autoSlicingMethod;
  211. slicingMethod = EditorGUILayout.Popup(s_Styles.methodLabel, slicingMethod, s_Styles.slicingMethodOptions);
  212. if (EditorGUI.EndChangeCheck())
  213. {
  214. Undo.RegisterCompleteObjectUndo(s_Setting, "Change Slicing Method");
  215. s_Setting.autoSlicingMethod = slicingMethod;
  216. }
  217. if (s_Setting.autoSlicingMethod == (int)SpriteFrameModule.AutoSlicingMethod.DeleteAll)
  218. EditorGUILayout.HelpBox(s_Styles.deleteExistingMessage, MessageType.Warning);
  219. GUILayout.FlexibleSpace();
  220. GUILayout.BeginHorizontal();
  221. GUILayout.Space(EditorGUIUtility.labelWidth + 4);
  222. if (GUILayout.Button(s_Styles.sliceButtonLabel))
  223. DoSlicing();
  224. GUILayout.EndHorizontal();
  225. }
  226. private static void UpdateToDefaultAutoSliceMethod()
  227. {
  228. s_Setting.autoSlicingMethod = (int)SpriteFrameModule.AutoSlicingMethod.DeleteAll;
  229. }
  230. private void DoSlicing()
  231. {
  232. switch (s_Setting.slicingType)
  233. {
  234. case SpriteEditorMenuSetting.SlicingType.GridByCellCount:
  235. case SpriteEditorMenuSetting.SlicingType.GridByCellSize:
  236. DoGridSlicing();
  237. break;
  238. case SpriteEditorMenuSetting.SlicingType.Automatic:
  239. DoAutomaticSlicing();
  240. break;
  241. case SpriteEditorMenuSetting.SlicingType.IsometricGrid:
  242. DoIsometricGridSlicing();
  243. break;
  244. }
  245. }
  246. private void TwoIntFields(GUIContent label, GUIContent labelX, GUIContent labelY, ref int x, ref int y)
  247. {
  248. float height = EditorGUI.kSingleLineHeight;
  249. Rect rect = GUILayoutUtility.GetRect(EditorGUILayout.kLabelFloatMinW, EditorGUILayout.kLabelFloatMaxW, height, height, EditorStyles.numberField);
  250. Rect labelRect = rect;
  251. labelRect.width = EditorGUIUtility.labelWidth;
  252. labelRect.height = EditorGUI.kSingleLineHeight;
  253. GUI.Label(labelRect, label);
  254. Rect fieldRect = rect;
  255. fieldRect.width -= EditorGUIUtility.labelWidth;
  256. fieldRect.height = EditorGUI.kSingleLineHeight;
  257. fieldRect.x += EditorGUIUtility.labelWidth;
  258. fieldRect.width /= 2;
  259. fieldRect.width -= 2;
  260. EditorGUIUtility.labelWidth = 12;
  261. x = EditorGUI.IntField(fieldRect, labelX, x);
  262. fieldRect.x += fieldRect.width + 3;
  263. y = EditorGUI.IntField(fieldRect, labelY, y);
  264. EditorGUIUtility.labelWidth = labelRect.width;
  265. }
  266. private void OnGridGUI()
  267. {
  268. int width, height;
  269. m_TextureDataProvider.GetTextureActualWidthAndHeight(out width, out height);
  270. var texture = m_TextureDataProvider.GetReadableTexture2D();
  271. int maxWidth = texture != null ? width : 4096;
  272. int maxHeight = texture != null ? height : 4096;
  273. if (s_Setting.slicingType == SpriteEditorMenuSetting.SlicingType.GridByCellCount)
  274. {
  275. int x = (int)s_Setting.gridCellCount.x;
  276. int y = (int)s_Setting.gridCellCount.y;
  277. EditorGUI.BeginChangeCheck();
  278. TwoIntFields(s_Styles.columnAndRowLabel, s_Styles.columnLabel, s_Styles.rowLabel, ref x, ref y);
  279. if (EditorGUI.EndChangeCheck())
  280. {
  281. Undo.RegisterCompleteObjectUndo(s_Setting, "Change column & row");
  282. s_Setting.gridCellCount.x = Mathf.Clamp(x, 1, maxWidth);
  283. s_Setting.gridCellCount.y = Mathf.Clamp(y, 1, maxHeight);
  284. RectSettingsDirty();
  285. }
  286. }
  287. else
  288. {
  289. int x = (int)s_Setting.gridSpriteSize.x;
  290. int y = (int)s_Setting.gridSpriteSize.y;
  291. EditorGUI.BeginChangeCheck();
  292. TwoIntFields(s_Styles.pixelSizeLabel, s_Styles.xLabel, s_Styles.yLabel, ref x, ref y);
  293. if (EditorGUI.EndChangeCheck())
  294. {
  295. Undo.RegisterCompleteObjectUndo(s_Setting, "Change grid size");
  296. s_Setting.gridSpriteSize.x = Mathf.Clamp(x, 1, maxWidth);
  297. s_Setting.gridSpriteSize.y = Mathf.Clamp(y, 1, maxHeight);
  298. RectSettingsDirty();
  299. }
  300. }
  301. {
  302. int x = (int)s_Setting.gridSpriteOffset.x;
  303. int y = (int)s_Setting.gridSpriteOffset.y;
  304. EditorGUI.BeginChangeCheck();
  305. TwoIntFields(s_Styles.offsetLabel, s_Styles.xLabel, s_Styles.yLabel, ref x, ref y);
  306. if (EditorGUI.EndChangeCheck())
  307. {
  308. Undo.RegisterCompleteObjectUndo(s_Setting, "Change grid offset");
  309. s_Setting.gridSpriteOffset.x = Mathf.Clamp(x, 0, maxWidth - s_Setting.gridSpriteSize.x);
  310. s_Setting.gridSpriteOffset.y = Mathf.Clamp(y, 0, maxHeight - s_Setting.gridSpriteSize.y);
  311. RectSettingsDirty();
  312. }
  313. }
  314. {
  315. int x = (int)s_Setting.gridSpritePadding.x;
  316. int y = (int)s_Setting.gridSpritePadding.y;
  317. EditorGUI.BeginChangeCheck();
  318. TwoIntFields(s_Styles.paddingLabel, s_Styles.xLabel, s_Styles.yLabel, ref x, ref y);
  319. if (EditorGUI.EndChangeCheck())
  320. {
  321. Undo.RegisterCompleteObjectUndo(s_Setting, "Change grid padding");
  322. s_Setting.gridSpritePadding.x = Mathf.Clamp(x, 0, maxWidth);
  323. s_Setting.gridSpritePadding.y = Mathf.Clamp(y, 0, maxHeight);
  324. RectSettingsDirty();
  325. }
  326. }
  327. EditorGUI.BeginChangeCheck();
  328. bool keepEmptyRects = s_Setting.keepEmptyRects;
  329. keepEmptyRects = EditorGUILayout.Toggle(s_Styles.keepEmptyRectsLabel, keepEmptyRects);
  330. if (EditorGUI.EndChangeCheck())
  331. {
  332. Undo.RegisterCompleteObjectUndo(s_Setting, "Keep Empty Rects");
  333. s_Setting.keepEmptyRects = keepEmptyRects;
  334. }
  335. }
  336. private void OnAutomaticGUI()
  337. {
  338. float spacing = 38f;
  339. var texture = m_TextureDataProvider.GetReadableTexture2D();
  340. if (texture != null && UnityEditor.TextureUtil.IsCompressedTextureFormat(texture.format))
  341. {
  342. EditorGUILayout.LabelField(s_Styles.automaticSlicingHintLabel, s_Styles.notice);
  343. spacing -= 31f;
  344. }
  345. }
  346. private void OnIsometricGridGUI()
  347. {
  348. int width, height;
  349. m_TextureDataProvider.GetTextureActualWidthAndHeight(out width, out height);
  350. var texture = m_TextureDataProvider.GetReadableTexture2D();
  351. int maxWidth = texture != null ? width : 4096;
  352. int maxHeight = texture != null ? height : 4096;
  353. {
  354. int x = (int)s_Setting.gridSpriteSize.x;
  355. int y = (int)s_Setting.gridSpriteSize.y;
  356. EditorGUI.BeginChangeCheck();
  357. TwoIntFields(s_Styles.pixelSizeLabel, s_Styles.xLabel, s_Styles.yLabel, ref x, ref y);
  358. if (EditorGUI.EndChangeCheck())
  359. {
  360. Undo.RegisterCompleteObjectUndo(s_Setting, "Change grid size");
  361. s_Setting.gridSpriteSize.x = Mathf.Clamp(x, 1, maxWidth);
  362. s_Setting.gridSpriteSize.y = Mathf.Clamp(y, 1, maxHeight);
  363. RectSettingsDirty();
  364. }
  365. }
  366. {
  367. int x = (int)s_Setting.gridSpriteOffset.x;
  368. int y = (int)s_Setting.gridSpriteOffset.y;
  369. EditorGUI.BeginChangeCheck();
  370. TwoIntFields(s_Styles.offsetLabel, s_Styles.xLabel, s_Styles.yLabel, ref x, ref y);
  371. if (EditorGUI.EndChangeCheck())
  372. {
  373. Undo.RegisterCompleteObjectUndo(s_Setting, "Change grid offset");
  374. s_Setting.gridSpriteOffset.x = Mathf.Clamp(x, 0, maxWidth - s_Setting.gridSpriteSize.x);
  375. s_Setting.gridSpriteOffset.y = Mathf.Clamp(y, 0, maxHeight - s_Setting.gridSpriteSize.y);
  376. RectSettingsDirty();
  377. }
  378. }
  379. EditorGUI.BeginChangeCheck();
  380. bool keepEmptyRects = s_Setting.keepEmptyRects;
  381. keepEmptyRects = EditorGUILayout.Toggle(s_Styles.keepEmptyRectsLabel, keepEmptyRects);
  382. if (EditorGUI.EndChangeCheck())
  383. {
  384. Undo.RegisterCompleteObjectUndo(s_Setting, "Keep Empty Rects");
  385. s_Setting.keepEmptyRects = keepEmptyRects;
  386. }
  387. EditorGUI.BeginChangeCheck();
  388. bool isAlternate = s_Setting.isAlternate;
  389. isAlternate = EditorGUILayout.Toggle(s_Styles.isAlternateLabel, isAlternate);
  390. if (EditorGUI.EndChangeCheck())
  391. {
  392. Undo.RegisterCompleteObjectUndo(s_Setting, "Is Alternate");
  393. s_Setting.isAlternate = isAlternate;
  394. RectSettingsDirty();
  395. }
  396. }
  397. private void DoPivotGUI()
  398. {
  399. EditorGUI.BeginChangeCheck();
  400. int alignment = s_Setting.spriteAlignment;
  401. alignment = EditorGUILayout.Popup(s_Styles.pivotLabel, alignment, s_Styles.spriteAlignmentOptions);
  402. if (EditorGUI.EndChangeCheck())
  403. {
  404. Undo.RegisterCompleteObjectUndo(s_Setting, "Change Alignment");
  405. s_Setting.spriteAlignment = alignment;
  406. s_Setting.pivot = SpriteEditorUtility.GetPivotValue((SpriteAlignment)alignment, s_Setting.pivot);
  407. }
  408. Vector2 pivot = s_Setting.pivot;
  409. EditorGUI.BeginChangeCheck();
  410. using (new EditorGUI.DisabledScope(alignment != (int)SpriteAlignment.Custom))
  411. {
  412. pivot = EditorGUILayout.Vector2Field(s_Styles.customPivotLabel, pivot);
  413. }
  414. if (EditorGUI.EndChangeCheck())
  415. {
  416. Undo.RegisterCompleteObjectUndo(s_Setting, "Change custom pivot");
  417. s_Setting.pivot = pivot;
  418. }
  419. }
  420. private void DoAutomaticSlicing()
  421. {
  422. // 4 seems to be a pretty nice min size for a automatic sprite slicing. It used to be exposed to the slicing dialog, but it is actually better workflow to slice&crop manually than find a suitable size number
  423. m_SpriteFrameModule.DoAutomaticSlicing(4, s_Setting.spriteAlignment, s_Setting.pivot, (SpriteFrameModule.AutoSlicingMethod)s_Setting.autoSlicingMethod);
  424. }
  425. private void DoGridSlicing()
  426. {
  427. if (s_Setting.slicingType == SpriteEditorMenuSetting.SlicingType.GridByCellCount)
  428. SetGridCellSizeWithCellCount();
  429. m_SpriteFrameModule.DoGridSlicing(s_Setting.gridSpriteSize, s_Setting.gridSpriteOffset, s_Setting.gridSpritePadding, s_Setting.spriteAlignment, s_Setting.pivot, (SpriteFrameModule.AutoSlicingMethod)s_Setting.autoSlicingMethod, s_Setting.keepEmptyRects);
  430. }
  431. private void DoIsometricGridSlicing()
  432. {
  433. m_SpriteFrameModule.DoIsometricGridSlicing(s_Setting.gridSpriteSize, s_Setting.gridSpriteOffset, s_Setting.spriteAlignment, s_Setting.pivot, (SpriteFrameModule.AutoSlicingMethod)s_Setting.autoSlicingMethod, s_Setting.keepEmptyRects, s_Setting.isAlternate);
  434. }
  435. private void SetGridCellSizeWithCellCount()
  436. {
  437. DetermineGridCellSizeWithCellCount(out var cellSize);
  438. s_Setting.gridSpriteSize = cellSize;
  439. }
  440. private void DetermineGridCellSizeWithCellCount(out Vector2 cellSize)
  441. {
  442. int width, height;
  443. m_TextureDataProvider.GetTextureActualWidthAndHeight(out width, out height);
  444. var texture = m_TextureDataProvider.GetReadableTexture2D();
  445. int maxWidth = texture != null ? width : 4096;
  446. int maxHeight = texture != null ? height : 4096;
  447. cellSize.x = (maxWidth - s_Setting.gridSpriteOffset.x - (s_Setting.gridSpritePadding.x * s_Setting.gridCellCount.x)) / s_Setting.gridCellCount.x;
  448. cellSize.y = (maxHeight - s_Setting.gridSpriteOffset.y - (s_Setting.gridSpritePadding.y * s_Setting.gridCellCount.y)) / s_Setting.gridCellCount.y;
  449. cellSize.x = Mathf.Clamp(cellSize.x, 1, maxWidth);
  450. cellSize.y = Mathf.Clamp(cellSize.y, 1, maxHeight);
  451. }
  452. }
  453. }