TODO features:
Functionality: - Rewrite history class so it tracks all changes, not only a canvas changes Bugs fixed: - In some cases after switching to a symbol dotPanel mouse move causes "Out of range" exception (history.Pre after width change?)
This commit is contained in:
		| @@ -6,19 +6,18 @@ using System.Runtime.InteropServices; | |||||||
| using System.Text; | using System.Text; | ||||||
| using System.Threading.Tasks; | using System.Threading.Tasks; | ||||||
| using System.Windows.Forms; | using System.Windows.Forms; | ||||||
| using static McBitFont.ChangeHistory; |  | ||||||
| using static McBitFont.MainForm; | using static McBitFont.MainForm; | ||||||
|  |  | ||||||
| namespace McBitFont { | namespace McBitFont { | ||||||
|     internal class ChangeHistory { |     internal class ChangeHistory { | ||||||
|         private MainForm mainForm; |         private MainForm mainForm; | ||||||
|         private List<ChangeType> timeline = []; |         private List<ChangeEvent> timeline = []; | ||||||
|         private List<FrameMiniature> canvasChanges = []; |         private List<FrameMiniature> canvasChanges = []; | ||||||
|         private List<List<FrameMiniature>> fontChanges = []; |         private List<List<FrameMiniature>> fontChanges = []; | ||||||
|         private List<int> selFrameChanges = []; |         private List<int> selectionChanges = []; | ||||||
|         private int canvasIndex = 0; |         private int canvasIndex = 0; | ||||||
|         private int fontIndex = 0; |         private int fontIndex = 0; | ||||||
|         private int selFrameIndex = 0; |         private int selectionIndex = 0; | ||||||
|         public int Depth { get; set; } |         public int Depth { get; set; } | ||||||
|         public int Index { get; set; } = -1; |         public int Index { get; set; } = -1; | ||||||
|         public int Count { |         public int Count { | ||||||
| @@ -30,7 +29,6 @@ namespace McBitFont { | |||||||
|         public int Redos { |         public int Redos { | ||||||
|             get { return Index < 0 ? Count : Count - Index - 1; } |             get { return Index < 0 ? Count : Count - Index - 1; } | ||||||
|         } |         } | ||||||
|         public bool HistoryAction { get; set; } = false; |  | ||||||
|         public bool Doing { get; set; } = false; |         public bool Doing { get; set; } = false; | ||||||
|  |  | ||||||
|         // Constructor |         // Constructor | ||||||
| @@ -38,32 +36,34 @@ namespace McBitFont { | |||||||
|             timeline = []; |             timeline = []; | ||||||
|             canvasChanges = []; |             canvasChanges = []; | ||||||
|             fontChanges = []; |             fontChanges = []; | ||||||
|             selFrameChanges = []; |             selectionChanges = []; | ||||||
|             mainForm = form; |             mainForm = form; | ||||||
|             Depth = depth; |             Depth = depth; | ||||||
|             ResetIndices(); |             ResetIndices(); | ||||||
|             Add(); |             Add(); | ||||||
|             HistoryAction = false; |  | ||||||
|             Doing = false; |             Doing = false; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|         private void ResetIndices() { |         private void ResetIndices() { | ||||||
|             Index = -1; |             Index = -1; | ||||||
|             canvasIndex = 0; |             canvasIndex = 0; | ||||||
|             fontIndex = 0; |             fontIndex = 0; | ||||||
|             selFrameIndex = 0; |             selectionIndex = 0; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         public enum ChangeType { |         public enum ChangeType { | ||||||
|             None   = 0, |             None   = 0, | ||||||
|             Canvas = 1, // Changes made to canvas |             Canvas = 1,     // Changes made to canvas | ||||||
|             Font   = 2, // Symbol width has been changed |             Font   = 2,     // Symbol width has been changed | ||||||
|             Frame  = 3  // Selected another frame |             Selection  = 3  // Selected another frame | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         public class ChangeEvent(ChangeType type, FrameMiniature? canvas = null) { | ||||||
|  |             public ChangeType Type { get; set; } = type; | ||||||
|  |             public FrameMiniature? Canvas { get; set; } = canvas; | ||||||
|         } |         } | ||||||
|         //public class ChangeEvent(ChangeType type, int index) { |  | ||||||
|         //    public ChangeType Type { get; set; } = type; |  | ||||||
|         //    public int Index { get; set; } = index; |  | ||||||
|         //} |  | ||||||
|  |  | ||||||
|         private static FrameMiniature CopyFrameSimple(FrameMiniature f) { |         private static FrameMiniature CopyFrameSimple(FrameMiniature f) { | ||||||
|             FrameMiniature newf = new(f.code, f.width, f.height); |             FrameMiniature newf = new(f.code, f.width, f.height); | ||||||
| @@ -75,14 +75,14 @@ namespace McBitFont { | |||||||
|             timeline.Clear(); |             timeline.Clear(); | ||||||
|             canvasChanges.Clear(); |             canvasChanges.Clear(); | ||||||
|             fontChanges.Clear(); |             fontChanges.Clear(); | ||||||
|             selFrameChanges.Clear(); |             selectionChanges.Clear(); | ||||||
|             ResetIndices(); |             ResetIndices(); | ||||||
|             Add(); |             Add(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // Remove from a proper list by change type |         // Remove from a proper list by change type | ||||||
|         private bool RemoveByType(ChangeType ct, bool first = true) { |         private bool RemoveByType(ChangeEvent ce, bool first = true) { | ||||||
|             switch (ct) { |             switch (ce.Type) { | ||||||
|                 case ChangeType.Canvas: |                 case ChangeType.Canvas: | ||||||
|                     if (canvasChanges.Count <= 1) return false; |                     if (canvasChanges.Count <= 1) return false; | ||||||
|                     if ((first && canvasIndex > 0) || (!first && canvasIndex == canvasChanges.Count - 1)) canvasIndex--; |                     if ((first && canvasIndex > 0) || (!first && canvasIndex == canvasChanges.Count - 1)) canvasIndex--; | ||||||
| @@ -91,12 +91,20 @@ namespace McBitFont { | |||||||
|                 case ChangeType.Font: |                 case ChangeType.Font: | ||||||
|                     if (fontChanges.Count <= 1) return false; |                     if (fontChanges.Count <= 1) return false; | ||||||
|                     if ((first && fontIndex > 0) || (!first && fontIndex == fontChanges.Count - 1)) fontIndex--; |                     if ((first && fontIndex > 0) || (!first && fontIndex == fontChanges.Count - 1)) fontIndex--; | ||||||
|  |                     if (ce.Canvas != null) { | ||||||
|  |                         if ((first && canvasIndex > 0) || (!first && canvasIndex == canvasChanges.Count - 1)) canvasIndex--; | ||||||
|  |                         canvasChanges.Remove((FrameMiniature)ce.Canvas); | ||||||
|  |                     } | ||||||
|                     fontChanges.RemoveAt(first ? 0 : fontChanges.Count - 1); |                     fontChanges.RemoveAt(first ? 0 : fontChanges.Count - 1); | ||||||
|                     break; |                     break; | ||||||
|                 case ChangeType.Frame: |                 case ChangeType.Selection: | ||||||
|                     if (selFrameChanges.Count <= 1) return false; |                     if (selectionChanges.Count <= 1) return false; | ||||||
|                     if ((first && selFrameIndex > 0) || (!first && selFrameIndex == selFrameChanges.Count - 1)) selFrameIndex--; |                     if ((first && selectionIndex > 0) || (!first && selectionIndex == selectionChanges.Count - 1)) selectionIndex--; | ||||||
|                     selFrameChanges.RemoveAt(first ? 0 : selFrameChanges.Count - 1); |                     if (ce.Canvas != null) { | ||||||
|  |                         if ((first && canvasIndex > 0) || (!first && canvasIndex == canvasChanges.Count - 1)) canvasIndex--; | ||||||
|  |                         canvasChanges.Remove((FrameMiniature)ce.Canvas); | ||||||
|  |                     } | ||||||
|  |                     selectionChanges.RemoveAt(first ? 0 : selectionChanges.Count - 1); | ||||||
|                     break; |                     break; | ||||||
|                 default: |                 default: | ||||||
|                     return false; |                     return false; | ||||||
| @@ -111,8 +119,8 @@ namespace McBitFont { | |||||||
|         // Remove oldest event |         // Remove oldest event | ||||||
|         private bool RemoveOldest() { |         private bool RemoveOldest() { | ||||||
|             if (Count == 0) return false; |             if (Count == 0) return false; | ||||||
|             ChangeType ct = timeline.First(); |             ChangeEvent ce = timeline.First(); | ||||||
|             RemoveByType(ct); |             RemoveByType(ce); | ||||||
|  |  | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| @@ -120,8 +128,8 @@ namespace McBitFont { | |||||||
|         // Remove last event |         // Remove last event | ||||||
|         public bool RemoveLast() { |         public bool RemoveLast() { | ||||||
|             if (Count == 0) return false; |             if (Count == 0) return false; | ||||||
|             var ct = timeline.Last(); |             var ce = timeline.Last(); | ||||||
|             RemoveByType(ct, false); |             RemoveByType(ce, false); | ||||||
|  |  | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| @@ -134,17 +142,7 @@ namespace McBitFont { | |||||||
|                 timeline.RemoveRange(       Index + 1,         Count                 - Index - 1); |                 timeline.RemoveRange(       Index + 1,         Count                 - Index - 1); | ||||||
|                 canvasChanges.RemoveRange(  canvasIndex + 1,   canvasChanges.Count   - canvasIndex - 1); |                 canvasChanges.RemoveRange(  canvasIndex + 1,   canvasChanges.Count   - canvasIndex - 1); | ||||||
|                 fontChanges.RemoveRange(    fontIndex + 1,     fontChanges.Count     - fontIndex - 1); |                 fontChanges.RemoveRange(    fontIndex + 1,     fontChanges.Count     - fontIndex - 1); | ||||||
|                 selFrameChanges.RemoveRange(selFrameIndex + 1, selFrameChanges.Count - selFrameIndex - 1); |                 selectionChanges.RemoveRange(selectionIndex + 1, selectionChanges.Count - selectionIndex - 1); | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // Checks and resets HistoryAction property to abort Add action |  | ||||||
|         private bool CheckHistoryAction() { |  | ||||||
|             if (HistoryAction) { |  | ||||||
|                 HistoryAction = false; |  | ||||||
|                 return true; |  | ||||||
|             } else { |  | ||||||
|                 return false; |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -158,24 +156,23 @@ namespace McBitFont { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         // Add canvas change |         // Add canvas change | ||||||
|         public void Add(FrameMiniature f, bool useIndex = true) { |         public FrameMiniature? Add(FrameMiniature f, bool useIndex = true) { | ||||||
|             if (Doing) return; |             if (Doing) return null ; | ||||||
|             if (useIndex && CheckHistoryAction()) return; |  | ||||||
|             TruncateTail(); |             TruncateTail(); | ||||||
|  |  | ||||||
|             if (Count > Depth) RemoveOldest(); |             if (Count >= Depth) RemoveOldest(); | ||||||
|             canvasChanges.Add(CopyFrameSimple(f)); |             canvasChanges.Add(CopyFrameSimple(f)); | ||||||
|             if (useIndex) { |             if (useIndex) { | ||||||
|                 timeline.Add(ChangeType.Canvas); |                 timeline.Add(new ChangeEvent(ChangeType.Canvas)); | ||||||
|                 Index++; |                 Index++; | ||||||
|                 canvasIndex++; |                 canvasIndex++; | ||||||
|             } |             } | ||||||
|  |             return canvasChanges.Last(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // Add Font change |         // Add Font change | ||||||
|         public void Add(List<FrameMiniature> ff, bool useIndex = true) { |         public void Add(List<FrameMiniature> ff, bool useIndex = true) { | ||||||
|             if (Doing) return; |             if (Doing) return; | ||||||
|             if (useIndex && CheckHistoryAction()) return; |  | ||||||
|             TruncateTail(); |             TruncateTail(); | ||||||
|  |  | ||||||
|             var l = new List<FrameMiniature>(); |             var l = new List<FrameMiniature>(); | ||||||
| @@ -183,44 +180,52 @@ namespace McBitFont { | |||||||
|                 l.Add(CopyFrameSimple(f)); |                 l.Add(CopyFrameSimple(f)); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             if (Count > Depth) RemoveOldest(); |             if (Count >= Depth) RemoveOldest(); | ||||||
|             fontChanges.Add(l); |             fontChanges.Add(l); | ||||||
|             if (useIndex) { |             if (useIndex) { | ||||||
|                 timeline.Add(ChangeType.Font); |                 var canv = Add(mainForm.f, false); | ||||||
|  |                 canvasIndex++; | ||||||
|  |                 timeline.Add(new ChangeEvent(ChangeType.Font, canv)); | ||||||
|                 Index++; |                 Index++; | ||||||
|                 fontIndex++; |                 fontIndex++; | ||||||
|                 Add(mainForm.f); |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // Add Frame selection change |         // Add Frame selection change | ||||||
|         public void Add(int code, bool useIndex = true) { |         public void Add(int code, bool useIndex = true) { | ||||||
|             if (Doing) return; |             if (Doing) return; | ||||||
|             if (useIndex && CheckHistoryAction()) return; |  | ||||||
|             if (useIndex) { |  | ||||||
|                 Add(mainForm.frames.Find(x => x.code == code)); |  | ||||||
|                 //Add(mainForm.f); |  | ||||||
|             } |  | ||||||
|             TruncateTail(); |             TruncateTail(); | ||||||
|  |  | ||||||
|             if (Count > Depth) RemoveOldest(); |             if (Count >= Depth) RemoveOldest(); | ||||||
|             selFrameChanges.Add(code); |             selectionChanges.Add(code); | ||||||
|             if (useIndex) { |             if (useIndex) { | ||||||
|                 timeline.Add(ChangeType.Frame); |                 var canv = Add(mainForm.f, false); | ||||||
|  |                 canvasIndex++; | ||||||
|  |                 timeline.Add(new ChangeEvent(ChangeType.Selection, canv)); | ||||||
|                 Index++; |                 Index++; | ||||||
|                 selFrameIndex++; |                 selectionIndex++; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         private void Do(bool undo = true) { |         private void Do(bool undo = true) { | ||||||
|  |             if (!undo && Index >= Count - 1) return; | ||||||
|             Doing = true; |             Doing = true; | ||||||
|             var ct = timeline.ElementAt(Index + (undo ? 0 : 1)); |             var ce = timeline.ElementAt(Index + (undo ? 0 : 1)); | ||||||
|             int dIndex = undo ? -1 : 1; |             int dIndex = undo ? -1 : 1; | ||||||
|             switch (ct) { |             FrameMiniature fff; | ||||||
|  |             switch (ce.Type) { | ||||||
|                 case ChangeType.Canvas: |                 case ChangeType.Canvas: | ||||||
|                     canvasIndex += dIndex; |                     canvasIndex += dIndex; | ||||||
|                     mainForm.f = CopyFrameSimple(canvasChanges[canvasIndex]); |                     mainForm.f = CopyFrameSimple(canvasChanges[canvasIndex]); | ||||||
|  |                     mainForm.SetModified(); | ||||||
|  |                     mainForm.nudX.ValueChanged -= mainForm.nudX_ValueChanged; | ||||||
|  |                     mainForm.nudY.ValueChanged -= mainForm.nudY_ValueChanged; | ||||||
|  |                     mainForm.nudY.Value = mainForm.dotHeight = canvasChanges[canvasIndex].height; | ||||||
|  |                     mainForm.nudX.Value = mainForm.dotWidth = canvasChanges[canvasIndex].width; | ||||||
|  |                     mainForm.SetNewWH(); | ||||||
|  |                     mainForm.nudX.ValueChanged += mainForm.nudX_ValueChanged; | ||||||
|  |                     mainForm.nudY.ValueChanged += mainForm.nudY_ValueChanged; | ||||||
|                     break; |                     break; | ||||||
|                 case ChangeType.Font: |                 case ChangeType.Font: | ||||||
|                     Cursor.Current = Cursors.WaitCursor; |                     Cursor.Current = Cursors.WaitCursor; | ||||||
| @@ -231,6 +236,7 @@ namespace McBitFont { | |||||||
|                         selCode = Convert.ToInt32(selItem); |                         selCode = Convert.ToInt32(selItem); | ||||||
|                     } |                     } | ||||||
|                     fontIndex += dIndex; |                     fontIndex += dIndex; | ||||||
|  |                     canvasIndex += dIndex; | ||||||
|                     mainForm.frames.Clear(); |                     mainForm.frames.Clear(); | ||||||
|                     mainForm.miniList.Clear(); |                     mainForm.miniList.Clear(); | ||||||
|                     mainForm.ilMiniatures.Images.Clear(); |                     mainForm.ilMiniatures.Images.Clear(); | ||||||
| @@ -238,7 +244,7 @@ namespace McBitFont { | |||||||
|                         mainForm.frames.Add(CopyFrameSimple(f)); |                         mainForm.frames.Add(CopyFrameSimple(f)); | ||||||
|                     } |                     } | ||||||
|                     mainForm.FillFrameLists(); |                     mainForm.FillFrameLists(); | ||||||
|                     FrameMiniature fff; |                      | ||||||
|                     if (selItem != "") { |                     if (selItem != "") { | ||||||
|                         var selection = mainForm.miniList.Items.Find(selItem, false); |                         var selection = mainForm.miniList.Items.Find(selItem, false); | ||||||
|                         if (selection.Length > 0) selection[0].Selected = true; |                         if (selection.Length > 0) selection[0].Selected = true; | ||||||
| @@ -248,44 +254,38 @@ namespace McBitFont { | |||||||
|                         fff = mainForm.frames[0]; |                         fff = mainForm.frames[0]; | ||||||
|                     } |                     } | ||||||
|                     mainForm.f = mainForm.CopyFrame(fff); |                     mainForm.f = mainForm.CopyFrame(fff); | ||||||
|  |                     mainForm.nudX.ValueChanged -= mainForm.nudX_ValueChanged; | ||||||
|  |                     mainForm.nudY.ValueChanged -= mainForm.nudY_ValueChanged; | ||||||
|                     mainForm.nudY.Value = mainForm.dotHeight = fff.height; |                     mainForm.nudY.Value = mainForm.dotHeight = fff.height; | ||||||
|                     mainForm.nudX.Value = mainForm.dotWidth = fff.width; |                     mainForm.nudX.Value = mainForm.dotWidth = fff.width; | ||||||
|  |                     mainForm.SetNewWH(); | ||||||
|  |                     mainForm.nudX.ValueChanged += mainForm.nudX_ValueChanged; | ||||||
|  |                     mainForm.nudY.ValueChanged += mainForm.nudY_ValueChanged; | ||||||
|  |                      | ||||||
|                     Cursor.Current = Cursors.Default; |                     Cursor.Current = Cursors.Default; | ||||||
|                     break; |                     break; | ||||||
|                 case ChangeType.Frame: |                 case ChangeType.Selection: | ||||||
|                     HistoryAction = true; |                     selectionIndex += dIndex; | ||||||
|                     selFrameIndex += dIndex; |                     canvasIndex += dIndex; | ||||||
|                     var s = selFrameChanges[selFrameIndex].ToString().PadLeft(3, '0'); |                     var s = selectionChanges[selectionIndex].ToString().PadLeft(3, '0'); | ||||||
|                     var sel = mainForm.miniList.Items.Find(s, false); |                     var sel = mainForm.miniList.Items.Find(s, false); | ||||||
|                     if (sel.Length > 0) sel[0].Selected = true; |                     if (sel.Length > 0) sel[0].Selected = true; | ||||||
|  |                     fff = mainForm.frames.Find(x => x.code == selectionChanges[selectionIndex]); | ||||||
|  |                     mainForm.f = CopyFrameSimple(fff); | ||||||
|  |                     mainForm.nudX.ValueChanged -= mainForm.nudX_ValueChanged; | ||||||
|  |                     mainForm.nudY.ValueChanged -= mainForm.nudY_ValueChanged; | ||||||
|  |                     mainForm.nudY.Value = mainForm.dotHeight = fff.height; | ||||||
|  |                     mainForm.nudX.Value = mainForm.dotWidth = fff.width; | ||||||
|  |                     mainForm.SetNewWH(); | ||||||
|  |                     mainForm.nudX.ValueChanged += mainForm.nudX_ValueChanged; | ||||||
|  |                     mainForm.nudY.ValueChanged += mainForm.nudY_ValueChanged; | ||||||
|                     break; |                     break; | ||||||
|                 default: |                 default: | ||||||
|                     break; |                     break; | ||||||
|             } |             } | ||||||
|             Index += dIndex; |             Index += dIndex; | ||||||
|             Doing = false; |             Doing = false; | ||||||
|             // Frame select change + Canvas change workarounds |             | ||||||
|             if (ct == ChangeType.Frame && undo) { |  | ||||||
|                 Undo(); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             if (Index < Count - 1) { |  | ||||||
|                 var nextctframe = timeline.ElementAt(Index + 1) == ChangeType.Frame; |  | ||||||
|                 if (ct == ChangeType.Canvas && !undo && nextctframe) { |  | ||||||
|                     Redo(); |  | ||||||
|                     return; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             //Font change + Canvas change workarounds |  | ||||||
|             if (Index >= 0) { |  | ||||||
|                 var prevctfont = timeline.ElementAt(Index) == ChangeType.Font; |  | ||||||
|                 if (ct == ChangeType.Canvas && undo && prevctfont) { |  | ||||||
|                     Undo(); |  | ||||||
|                     return; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             if (!undo && ct == ChangeType.Font) |  | ||||||
|                 Redo(); |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // Undo last change |         // Undo last change | ||||||
|   | |||||||
| @@ -76,7 +76,7 @@ namespace McBitFont { | |||||||
|             this.dotPanel.MouseWheel += new MouseEventHandler(this.DotPanel_MouseWheel); |             this.dotPanel.MouseWheel += new MouseEventHandler(this.DotPanel_MouseWheel); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         private void SetNewWH() { |         public void SetNewWH() { | ||||||
|             w = pixelOffset + dotWidth * (cellSize + gap); |             w = pixelOffset + dotWidth * (cellSize + gap); | ||||||
|             h = pixelOffset + dotHeight * (cellSize + gap); |             h = pixelOffset + dotHeight * (cellSize + gap); | ||||||
|         } |         } | ||||||
| @@ -85,7 +85,7 @@ namespace McBitFont { | |||||||
|             lblSelection.Text = width.ToString() + ',' + height.ToString(); |             lblSelection.Text = width.ToString() + ',' + height.ToString(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         private void SetModified(bool modif = true, bool prj = false) { |         public void SetModified(bool modif = true, bool prj = false) { | ||||||
|             string suffix = ""; |             string suffix = ""; | ||||||
|             if (prj) { |             if (prj) { | ||||||
|                 prjModified = modif; |                 prjModified = modif; | ||||||
| @@ -197,7 +197,7 @@ namespace McBitFont { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         private void nudX_ValueChanged(object sender, EventArgs e) { |         public void nudX_ValueChanged(object sender, EventArgs e) { | ||||||
|             Cursor.Current = Cursors.WaitCursor; |             Cursor.Current = Cursors.WaitCursor; | ||||||
|             if (monospaced) { |             if (monospaced) { | ||||||
|                 Bitmap bmp; |                 Bitmap bmp; | ||||||
| @@ -216,10 +216,13 @@ namespace McBitFont { | |||||||
|             } |             } | ||||||
|  |  | ||||||
|             DotResize((int)nudX.Value, dotHeight); |             DotResize((int)nudX.Value, dotHeight); | ||||||
|  |             if (monospaced) history.Add(frames); | ||||||
|  |             else history.Add(f); | ||||||
|  |              | ||||||
|             Cursor.Current = Cursors.Default; |             Cursor.Current = Cursors.Default; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         private void nudY_ValueChanged(object sender, EventArgs e) { |         public void nudY_ValueChanged(object sender, EventArgs e) { | ||||||
|             Cursor.Current = Cursors.WaitCursor; |             Cursor.Current = Cursors.WaitCursor; | ||||||
|             Bitmap bmp; |             Bitmap bmp; | ||||||
|             for (int i = 0; i < frames.Count; i++) { |             for (int i = 0; i < frames.Count; i++) { | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								TODO.txt
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								TODO.txt
									
									
									
									
									
								
							| @@ -3,9 +3,9 @@ Application: | |||||||
| V Copy-Paste now uses System clipboard and it is possible to copy-paste from/to different instances of running program | V Copy-Paste now uses System clipboard and it is possible to copy-paste from/to different instances of running program | ||||||
|  |  | ||||||
| Functionality: | Functionality: | ||||||
| - Rewrite history class so it tracks all changes, not only a canvas changes | V Rewrite history class so it tracks all changes, not only a canvas changes | ||||||
|  |  | ||||||
| Bugs: | Bugs: | ||||||
| - In some cases after switching to a symbol dotPanel mouse move causes "Out of range" exception (history.Pre after width change?) | V In some cases after switching to a symbol dotPanel mouse move causes "Out of range" exception (history.Pre after width change?) | ||||||
| V Switching between symbols while select tool is active and small area selected trows an error | V Switching between symbols while select tool is active and small area selected trows an error | ||||||
| V Full frame Copy in Clipboard does not respect selection on Paste operation | V Full frame Copy in Clipboard does not respect selection on Paste operation | ||||||
		Reference in New Issue
	
	Block a user