No Description
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

SpriteEditorMenu.cs 24KB

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