Compare commits
	
		
			69 Commits
		
	
	
		
			v2.0
			...
			d70d8d8a3c
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| d70d8d8a3c | |||
| e5a4baadb7 | |||
| 37abcf2c8e | |||
| 2c2a8d6158 | |||
|  | 4115455a54 | ||
| 67be566605 | |||
| 7aa75224ee | |||
| 4fe2af03b0 | |||
|  | fc4822065a | ||
|  | 3778a753fb | ||
|  | 20bd7095dd | ||
| 8ed1e33f22 | |||
|  | 1eb463c94f | ||
| 30142fda26 | |||
|  | 70a4d34d69 | ||
|  | c913525b31 | ||
|  | 42c72b907f | ||
|  | 32a8ffd749 | ||
|  | c092aebeca | ||
|  | 346088b532 | ||
|  | ac7981d40a | ||
|  | dd3ecfcf3e | ||
|  | 6ba4a56197 | ||
|  | 87b46ec714 | ||
|  | 12593ef7ad | ||
|  | b01bff86b9 | ||
| 3e734432f4 | |||
| aa5b8354d6 | |||
|  | 7952263595 | ||
| 07906b8abc | |||
| 25e54c35e7 | |||
| fc3ef33f3e | |||
|  | 780f92ccf5 | ||
|  | cebbdc63c8 | ||
|  | 8ca83b7edc | ||
|  | 9cfe8ef5c3 | ||
| 76ca7ccf35 | |||
|  | 3c656b36a7 | ||
|  | 9f6f5ba5d7 | ||
|  | 4fa3d9bc49 | ||
|  | 1a26a2d16b | ||
|  | e0a4a6194c | ||
|  | 6971686f88 | ||
|  | ac2e345397 | ||
|  | d1d653bc34 | ||
| 1c034fded1 | |||
|  | a05352acf7 | ||
| 2f86598a2a | |||
|  | 313f35bb3e | ||
|  | 679b4fc61d | ||
|  | eda7af8f67 | ||
|  | 4381d6d911 | ||
|  | 8d34e34326 | ||
|  | 92027a0ee3 | ||
| 6c32edac6e | |||
| f9c9d440ec | |||
|  | f8b53f2dab | ||
|  | 2a4b36d368 | ||
| 083ede5985 | |||
| 5208d40a92 | |||
| 519720f2ef | |||
| 88ee72567e | |||
| 0d923ef8ed | |||
|  | 5e1a2085cf | ||
|  | ca21c43926 | ||
|  | c10a8e49ff | ||
|  | 5d17ba5538 | ||
| 4f80a5df1b | |||
| 37f2bb5eac | 
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -5,6 +5,7 @@ | |||||||
| ## Get latest from https://github.com/github/gitignore/blob/main/VisualStudio.gitignore | ## Get latest from https://github.com/github/gitignore/blob/main/VisualStudio.gitignore | ||||||
|  |  | ||||||
| examples/tests/32x32/ | examples/tests/32x32/ | ||||||
|  | examples/tests/PNGout/ | ||||||
|  |  | ||||||
| # User-specific files | # User-specific files | ||||||
| *.rsuser | *.rsuser | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								McBitFont/About.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						| @@ -124,7 +124,7 @@ | |||||||
|             MinimizeBox = false; |             MinimizeBox = false; | ||||||
|             Name = "About"; |             Name = "About"; | ||||||
|             ShowInTaskbar = false; |             ShowInTaskbar = false; | ||||||
|             StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen; |             StartPosition = System.Windows.Forms.FormStartPosition.CenterParent; | ||||||
|             Text = "About McBitFont"; |             Text = "About McBitFont"; | ||||||
|             Load += About_Load; |             Load += About_Load; | ||||||
|             ((System.ComponentModel.ISupportInitialize)pictureBox1).EndInit(); |             ((System.ComponentModel.ISupportInitialize)pictureBox1).EndInit(); | ||||||
|   | |||||||
| @@ -15,7 +15,7 @@ namespace McBitFont { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         private void About_Load(object sender, EventArgs e) { |         private void About_Load(object sender, EventArgs e) { | ||||||
|             lblVersion.Text = "Version: v" + MainForm.version; |             lblVersion.Text = "Version: " + MainForm.version; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         private void linkLabel1_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e) { |         private void linkLabel1_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e) { | ||||||
|   | |||||||
| @@ -1,85 +0,0 @@ | |||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Reflection; |  | ||||||
| using System.Text; |  | ||||||
| using System.Threading.Tasks; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| namespace McBitFont { |  | ||||||
|     internal class CanvasHistory { |  | ||||||
|         private List<bool[,]> stack; |  | ||||||
|         public int Depth { get; set; } |  | ||||||
|         public int Index { get; set; } |  | ||||||
|         public int Count { |  | ||||||
|             get { return stack.Count - 1; } |  | ||||||
|         } |  | ||||||
|         public int Redos { |  | ||||||
|             get { |  | ||||||
|                 var r = Count - Index - 1; |  | ||||||
|  |  | ||||||
|                 return r < 0 ? 0 : r; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         public int Undos { |  | ||||||
|             get { |  | ||||||
|                 return Index + 1; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|          |  | ||||||
|         public CanvasHistory(int depth = 50) { |  | ||||||
|             Depth = depth; |  | ||||||
|             Index = -1; |  | ||||||
|             stack = []; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public void Clear() { |  | ||||||
|             stack.Clear(); |  | ||||||
|             Index = -1; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public void AddPre(MainForm.FrameMiniature f, bool useIndex = true) { |  | ||||||
|             if (Count < 0) stack.Add(new bool[f.width, f.height]); |  | ||||||
|             if (Index < Count - 1) { |  | ||||||
|                 stack.RemoveRange(Index + 1, Count - Index - 1); |  | ||||||
|             } |  | ||||||
|             bool[,] d = new bool[f.width, f.height]; |  | ||||||
|             Array.Copy(f.data, d, f.data.Length); |  | ||||||
|             stack.Insert(Count, d); |  | ||||||
|             if (useIndex) { |  | ||||||
|                 if (Count > Depth) stack.RemoveAt(0); |  | ||||||
|                 else Index++; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public void AddPost(MainForm.FrameMiniature f) { |  | ||||||
|             var d = stack.ElementAt(Count); |  | ||||||
|             Array.Copy(f.data, d, f.data.Length); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public void ApplyAdded() { |  | ||||||
|             while (Count > Depth) stack.RemoveAt(0); |  | ||||||
|             Index = Count - 1; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public void Remove(bool useIndex = true) { |  | ||||||
|             stack.RemoveAt(Count - 1); |  | ||||||
|             if (useIndex) Index--; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public void Undo(MainForm.FrameMiniature f) { |  | ||||||
|             if (Index < 0) return; |  | ||||||
|             var d = stack.ElementAt(Index); |  | ||||||
|             Array.Copy(d, f.data, d.Length); |  | ||||||
|             Index--; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public void Redo(MainForm.FrameMiniature f) { |  | ||||||
|             if (Index >= Count - 1) return; |  | ||||||
|             Index++; |  | ||||||
|             var d = stack.ElementAt(Index + 1); |  | ||||||
|             Array.Copy(d, f.data, d.Length); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
							
								
								
									
										304
									
								
								McBitFont/ChangeHistory.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,304 @@ | |||||||
|  | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Windows.Forms; | ||||||
|  | using static McBitFont.MainForm; | ||||||
|  |  | ||||||
|  | namespace McBitFont { | ||||||
|  |     internal class ChangeHistory { | ||||||
|  |         private MainForm mainForm; | ||||||
|  |         private List<ChangeEvent> timeline = []; | ||||||
|  |         private List<FrameMiniature> canvasChanges = []; | ||||||
|  |         private List<List<FrameMiniature>> fontChanges = []; | ||||||
|  |         private List<int> selectionChanges = []; | ||||||
|  |         private int canvasIndex = 0; | ||||||
|  |         private int fontIndex = 0; | ||||||
|  |         private int selectionIndex = 0; | ||||||
|  |         public int Depth { get; set; } | ||||||
|  |         public int Index { get; set; } = -1; | ||||||
|  |         public int Count { | ||||||
|  |             get { return timeline.Count; } | ||||||
|  |         } | ||||||
|  |         public int Undos { | ||||||
|  |             get { return Index < 0 ? 0 : Index + 1; } | ||||||
|  |         } | ||||||
|  |         public int Redos { | ||||||
|  |             get { return Index < 0 ? Count : Count - Index - 1; } | ||||||
|  |         } | ||||||
|  |         public bool Doing { get; set; } = false; | ||||||
|  |  | ||||||
|  |         // Constructor | ||||||
|  |         public ChangeHistory(MainForm form, int depth = 100) { | ||||||
|  |             timeline = []; | ||||||
|  |             canvasChanges = []; | ||||||
|  |             fontChanges = []; | ||||||
|  |             selectionChanges = []; | ||||||
|  |             mainForm = form; | ||||||
|  |             Depth = depth; | ||||||
|  |             ResetIndices(); | ||||||
|  |             Add(); | ||||||
|  |             Doing = false; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         private void ResetIndices() { | ||||||
|  |             Index = -1; | ||||||
|  |             canvasIndex = 0; | ||||||
|  |             fontIndex = 0; | ||||||
|  |             selectionIndex = 0; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         public enum ChangeType { | ||||||
|  |             None   = 0, | ||||||
|  |             Canvas = 1,     // Changes made to canvas | ||||||
|  |             Font   = 2,     // Symbol width has been changed | ||||||
|  |             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 static FrameMiniature CopyFrameSimple(FrameMiniature f) { | ||||||
|  |             FrameMiniature newf = new(f.code, f.width, f.height); | ||||||
|  |             Array.Copy(f.data, newf.data, f.data.Length); | ||||||
|  |             return newf; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         public void Clear() { | ||||||
|  |             timeline.Clear(); | ||||||
|  |             canvasChanges.Clear(); | ||||||
|  |             fontChanges.Clear(); | ||||||
|  |             selectionChanges.Clear(); | ||||||
|  |             ResetIndices(); | ||||||
|  |             Add(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // Remove from a proper list by change type | ||||||
|  |         private bool RemoveByType(ChangeEvent ce, bool first = true) { | ||||||
|  |             switch (ce.Type) { | ||||||
|  |                 case ChangeType.Canvas: | ||||||
|  |                     if (canvasChanges.Count <= 1) return false; | ||||||
|  |                     if ((first && canvasIndex > 0) || (!first && canvasIndex == canvasChanges.Count - 1)) canvasIndex--; | ||||||
|  |                     canvasChanges.RemoveAt(first ? 0 : canvasChanges.Count - 1); | ||||||
|  |                     break; | ||||||
|  |                 case ChangeType.Font: | ||||||
|  |                     if (fontChanges.Count <= 1) return false; | ||||||
|  |                     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); | ||||||
|  |                     break; | ||||||
|  |                 case ChangeType.Selection: | ||||||
|  |                     if (selectionChanges.Count <= 1) return false; | ||||||
|  |                     if ((first && selectionIndex > 0) || (!first && selectionIndex == selectionChanges.Count - 1)) selectionIndex--; | ||||||
|  |                     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; | ||||||
|  |                 default: | ||||||
|  |                     return false; | ||||||
|  |             } | ||||||
|  |             if ((first && Index > 0) || (!first && Index == Count - 1) || Count == 1) Index--; | ||||||
|  |             timeline.RemoveAt(first ? 0 : Count - 1); | ||||||
|  |              | ||||||
|  |  | ||||||
|  |             return true; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // Remove oldest event | ||||||
|  |         private bool RemoveOldest() { | ||||||
|  |             if (Count == 0) return false; | ||||||
|  |             ChangeEvent ce = timeline.First(); | ||||||
|  |             RemoveByType(ce); | ||||||
|  |  | ||||||
|  |             return true; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // Remove last event | ||||||
|  |         public bool RemoveLast() { | ||||||
|  |             if (Count == 0) return false; | ||||||
|  |             var ce = timeline.Last(); | ||||||
|  |             RemoveByType(ce, false); | ||||||
|  |  | ||||||
|  |             return true; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // Remove history tail | ||||||
|  |         private void TruncateTail() { | ||||||
|  |             // Check if the Index does not point to the last event | ||||||
|  |             //while (Index < Count - 1) Remove | ||||||
|  |             if (Index >= -1 && Index < Count - 1) { | ||||||
|  |                 timeline.RemoveRange(       Index + 1,         Count                 - Index - 1); | ||||||
|  |                 canvasChanges.RemoveRange(  canvasIndex + 1,   canvasChanges.Count   - canvasIndex - 1); | ||||||
|  |                 fontChanges.RemoveRange(    fontIndex + 1,     fontChanges.Count     - fontIndex - 1); | ||||||
|  |                 selectionChanges.RemoveRange(selectionIndex + 1, selectionChanges.Count - selectionIndex - 1); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // Add first states to all lists | ||||||
|  |         private void Add() { | ||||||
|  |             Add(mainForm.f, false); | ||||||
|  |             Add(mainForm.frames, false); | ||||||
|  |             var fff = mainForm.f;   // Marshal-by-reference warning workaround | ||||||
|  |             int ccс = fff.code;     // | ||||||
|  |             Add(ccс, false); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // Add canvas change | ||||||
|  |         public FrameMiniature? Add(FrameMiniature f, bool useIndex = true) { | ||||||
|  |             if (Doing) return null ; | ||||||
|  |             TruncateTail(); | ||||||
|  |  | ||||||
|  |             if (Count >= Depth) RemoveOldest(); | ||||||
|  |             canvasChanges.Add(CopyFrameSimple(f)); | ||||||
|  |             if (useIndex) { | ||||||
|  |                 timeline.Add(new ChangeEvent(ChangeType.Canvas)); | ||||||
|  |                 Index++; | ||||||
|  |                 canvasIndex++; | ||||||
|  |             } | ||||||
|  |             return canvasChanges.Last(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // Add Font change | ||||||
|  |         public void Add(List<FrameMiniature> ff, bool useIndex = true) { | ||||||
|  |             if (Doing) return; | ||||||
|  |             TruncateTail(); | ||||||
|  |  | ||||||
|  |             var l = new List<FrameMiniature>(); | ||||||
|  |             foreach (var f in ff) { | ||||||
|  |                 l.Add(CopyFrameSimple(f)); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             if (Count >= Depth) RemoveOldest(); | ||||||
|  |             fontChanges.Add(l); | ||||||
|  |             if (useIndex) { | ||||||
|  |                 var canv = Add(mainForm.f, false); | ||||||
|  |                 canvasIndex++; | ||||||
|  |                 timeline.Add(new ChangeEvent(ChangeType.Font, canv)); | ||||||
|  |                 Index++; | ||||||
|  |                 fontIndex++; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // Add Frame selection change | ||||||
|  |         public void Add(int code, bool useIndex = true) { | ||||||
|  |             if (Doing) return; | ||||||
|  |             TruncateTail(); | ||||||
|  |  | ||||||
|  |             if (Count >= Depth) RemoveOldest(); | ||||||
|  |             selectionChanges.Add(code); | ||||||
|  |             if (useIndex) { | ||||||
|  |                 var canv = Add(mainForm.f, false); | ||||||
|  |                 canvasIndex++; | ||||||
|  |                 timeline.Add(new ChangeEvent(ChangeType.Selection, canv)); | ||||||
|  |                 Index++; | ||||||
|  |                 selectionIndex++; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private void Do(bool undo = true) { | ||||||
|  |             if (!undo && Index >= Count - 1) return; | ||||||
|  |             Doing = true; | ||||||
|  |             var ce = timeline.ElementAt(Index + (undo ? 0 : 1)); | ||||||
|  |             int dIndex = undo ? -1 : 1; | ||||||
|  |             FrameMiniature fff; | ||||||
|  |             switch (ce.Type) { | ||||||
|  |                 case ChangeType.Canvas: | ||||||
|  |                     canvasIndex += dIndex; | ||||||
|  |                     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; | ||||||
|  |                 case ChangeType.Font: | ||||||
|  |                     Cursor.Current = Cursors.WaitCursor; | ||||||
|  |                     string selItem = ""; | ||||||
|  |                     int selCode = 0; | ||||||
|  |                     if (mainForm.miniList.SelectedItems.Count > 0) { | ||||||
|  |                         selItem = mainForm.miniList.SelectedItems[0].Name; | ||||||
|  |                         selCode = Convert.ToInt32(selItem); | ||||||
|  |                     } | ||||||
|  |                     fontIndex += dIndex; | ||||||
|  |                     canvasIndex += dIndex; | ||||||
|  |                     mainForm.frames.Clear(); | ||||||
|  |                     mainForm.miniList.Clear(); | ||||||
|  |                     mainForm.ilMiniatures.Images.Clear(); | ||||||
|  |                     foreach (var f in fontChanges[fontIndex]) { | ||||||
|  |                         mainForm.frames.Add(CopyFrameSimple(f)); | ||||||
|  |                     } | ||||||
|  |                     mainForm.FillFrameLists(); | ||||||
|  |                      | ||||||
|  |                     if (selItem != "") { | ||||||
|  |                         var selection = mainForm.miniList.Items.Find(selItem, false); | ||||||
|  |                         if (selection.Length > 0) selection[0].Selected = true; | ||||||
|  |                         fff = mainForm.frames.Find(x => x.code == selCode); | ||||||
|  |                     } else { | ||||||
|  |                         mainForm.miniList.Items[0].Selected = true; | ||||||
|  |                         fff = mainForm.frames[0]; | ||||||
|  |                     } | ||||||
|  |                     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.nudX.Value = mainForm.dotWidth = fff.width; | ||||||
|  |                     mainForm.SetNewWH(); | ||||||
|  |                     mainForm.nudX.ValueChanged += mainForm.nudX_ValueChanged; | ||||||
|  |                     mainForm.nudY.ValueChanged += mainForm.nudY_ValueChanged; | ||||||
|  |                      | ||||||
|  |                     Cursor.Current = Cursors.Default; | ||||||
|  |                     break; | ||||||
|  |                 case ChangeType.Selection: | ||||||
|  |                     selectionIndex += dIndex; | ||||||
|  |                     canvasIndex += dIndex; | ||||||
|  |                     var s = selectionChanges[selectionIndex].ToString().PadLeft(3, '0'); | ||||||
|  |                     var sel = mainForm.miniList.Items.Find(s, false); | ||||||
|  |                     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; | ||||||
|  |                 default: | ||||||
|  |                     break; | ||||||
|  |             } | ||||||
|  |             Index += dIndex; | ||||||
|  |             Doing = false; | ||||||
|  |             | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // Undo last change | ||||||
|  |         public bool Undo() { | ||||||
|  |             if (Undos < 1) return false; | ||||||
|  |             Do(); | ||||||
|  |  | ||||||
|  |             return true; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // Redo last ondone change | ||||||
|  |         public bool Redo() { | ||||||
|  |             if (Redos < 1) return false; | ||||||
|  |             Do(false); | ||||||
|  |  | ||||||
|  |             return true; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										2
									
								
								McBitFont/CodeShift.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						| @@ -164,7 +164,7 @@ | |||||||
|             Name = "CodeShift"; |             Name = "CodeShift"; | ||||||
|             ShowIcon = false; |             ShowIcon = false; | ||||||
|             ShowInTaskbar = false; |             ShowInTaskbar = false; | ||||||
|             StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen; |             StartPosition = System.Windows.Forms.FormStartPosition.CenterParent; | ||||||
|             Text = "Code Shift"; |             Text = "Code Shift"; | ||||||
|             Load += CodeShift_Load; |             Load += CodeShift_Load; | ||||||
|             ((System.ComponentModel.ISupportInitialize)nudValue).EndInit(); |             ((System.ComponentModel.ISupportInitialize)nudValue).EndInit(); | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								McBitFont/Export.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						| @@ -343,7 +343,7 @@ | |||||||
|             Name = "Export"; |             Name = "Export"; | ||||||
|             ShowIcon = false; |             ShowIcon = false; | ||||||
|             ShowInTaskbar = false; |             ShowInTaskbar = false; | ||||||
|             StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen; |             StartPosition = System.Windows.Forms.FormStartPosition.CenterParent; | ||||||
|             Text = "Export"; |             Text = "Export"; | ||||||
|             Load += Export_Load; |             Load += Export_Load; | ||||||
|             gbScan.ResumeLayout(false); |             gbScan.ResumeLayout(false); | ||||||
|   | |||||||
| @@ -233,7 +233,7 @@ namespace McBitFont { | |||||||
|                 if (com && lines != 1 && fcount > 1) { |                 if (com && lines != 1 && fcount > 1) { | ||||||
|                     // Comments enabled and other than "1 symbol per line" selected |                     // Comments enabled and other than "1 symbol per line" selected | ||||||
|                     // Print a symbol comment before its data |                     // Print a symbol comment before its data | ||||||
|                     output += "  // " + f.code.ToString() + " --> " + mainForm.decodeSymbol(f.code) + "\n"; |                     output += "  // " + f.code.ToString() + " --> " + mainForm.DecodeSymbol(f.code) + "\n"; | ||||||
|                 } |                 } | ||||||
|                 if (lines == 1) { |                 if (lines == 1) { | ||||||
|                     // "1 symbol per line" - new line offset |                     // "1 symbol per line" - new line offset | ||||||
| @@ -369,7 +369,7 @@ namespace McBitFont { | |||||||
|                     if (!f.Equals(flast) && f.width > 0) output += ","; |                     if (!f.Equals(flast) && f.width > 0) output += ","; | ||||||
|                     if (com && fcount > 1) { |                     if (com && fcount > 1) { | ||||||
|                         //...with a comment |                         //...with a comment | ||||||
|                         output += " // " + f.code.ToString() + " --> " + mainForm.decodeSymbol(f.code); |                         output += " // " + f.code.ToString() + " --> " + mainForm.DecodeSymbol(f.code); | ||||||
|                     } |                     } | ||||||
|                     output += "\n"; |                     output += "\n"; | ||||||
|                 } |                 } | ||||||
|   | |||||||
							
								
								
									
										216
									
								
								McBitFont/FontTester.Designer.cs
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,216 @@ | |||||||
|  | namespace McBitFont { | ||||||
|  |     partial class FontTester { | ||||||
|  |         /// <summary> | ||||||
|  |         /// Required designer variable. | ||||||
|  |         /// </summary> | ||||||
|  |         private System.ComponentModel.IContainer components = null; | ||||||
|  |  | ||||||
|  |         /// <summary> | ||||||
|  |         /// Clean up any resources being used. | ||||||
|  |         /// </summary> | ||||||
|  |         /// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param> | ||||||
|  |         protected override void Dispose(bool disposing) { | ||||||
|  |             if (disposing && (components != null)) { | ||||||
|  |                 components.Dispose(); | ||||||
|  |             } | ||||||
|  |             base.Dispose(disposing); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         #region Windows Form Designer generated code | ||||||
|  |  | ||||||
|  |         /// <summary> | ||||||
|  |         /// Required method for Designer support - do not modify | ||||||
|  |         /// the contents of this method with the code editor. | ||||||
|  |         /// </summary> | ||||||
|  |         private void InitializeComponent() { | ||||||
|  |             components = new System.ComponentModel.Container(); | ||||||
|  |             lblSpace = new System.Windows.Forms.Label(); | ||||||
|  |             nudSpace = new System.Windows.Forms.NumericUpDown(); | ||||||
|  |             lblText = new System.Windows.Forms.Label(); | ||||||
|  |             tbText = new System.Windows.Forms.TextBox(); | ||||||
|  |             dotPanel = new System.Windows.Forms.Panel(); | ||||||
|  |             vScroll = new System.Windows.Forms.VScrollBar(); | ||||||
|  |             hScroll = new System.Windows.Forms.HScrollBar(); | ||||||
|  |             lblZoom = new System.Windows.Forms.Label(); | ||||||
|  |             cbZoom = new System.Windows.Forms.ComboBox(); | ||||||
|  |             toolTip1 = new System.Windows.Forms.ToolTip(components); | ||||||
|  |             btnCopy = new System.Windows.Forms.Button(); | ||||||
|  |             chkBaseline = new System.Windows.Forms.CheckBox(); | ||||||
|  |             ((System.ComponentModel.ISupportInitialize)nudSpace).BeginInit(); | ||||||
|  |             SuspendLayout(); | ||||||
|  |             //  | ||||||
|  |             // lblSpace | ||||||
|  |             //  | ||||||
|  |             lblSpace.AutoSize = true; | ||||||
|  |             lblSpace.Location = new System.Drawing.Point(12, 9); | ||||||
|  |             lblSpace.Name = "lblSpace"; | ||||||
|  |             lblSpace.Size = new System.Drawing.Size(41, 15); | ||||||
|  |             lblSpace.TabIndex = 0; | ||||||
|  |             lblSpace.Text = "Space:"; | ||||||
|  |             //  | ||||||
|  |             // nudSpace | ||||||
|  |             //  | ||||||
|  |             nudSpace.Location = new System.Drawing.Point(59, 6); | ||||||
|  |             nudSpace.Maximum = new decimal(new int[] { 255, 0, 0, 0 }); | ||||||
|  |             nudSpace.Name = "nudSpace"; | ||||||
|  |             nudSpace.Size = new System.Drawing.Size(40, 23); | ||||||
|  |             nudSpace.TabIndex = 2; | ||||||
|  |             toolTip1.SetToolTip(nudSpace, "Space between symbols in pixels"); | ||||||
|  |             nudSpace.Value = new decimal(new int[] { 1, 0, 0, 0 }); | ||||||
|  |             nudSpace.ValueChanged += Scrolling; | ||||||
|  |             //  | ||||||
|  |             // lblText | ||||||
|  |             //  | ||||||
|  |             lblText.AutoSize = true; | ||||||
|  |             lblText.Location = new System.Drawing.Point(12, 37); | ||||||
|  |             lblText.Name = "lblText"; | ||||||
|  |             lblText.Size = new System.Drawing.Size(138, 15); | ||||||
|  |             lblText.TabIndex = 2; | ||||||
|  |             lblText.Text = "Text to test the font with:"; | ||||||
|  |             //  | ||||||
|  |             // tbText | ||||||
|  |             //  | ||||||
|  |             tbText.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left | System.Windows.Forms.AnchorStyles.Right; | ||||||
|  |             tbText.Font = new System.Drawing.Font("Segoe UI Semibold", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|  |             tbText.Location = new System.Drawing.Point(12, 55); | ||||||
|  |             tbText.Name = "tbText"; | ||||||
|  |             tbText.Size = new System.Drawing.Size(260, 29); | ||||||
|  |             tbText.TabIndex = 1; | ||||||
|  |             toolTip1.SetToolTip(tbText, "Text to test the font with"); | ||||||
|  |             tbText.TextChanged += Text_Changed; | ||||||
|  |             //  | ||||||
|  |             // dotPanel | ||||||
|  |             //  | ||||||
|  |             dotPanel.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left | System.Windows.Forms.AnchorStyles.Right; | ||||||
|  |             dotPanel.AutoSizeMode = System.Windows.Forms.AutoSizeMode.GrowAndShrink; | ||||||
|  |             dotPanel.BackColor = System.Drawing.Color.White; | ||||||
|  |             dotPanel.BorderStyle = System.Windows.Forms.BorderStyle.FixedSingle; | ||||||
|  |             dotPanel.Location = new System.Drawing.Point(12, 90); | ||||||
|  |             dotPanel.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|  |             dotPanel.Name = "dotPanel"; | ||||||
|  |             dotPanel.Size = new System.Drawing.Size(238, 98); | ||||||
|  |             dotPanel.TabIndex = 4; | ||||||
|  |             dotPanel.Paint += PaintPixels; | ||||||
|  |             dotPanel.Resize += ZoomChanged; | ||||||
|  |             //  | ||||||
|  |             // vScroll | ||||||
|  |             //  | ||||||
|  |             vScroll.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right; | ||||||
|  |             vScroll.LargeChange = 25; | ||||||
|  |             vScroll.Location = new System.Drawing.Point(251, 84); | ||||||
|  |             vScroll.Name = "vScroll"; | ||||||
|  |             vScroll.Size = new System.Drawing.Size(21, 104); | ||||||
|  |             vScroll.TabIndex = 17; | ||||||
|  |             vScroll.ValueChanged += Scrolling; | ||||||
|  |             //  | ||||||
|  |             // hScroll | ||||||
|  |             //  | ||||||
|  |             hScroll.Anchor = System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left | System.Windows.Forms.AnchorStyles.Right; | ||||||
|  |             hScroll.Location = new System.Drawing.Point(12, 188); | ||||||
|  |             hScroll.Name = "hScroll"; | ||||||
|  |             hScroll.Size = new System.Drawing.Size(238, 21); | ||||||
|  |             hScroll.TabIndex = 16; | ||||||
|  |             hScroll.ValueChanged += Scrolling; | ||||||
|  |             //  | ||||||
|  |             // lblZoom | ||||||
|  |             //  | ||||||
|  |             lblZoom.AutoSize = true; | ||||||
|  |             lblZoom.Location = new System.Drawing.Point(173, 9); | ||||||
|  |             lblZoom.Name = "lblZoom"; | ||||||
|  |             lblZoom.Size = new System.Drawing.Size(42, 15); | ||||||
|  |             lblZoom.TabIndex = 18; | ||||||
|  |             lblZoom.Text = "Zoom:"; | ||||||
|  |             //  | ||||||
|  |             // cbZoom | ||||||
|  |             //  | ||||||
|  |             cbZoom.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList; | ||||||
|  |             cbZoom.FormattingEnabled = true; | ||||||
|  |             cbZoom.Items.AddRange(new object[] { "1", "2", "3", "5", "10", "15", "20", "25", "30", "35", "40", "45", "50" }); | ||||||
|  |             cbZoom.Location = new System.Drawing.Point(222, 6); | ||||||
|  |             cbZoom.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|  |             cbZoom.Name = "cbZoom"; | ||||||
|  |             cbZoom.Size = new System.Drawing.Size(50, 23); | ||||||
|  |             cbZoom.TabIndex = 3; | ||||||
|  |             cbZoom.TabStop = false; | ||||||
|  |             toolTip1.SetToolTip(cbZoom, "Zoom level"); | ||||||
|  |             cbZoom.SelectedIndexChanged += ZoomChanged; | ||||||
|  |             //  | ||||||
|  |             // toolTip1 | ||||||
|  |             //  | ||||||
|  |             toolTip1.AutoPopDelay = 10000; | ||||||
|  |             toolTip1.InitialDelay = 500; | ||||||
|  |             toolTip1.ReshowDelay = 100; | ||||||
|  |             //  | ||||||
|  |             // btnCopy | ||||||
|  |             //  | ||||||
|  |             btnCopy.Anchor = System.Windows.Forms.AnchorStyles.Bottom; | ||||||
|  |             btnCopy.Image = Properties.Resources.Famfamfam_Silk_Page_copy_16; | ||||||
|  |             btnCopy.ImageAlign = System.Drawing.ContentAlignment.MiddleRight; | ||||||
|  |             btnCopy.Location = new System.Drawing.Point(110, 214); | ||||||
|  |             btnCopy.Name = "btnCopy"; | ||||||
|  |             btnCopy.Size = new System.Drawing.Size(80, 30); | ||||||
|  |             btnCopy.TabIndex = 5; | ||||||
|  |             btnCopy.Text = " Copy"; | ||||||
|  |             btnCopy.TextImageRelation = System.Windows.Forms.TextImageRelation.ImageBeforeText; | ||||||
|  |             toolTip1.SetToolTip(btnCopy, "Copy BitPixels you see to Clipboard"); | ||||||
|  |             btnCopy.UseVisualStyleBackColor = true; | ||||||
|  |             btnCopy.MouseClick += Copy_Click; | ||||||
|  |             //  | ||||||
|  |             // chkBaseline | ||||||
|  |             //  | ||||||
|  |             chkBaseline.AutoSize = true; | ||||||
|  |             chkBaseline.Location = new System.Drawing.Point(203, 36); | ||||||
|  |             chkBaseline.Name = "chkBaseline"; | ||||||
|  |             chkBaseline.Size = new System.Drawing.Size(69, 19); | ||||||
|  |             chkBaseline.TabIndex = 4; | ||||||
|  |             chkBaseline.Text = "Baseline"; | ||||||
|  |             chkBaseline.UseVisualStyleBackColor = true; | ||||||
|  |             chkBaseline.CheckedChanged += Scrolling; | ||||||
|  |             //  | ||||||
|  |             // FontTester | ||||||
|  |             //  | ||||||
|  |             AutoScaleDimensions = new System.Drawing.SizeF(7F, 15F); | ||||||
|  |             AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; | ||||||
|  |             ClientSize = new System.Drawing.Size(284, 251); | ||||||
|  |             Controls.Add(btnCopy); | ||||||
|  |             Controls.Add(chkBaseline); | ||||||
|  |             Controls.Add(cbZoom); | ||||||
|  |             Controls.Add(lblZoom); | ||||||
|  |             Controls.Add(vScroll); | ||||||
|  |             Controls.Add(hScroll); | ||||||
|  |             Controls.Add(dotPanel); | ||||||
|  |             Controls.Add(tbText); | ||||||
|  |             Controls.Add(lblText); | ||||||
|  |             Controls.Add(nudSpace); | ||||||
|  |             Controls.Add(lblSpace); | ||||||
|  |             MaximizeBox = false; | ||||||
|  |             MinimizeBox = false; | ||||||
|  |             MinimumSize = new System.Drawing.Size(300, 290); | ||||||
|  |             Name = "FontTester"; | ||||||
|  |             ShowIcon = false; | ||||||
|  |             ShowInTaskbar = false; | ||||||
|  |             StartPosition = System.Windows.Forms.FormStartPosition.CenterParent; | ||||||
|  |             Text = "Font Tester"; | ||||||
|  |             Load += FontTester_Load; | ||||||
|  |             Resize += Form_Resize; | ||||||
|  |             ((System.ComponentModel.ISupportInitialize)nudSpace).EndInit(); | ||||||
|  |             ResumeLayout(false); | ||||||
|  |             PerformLayout(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         #endregion | ||||||
|  |  | ||||||
|  |         private System.Windows.Forms.Label lblSpace; | ||||||
|  |         private System.Windows.Forms.NumericUpDown nudSpace; | ||||||
|  |         private System.Windows.Forms.Label lblText; | ||||||
|  |         private System.Windows.Forms.TextBox tbText; | ||||||
|  |         private System.Windows.Forms.Panel dotPanel; | ||||||
|  |         private System.Windows.Forms.VScrollBar vScroll; | ||||||
|  |         private System.Windows.Forms.HScrollBar hScroll; | ||||||
|  |         private System.Windows.Forms.Label lblZoom; | ||||||
|  |         private System.Windows.Forms.ToolTip toolTip1; | ||||||
|  |         private System.Windows.Forms.ComboBox cbZoom; | ||||||
|  |         private System.Windows.Forms.CheckBox chkBaseline; | ||||||
|  |         private System.Windows.Forms.Button btnCopy; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										205
									
								
								McBitFont/FontTester.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,205 @@ | |||||||
|  | using MessagePack; | ||||||
|  | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using System.ComponentModel; | ||||||
|  | using System.Data; | ||||||
|  | using System.Drawing; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Runtime.CompilerServices; | ||||||
|  | using System.Text; | ||||||
|  | using System.Threading.Tasks; | ||||||
|  | using System.Windows.Forms; | ||||||
|  |  | ||||||
|  | namespace McBitFont { | ||||||
|  |     public partial class FontTester : Form { | ||||||
|  |  | ||||||
|  |         private int codepage = 1251; | ||||||
|  |         private int height; | ||||||
|  |         private List<MainForm.FrameMiniature> frames; | ||||||
|  |         private int baseline; | ||||||
|  |         private readonly int absentWidth = 5; | ||||||
|  |         private readonly int pixelOffset = 5; | ||||||
|  |  | ||||||
|  |         private int baselineThickness = 1; | ||||||
|  |         private byte[] encoded = []; | ||||||
|  |         private int cellSize; | ||||||
|  |         private int width; | ||||||
|  |  | ||||||
|  |         private readonly DataFormats.Format clpbFormat = DataFormats.GetFormat("McBitFontFrame"); | ||||||
|  |  | ||||||
|  |         public FontTester(int codepage, int height, int baseline, List<MainForm.FrameMiniature> frames) { | ||||||
|  |             InitializeComponent(); | ||||||
|  |             Encoding.RegisterProvider(CodePagesEncodingProvider.Instance); | ||||||
|  |             this.codepage = codepage; | ||||||
|  |             this.height = height; | ||||||
|  |             this.baseline = baseline; | ||||||
|  |             this.frames = frames; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private void FontTester_Load(object sender, EventArgs e) { | ||||||
|  |             cbZoom.SelectedIndex = 2; | ||||||
|  |             //cbZoom.SelectedIndexChanged += ZoomChanged; | ||||||
|  |             dotPanel.MouseWheel += new MouseEventHandler(DotPanel_MouseWheel); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private void PaintPixels(object sender, PaintEventArgs e) { | ||||||
|  |             Graphics g = dotPanel.CreateGraphics(); | ||||||
|  |             SolidBrush sbb = new SolidBrush(Color.Black); | ||||||
|  |             SolidBrush sbw = new SolidBrush(Color.White); | ||||||
|  |             SolidBrush sbp = new SolidBrush(Color.LightPink); | ||||||
|  |             SolidBrush sb; | ||||||
|  |             Pen blackPen = new(Color.Black); | ||||||
|  |             Pen bluePen = new(Color.FromArgb(100, 20, 20, 200), baselineThickness); | ||||||
|  |             int x, y, i, j; | ||||||
|  |  | ||||||
|  |             // Sycle through ecoded bytes of test text | ||||||
|  |             int space = (int)nudSpace.Value; | ||||||
|  |             int index = 0; | ||||||
|  |             for (int c = 0; c < encoded.Length; c++) { | ||||||
|  |                 // Check if we have such symbol | ||||||
|  |                 var f = frames.FindAll(x => x.code == encoded[c]); | ||||||
|  |                 if (f.Count == 1) { | ||||||
|  |                     // Draw the symbol | ||||||
|  |                     for (i = 0; i < f[0].width; i++) { | ||||||
|  |                         x = pixelOffset + (index + i) * cellSize - hScroll.Value; | ||||||
|  |                         for (j = 0; j < f[0].height; j++) { | ||||||
|  |                             y = pixelOffset + j * cellSize - vScroll.Value; | ||||||
|  |                             // Fill the cell with color | ||||||
|  |                             if (f[0].data[i, j]) sb = sbb; | ||||||
|  |                             else sb = sbw; | ||||||
|  |                             g.FillRectangle(sb, x, y, cellSize, cellSize); | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                     index += (f[0].width > 0 ? f[0].width + space : 0); | ||||||
|  |                 } else { | ||||||
|  |                     blackPen.Width = cellSize; | ||||||
|  |                     blackPen.Alignment = System.Drawing.Drawing2D.PenAlignment.Inset; | ||||||
|  |                     x = pixelOffset + index * cellSize - hScroll.Value; | ||||||
|  |                     y = pixelOffset - vScroll.Value; | ||||||
|  |                     g.DrawRectangle(blackPen, x, y + cellSize, absentWidth * cellSize, (height - 2) * cellSize); | ||||||
|  |                     g.FillRectangle(sbp, x + cellSize, y + 2 * cellSize, (absentWidth - 2) * cellSize, (height - 4) * cellSize); | ||||||
|  |                     index += 5 + space; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             // Draw baseline | ||||||
|  |             if (chkBaseline.Checked && baseline > 0) { | ||||||
|  |                 x = pixelOffset - hScroll.Value; | ||||||
|  |                 y = pixelOffset + baseline * cellSize - vScroll.Value; | ||||||
|  |                 g.DrawLine(bluePen, x, y, dotPanel.Width - 2 * pixelOffset, y); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private void Text_Changed(object sender, EventArgs e) { | ||||||
|  |             int space = (int)nudSpace.Value; | ||||||
|  |  | ||||||
|  |             encoded = Encoding.GetEncoding(codepage).GetBytes(tbText.Text); | ||||||
|  |  | ||||||
|  |             width = space > 0 ? space : 1; | ||||||
|  |             for (int c = 0; c < encoded.Length; c++) { | ||||||
|  |                 var f = frames.FindAll(x => x.code == encoded[c]); | ||||||
|  |                 width += (f.Count == 1 ? f[0].width : absentWidth) + space; | ||||||
|  |             } | ||||||
|  |             dotPanel.Invalidate(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private void ZoomChanged(object sender, EventArgs e) { | ||||||
|  |             cellSize = Convert.ToInt32(cbZoom.Text); | ||||||
|  |  | ||||||
|  |             int w = pixelOffset + width * cellSize; | ||||||
|  |             int h = pixelOffset + height * cellSize; | ||||||
|  |  | ||||||
|  |             if (w <= dotPanel.Width) { | ||||||
|  |                 hScroll.Enabled = false; | ||||||
|  |                 hScroll.Value = 0; | ||||||
|  |             } else { | ||||||
|  |                 hScroll.Maximum = w - dotPanel.Width + 12; | ||||||
|  |                 hScroll.Minimum = 0; | ||||||
|  |                 hScroll.Enabled = true; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             if (h <= dotPanel.Height) { | ||||||
|  |                 vScroll.Enabled = false; | ||||||
|  |                 vScroll.Value = 0; | ||||||
|  |             } else { | ||||||
|  |                 vScroll.Maximum = h - dotPanel.Height + 12; | ||||||
|  |                 vScroll.Minimum = 0; | ||||||
|  |                 vScroll.Enabled = true; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             // Baseline thickness calc | ||||||
|  |             baselineThickness = cellSize / 5; | ||||||
|  |             if (baselineThickness > 5) baselineThickness = 5; | ||||||
|  |             if (baselineThickness < 1) baselineThickness = 1; | ||||||
|  |  | ||||||
|  |             dotPanel.Refresh(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private void DotPanel_MouseWheel(object sender, MouseEventArgs e) { | ||||||
|  |             int t = e.Delta / 120; | ||||||
|  |             if (e.Delta == 0) return; | ||||||
|  |             if (ModifierKeys.HasFlag(Keys.Control)) { | ||||||
|  |                 t += cbZoom.SelectedIndex; | ||||||
|  |                 if (t > cbZoom.Items.Count - 1) return; | ||||||
|  |                 if (t < 0) return; | ||||||
|  |                 cbZoom.SelectedIndex = t; | ||||||
|  |             } else if (ModifierKeys.HasFlag(Keys.Shift)) { | ||||||
|  |                 if (hScroll.Enabled) { | ||||||
|  |                     t = t * -1 * cellSize + hScroll.Value; | ||||||
|  |                     if (t < hScroll.Minimum) t = hScroll.Minimum; | ||||||
|  |                     if (t > hScroll.Maximum) t = hScroll.Maximum; | ||||||
|  |                     hScroll.Value = t; | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 if (vScroll.Enabled) { | ||||||
|  |                     t = t * -1 * cellSize + vScroll.Value; | ||||||
|  |                     if (t < vScroll.Minimum) t = vScroll.Minimum; | ||||||
|  |                     if (t > vScroll.Maximum) t = vScroll.Maximum; | ||||||
|  |                     vScroll.Value = t; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private void Scrolling(object sender, EventArgs e) { | ||||||
|  |             dotPanel.Invalidate(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private void Form_Resize(object sender, EventArgs e) { | ||||||
|  |             btnCopy.Left = this.Width / 2 - 40; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private void Copy_Click(object sender, MouseEventArgs e) { | ||||||
|  |             if (encoded.Length < 1) { | ||||||
|  |                 MessageBox.Show("Nothing to copy! Type some symbols first.", "Error!", MessageBoxButtons.OK, MessageBoxIcon.Error); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             // Sycle through ecoded bytes of test text | ||||||
|  |             int space = (int)nudSpace.Value; | ||||||
|  |             int index = 0; | ||||||
|  |             int i, j; | ||||||
|  |             MainForm.FrameMiniature ff = new(0, width, frames[0].height); | ||||||
|  |             for (int c = 0; c < encoded.Length; c++) { | ||||||
|  |                 // Check if we have such symbol | ||||||
|  |                 var f = frames.FindAll(x => x.code == encoded[c]); | ||||||
|  |                 if (f.Count == 1) { | ||||||
|  |                     // Draw the symbol | ||||||
|  |                     for (i = 0; i < f[0].width; i++) { | ||||||
|  |                         for (j = 0; j < f[0].height; j++) { | ||||||
|  |                             // Fill the frame with data | ||||||
|  |                             ff.data[index + i, j] = f[0].data[i, j]; | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                     index += (f[0].width > 0 ? f[0].width + space : 0); | ||||||
|  |                 } else { | ||||||
|  |                     index += 5 + space; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             // Copy the frame we made into Clipboard | ||||||
|  |             var bb = MessagePackSerializer.Serialize(ChangeHistory.CopyFrameSimple(ff)); | ||||||
|  |             DataObject clpbObj = new DataObject(clpbFormat.Name, bb); | ||||||
|  |             Clipboard.SetDataObject(clpbObj, true); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										123
									
								
								McBitFont/FontTester.resx
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,123 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <root> | ||||||
|  |   <!-- | ||||||
|  |     Microsoft ResX Schema | ||||||
|  |  | ||||||
|  |     Version 2.0 | ||||||
|  |  | ||||||
|  |     The primary goals of this format is to allow a simple XML format | ||||||
|  |     that is mostly human readable. The generation and parsing of the | ||||||
|  |     various data types are done through the TypeConverter classes | ||||||
|  |     associated with the data types. | ||||||
|  |  | ||||||
|  |     Example: | ||||||
|  |  | ||||||
|  |     ... ado.net/XML headers & schema ... | ||||||
|  |     <resheader name="resmimetype">text/microsoft-resx</resheader> | ||||||
|  |     <resheader name="version">2.0</resheader> | ||||||
|  |     <resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader> | ||||||
|  |     <resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader> | ||||||
|  |     <data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data> | ||||||
|  |     <data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data> | ||||||
|  |     <data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64"> | ||||||
|  |         <value>[base64 mime encoded serialized .NET Framework object]</value> | ||||||
|  |     </data> | ||||||
|  |     <data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> | ||||||
|  |         <value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value> | ||||||
|  |         <comment>This is a comment</comment> | ||||||
|  |     </data> | ||||||
|  |  | ||||||
|  |     There are any number of "resheader" rows that contain simple | ||||||
|  |     name/value pairs. | ||||||
|  |  | ||||||
|  |     Each data row contains a name, and value. The row also contains a | ||||||
|  |     type or mimetype. Type corresponds to a .NET class that support | ||||||
|  |     text/value conversion through the TypeConverter architecture. | ||||||
|  |     Classes that don't support this are serialized and stored with the | ||||||
|  |     mimetype set. | ||||||
|  |  | ||||||
|  |     The mimetype is used for serialized objects, and tells the | ||||||
|  |     ResXResourceReader how to depersist the object. This is currently not | ||||||
|  |     extensible. For a given mimetype the value must be set accordingly: | ||||||
|  |  | ||||||
|  |     Note - application/x-microsoft.net.object.binary.base64 is the format | ||||||
|  |     that the ResXResourceWriter will generate, however the reader can | ||||||
|  |     read any of the formats listed below. | ||||||
|  |  | ||||||
|  |     mimetype: application/x-microsoft.net.object.binary.base64 | ||||||
|  |     value   : The object must be serialized with | ||||||
|  |             : System.Runtime.Serialization.Formatters.Binary.BinaryFormatter | ||||||
|  |             : and then encoded with base64 encoding. | ||||||
|  |  | ||||||
|  |     mimetype: application/x-microsoft.net.object.soap.base64 | ||||||
|  |     value   : The object must be serialized with | ||||||
|  |             : System.Runtime.Serialization.Formatters.Soap.SoapFormatter | ||||||
|  |             : and then encoded with base64 encoding. | ||||||
|  |  | ||||||
|  |     mimetype: application/x-microsoft.net.object.bytearray.base64 | ||||||
|  |     value   : The object must be serialized into a byte array | ||||||
|  |             : using a System.ComponentModel.TypeConverter | ||||||
|  |             : and then encoded with base64 encoding. | ||||||
|  |     --> | ||||||
|  |   <xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"> | ||||||
|  |     <xsd:import namespace="http://www.w3.org/XML/1998/namespace" /> | ||||||
|  |     <xsd:element name="root" msdata:IsDataSet="true"> | ||||||
|  |       <xsd:complexType> | ||||||
|  |         <xsd:choice maxOccurs="unbounded"> | ||||||
|  |           <xsd:element name="metadata"> | ||||||
|  |             <xsd:complexType> | ||||||
|  |               <xsd:sequence> | ||||||
|  |                 <xsd:element name="value" type="xsd:string" minOccurs="0" /> | ||||||
|  |               </xsd:sequence> | ||||||
|  |               <xsd:attribute name="name" use="required" type="xsd:string" /> | ||||||
|  |               <xsd:attribute name="type" type="xsd:string" /> | ||||||
|  |               <xsd:attribute name="mimetype" type="xsd:string" /> | ||||||
|  |               <xsd:attribute ref="xml:space" /> | ||||||
|  |             </xsd:complexType> | ||||||
|  |           </xsd:element> | ||||||
|  |           <xsd:element name="assembly"> | ||||||
|  |             <xsd:complexType> | ||||||
|  |               <xsd:attribute name="alias" type="xsd:string" /> | ||||||
|  |               <xsd:attribute name="name" type="xsd:string" /> | ||||||
|  |             </xsd:complexType> | ||||||
|  |           </xsd:element> | ||||||
|  |           <xsd:element name="data"> | ||||||
|  |             <xsd:complexType> | ||||||
|  |               <xsd:sequence> | ||||||
|  |                 <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" /> | ||||||
|  |                 <xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" /> | ||||||
|  |               </xsd:sequence> | ||||||
|  |               <xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" /> | ||||||
|  |               <xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" /> | ||||||
|  |               <xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" /> | ||||||
|  |               <xsd:attribute ref="xml:space" /> | ||||||
|  |             </xsd:complexType> | ||||||
|  |           </xsd:element> | ||||||
|  |           <xsd:element name="resheader"> | ||||||
|  |             <xsd:complexType> | ||||||
|  |               <xsd:sequence> | ||||||
|  |                 <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" /> | ||||||
|  |               </xsd:sequence> | ||||||
|  |               <xsd:attribute name="name" type="xsd:string" use="required" /> | ||||||
|  |             </xsd:complexType> | ||||||
|  |           </xsd:element> | ||||||
|  |         </xsd:choice> | ||||||
|  |       </xsd:complexType> | ||||||
|  |     </xsd:element> | ||||||
|  |   </xsd:schema> | ||||||
|  |   <resheader name="resmimetype"> | ||||||
|  |     <value>text/microsoft-resx</value> | ||||||
|  |   </resheader> | ||||||
|  |   <resheader name="version"> | ||||||
|  |     <value>2.0</value> | ||||||
|  |   </resheader> | ||||||
|  |   <resheader name="reader"> | ||||||
|  |     <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | ||||||
|  |   </resheader> | ||||||
|  |   <resheader name="writer"> | ||||||
|  |     <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | ||||||
|  |   </resheader> | ||||||
|  |   <metadata name="toolTip1.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"> | ||||||
|  |     <value>17, 17</value> | ||||||
|  |   </metadata> | ||||||
|  | </root> | ||||||
							
								
								
									
										486
									
								
								McBitFont/Form1.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						| @@ -28,12 +28,13 @@ | |||||||
|             dotPanel = new System.Windows.Forms.Panel(); |             dotPanel = new System.Windows.Forms.Panel(); | ||||||
|             nudX = new System.Windows.Forms.NumericUpDown(); |             nudX = new System.Windows.Forms.NumericUpDown(); | ||||||
|             nudY = new System.Windows.Forms.NumericUpDown(); |             nudY = new System.Windows.Forms.NumericUpDown(); | ||||||
|             label1 = new System.Windows.Forms.Label(); |             lblWidth = new System.Windows.Forms.Label(); | ||||||
|             label2 = new System.Windows.Forms.Label(); |             lblHeight = new System.Windows.Forms.Label(); | ||||||
|             lblType = new System.Windows.Forms.Label(); |             lblType = new System.Windows.Forms.Label(); | ||||||
|             cbZoom = new System.Windows.Forms.ComboBox(); |             cbZoom = new System.Windows.Forms.ComboBox(); | ||||||
|             label4 = new System.Windows.Forms.Label(); |             label4 = new System.Windows.Forms.Label(); | ||||||
|             panel1 = new System.Windows.Forms.Panel(); |             panel1 = new System.Windows.Forms.Panel(); | ||||||
|  |             tbFrameNote = new System.Windows.Forms.TextBox(); | ||||||
|             btnFill = new System.Windows.Forms.Button(); |             btnFill = new System.Windows.Forms.Button(); | ||||||
|             btnClear = new System.Windows.Forms.Button(); |             btnClear = new System.Windows.Forms.Button(); | ||||||
|             btnMirrorY = new System.Windows.Forms.Button(); |             btnMirrorY = new System.Windows.Forms.Button(); | ||||||
| @@ -64,9 +65,13 @@ | |||||||
|             openToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             openToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             saveToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             saveToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             saveAsToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             saveAsToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|  |             toolStripSeparator1 = new System.Windows.Forms.ToolStripSeparator(); | ||||||
|             importTextToolStripMenuItem1 = new System.Windows.Forms.ToolStripMenuItem(); |             importTextToolStripMenuItem1 = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             importImageToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             importImageToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             exportToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             exportToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|  |             exportFontLayoutPNGToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|  |             frameScreenshotToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|  |             toolStripSeparator2 = new System.Windows.Forms.ToolStripSeparator(); | ||||||
|             exitToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             exitToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             editToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             editToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             undoToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             undoToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
| @@ -74,6 +79,7 @@ | |||||||
|             copyToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             copyToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             pasteToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             pasteToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             selectToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             selectToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|  |             selectAllToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             fontToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             fontToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             makeVarWidthToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             makeVarWidthToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             prependSymbolToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             prependSymbolToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
| @@ -81,7 +87,13 @@ | |||||||
|             removeSymbolToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             removeSymbolToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             removeBeforeToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             removeBeforeToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             removeAfterToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             removeAfterToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|  |             zerofyWidthToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             CodeShiftToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             CodeShiftToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|  |             toolStripSeparator3 = new System.Windows.Forms.ToolStripSeparator(); | ||||||
|  |             previousSymbolToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|  |             nextSymbolToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|  |             toolStripSeparator4 = new System.Windows.Forms.ToolStripSeparator(); | ||||||
|  |             testFontToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             canvasToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             canvasToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             ClearToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             ClearToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             FillToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             FillToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
| @@ -94,6 +106,7 @@ | |||||||
|             mirrorYToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             mirrorYToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             applyToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             applyToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             aboutToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); |             aboutToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|  |             toggleBarToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||||
|             dlgSave = new System.Windows.Forms.SaveFileDialog(); |             dlgSave = new System.Windows.Forms.SaveFileDialog(); | ||||||
|             dlgOpen = new System.Windows.Forms.OpenFileDialog(); |             dlgOpen = new System.Windows.Forms.OpenFileDialog(); | ||||||
|             btnBaseline = new System.Windows.Forms.Button(); |             btnBaseline = new System.Windows.Forms.Button(); | ||||||
| @@ -102,12 +115,23 @@ | |||||||
|             chkTopSide = new System.Windows.Forms.CheckBox(); |             chkTopSide = new System.Windows.Forms.CheckBox(); | ||||||
|             chkHexCodes = new System.Windows.Forms.CheckBox(); |             chkHexCodes = new System.Windows.Forms.CheckBox(); | ||||||
|             chkRectSelect = new System.Windows.Forms.CheckBox(); |             chkRectSelect = new System.Windows.Forms.CheckBox(); | ||||||
|  |             nudBrush = new System.Windows.Forms.NumericUpDown(); | ||||||
|             label3 = new System.Windows.Forms.Label(); |             label3 = new System.Windows.Forms.Label(); | ||||||
|  |             lblSelectionLabel = new System.Windows.Forms.Label(); | ||||||
|  |             lblSelection = new System.Windows.Forms.Label(); | ||||||
|  |             lblModified = new System.Windows.Forms.Label(); | ||||||
|  |             dlgSavePNG = new System.Windows.Forms.SaveFileDialog(); | ||||||
|  |             pnlRightButtons = new System.Windows.Forms.Panel(); | ||||||
|  |             lblBrush = new System.Windows.Forms.Label(); | ||||||
|  |             pnlInfo = new System.Windows.Forms.Panel(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)nudX).BeginInit(); |             ((System.ComponentModel.ISupportInitialize)nudX).BeginInit(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)nudY).BeginInit(); |             ((System.ComponentModel.ISupportInitialize)nudY).BeginInit(); | ||||||
|             panel1.SuspendLayout(); |             panel1.SuspendLayout(); | ||||||
|             cmMinilist.SuspendLayout(); |             cmMinilist.SuspendLayout(); | ||||||
|             menuStrip1.SuspendLayout(); |             menuStrip1.SuspendLayout(); | ||||||
|  |             ((System.ComponentModel.ISupportInitialize)nudBrush).BeginInit(); | ||||||
|  |             pnlRightButtons.SuspendLayout(); | ||||||
|  |             pnlInfo.SuspendLayout(); | ||||||
|             SuspendLayout(); |             SuspendLayout(); | ||||||
|             //  |             //  | ||||||
|             // dotPanel |             // dotPanel | ||||||
| @@ -127,8 +151,7 @@ | |||||||
|             //  |             //  | ||||||
|             // nudX |             // nudX | ||||||
|             //  |             //  | ||||||
|             nudX.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |             nudX.Location = new System.Drawing.Point(59, 3); | ||||||
|             nudX.Location = new System.Drawing.Point(777, 31); |  | ||||||
|             nudX.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             nudX.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             nudX.Maximum = new decimal(new int[] { 255, 0, 0, 0 }); |             nudX.Maximum = new decimal(new int[] { 255, 0, 0, 0 }); | ||||||
|             nudX.Name = "nudX"; |             nudX.Name = "nudX"; | ||||||
| @@ -140,8 +163,7 @@ | |||||||
|             //  |             //  | ||||||
|             // nudY |             // nudY | ||||||
|             //  |             //  | ||||||
|             nudY.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |             nudY.Location = new System.Drawing.Point(59, 27); | ||||||
|             nudY.Location = new System.Drawing.Point(777, 57); |  | ||||||
|             nudY.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             nudY.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             nudY.Maximum = new decimal(new int[] { 255, 0, 0, 0 }); |             nudY.Maximum = new decimal(new int[] { 255, 0, 0, 0 }); | ||||||
|             nudY.Minimum = new decimal(new int[] { 1, 0, 0, 0 }); |             nudY.Minimum = new decimal(new int[] { 1, 0, 0, 0 }); | ||||||
| @@ -152,32 +174,29 @@ | |||||||
|             nudY.Value = new decimal(new int[] { 32, 0, 0, 0 }); |             nudY.Value = new decimal(new int[] { 32, 0, 0, 0 }); | ||||||
|             nudY.ValueChanged += nudY_ValueChanged; |             nudY.ValueChanged += nudY_ValueChanged; | ||||||
|             //  |             //  | ||||||
|             // label1 |             // lblWidth | ||||||
|             //  |             //  | ||||||
|             label1.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |             lblWidth.AutoSize = true; | ||||||
|             label1.AutoSize = true; |             lblWidth.Location = new System.Drawing.Point(8, 5); | ||||||
|             label1.Location = new System.Drawing.Point(726, 33); |             lblWidth.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); | ||||||
|             label1.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); |             lblWidth.Name = "lblWidth"; | ||||||
|             label1.Name = "label1"; |             lblWidth.Size = new System.Drawing.Size(42, 15); | ||||||
|             label1.Size = new System.Drawing.Size(42, 15); |             lblWidth.TabIndex = 3; | ||||||
|             label1.TabIndex = 3; |             lblWidth.Text = "Width:"; | ||||||
|             label1.Text = "Width:"; |  | ||||||
|             //  |             //  | ||||||
|             // label2 |             // lblHeight | ||||||
|             //  |             //  | ||||||
|             label2.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |             lblHeight.AutoSize = true; | ||||||
|             label2.AutoSize = true; |             lblHeight.Location = new System.Drawing.Point(4, 29); | ||||||
|             label2.Location = new System.Drawing.Point(722, 59); |             lblHeight.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); | ||||||
|             label2.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); |             lblHeight.Name = "lblHeight"; | ||||||
|             label2.Name = "label2"; |             lblHeight.Size = new System.Drawing.Size(46, 15); | ||||||
|             label2.Size = new System.Drawing.Size(46, 15); |             lblHeight.TabIndex = 4; | ||||||
|             label2.TabIndex = 4; |             lblHeight.Text = "Height:"; | ||||||
|             label2.Text = "Height:"; |  | ||||||
|             //  |             //  | ||||||
|             // lblType |             // lblType | ||||||
|             //  |             //  | ||||||
|             lblType.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |             lblType.Location = new System.Drawing.Point(2, 136); | ||||||
|             lblType.Location = new System.Drawing.Point(718, 159); |  | ||||||
|             lblType.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); |             lblType.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); | ||||||
|             lblType.Name = "lblType"; |             lblType.Name = "lblType"; | ||||||
|             lblType.Size = new System.Drawing.Size(181, 15); |             lblType.Size = new System.Drawing.Size(181, 15); | ||||||
| @@ -191,19 +210,19 @@ | |||||||
|             cbZoom.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList; |             cbZoom.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList; | ||||||
|             cbZoom.FormattingEnabled = true; |             cbZoom.FormattingEnabled = true; | ||||||
|             cbZoom.Items.AddRange(new object[] { "2", "3", "5", "10", "15", "20", "25", "30", "35", "40", "45", "50" }); |             cbZoom.Items.AddRange(new object[] { "2", "3", "5", "10", "15", "20", "25", "30", "35", "40", "45", "50" }); | ||||||
|             cbZoom.Location = new System.Drawing.Point(619, 52); |             cbZoom.Location = new System.Drawing.Point(7, 28); | ||||||
|             cbZoom.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             cbZoom.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             cbZoom.Name = "cbZoom"; |             cbZoom.Name = "cbZoom"; | ||||||
|             cbZoom.Size = new System.Drawing.Size(75, 23); |             cbZoom.Size = new System.Drawing.Size(75, 23); | ||||||
|             cbZoom.TabIndex = 6; |             cbZoom.TabIndex = 6; | ||||||
|             cbZoom.TabStop = false; |             cbZoom.TabStop = false; | ||||||
|             toolTip1.SetToolTip(cbZoom, "Canvas zoom level"); |             toolTip1.SetToolTip(cbZoom, "Canvas zoom level (Ctrl+Scroll)"); | ||||||
|             //  |             //  | ||||||
|             // label4 |             // label4 | ||||||
|             //  |             //  | ||||||
|             label4.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |             label4.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; | ||||||
|             label4.AutoSize = true; |             label4.AutoSize = true; | ||||||
|             label4.Location = new System.Drawing.Point(618, 33); |             label4.Location = new System.Drawing.Point(6, 9); | ||||||
|             label4.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); |             label4.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); | ||||||
|             label4.Name = "label4"; |             label4.Name = "label4"; | ||||||
|             label4.Size = new System.Drawing.Size(69, 15); |             label4.Size = new System.Drawing.Size(69, 15); | ||||||
| @@ -213,7 +232,7 @@ | |||||||
|             // panel1 |             // panel1 | ||||||
|             //  |             //  | ||||||
|             panel1.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |             panel1.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; | ||||||
|             panel1.BorderStyle = System.Windows.Forms.BorderStyle.FixedSingle; |             panel1.Controls.Add(tbFrameNote); | ||||||
|             panel1.Controls.Add(btnFill); |             panel1.Controls.Add(btnFill); | ||||||
|             panel1.Controls.Add(btnClear); |             panel1.Controls.Add(btnClear); | ||||||
|             panel1.Controls.Add(btnMirrorY); |             panel1.Controls.Add(btnMirrorY); | ||||||
| @@ -223,47 +242,58 @@ | |||||||
|             panel1.Controls.Add(btnShiftUp); |             panel1.Controls.Add(btnShiftUp); | ||||||
|             panel1.Controls.Add(btnShiftRight); |             panel1.Controls.Add(btnShiftRight); | ||||||
|             panel1.Controls.Add(btnShiftLeft); |             panel1.Controls.Add(btnShiftLeft); | ||||||
|             panel1.Location = new System.Drawing.Point(472, 31); |             panel1.Location = new System.Drawing.Point(472, 24); | ||||||
|             panel1.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             panel1.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             panel1.Name = "panel1"; |             panel1.Name = "panel1"; | ||||||
|             panel1.Size = new System.Drawing.Size(140, 139); |             panel1.Size = new System.Drawing.Size(140, 154); | ||||||
|             panel1.TabIndex = 9; |             panel1.TabIndex = 9; | ||||||
|             //  |             //  | ||||||
|  |             // tbFrameNote | ||||||
|  |             //  | ||||||
|  |             tbFrameNote.Location = new System.Drawing.Point(7, 127); | ||||||
|  |             tbFrameNote.Name = "tbFrameNote"; | ||||||
|  |             tbFrameNote.PlaceholderText = "Frame note"; | ||||||
|  |             tbFrameNote.Size = new System.Drawing.Size(119, 23); | ||||||
|  |             tbFrameNote.TabIndex = 9; | ||||||
|  |             toolTip1.SetToolTip(tbFrameNote, "Frame note"); | ||||||
|  |             tbFrameNote.WordWrap = false; | ||||||
|  |             tbFrameNote.TextChanged += tbFrameNote_TextChanged; | ||||||
|  |             //  | ||||||
|             // btnFill |             // btnFill | ||||||
|             //  |             //  | ||||||
|             btnFill.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnFill.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|             btnFill.Location = new System.Drawing.Point(92, 9); |             btnFill.Image = Properties.Resources.Canvas_Fill; | ||||||
|  |             btnFill.Location = new System.Drawing.Point(91, 3); | ||||||
|             btnFill.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnFill.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnFill.Name = "btnFill"; |             btnFill.Name = "btnFill"; | ||||||
|             btnFill.Size = new System.Drawing.Size(35, 35); |             btnFill.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnFill.TabIndex = 8; |             btnFill.TabIndex = 8; | ||||||
|             btnFill.Text = "⬤"; |             toolTip1.SetToolTip(btnFill, "Paint canvas black (Ctrl+B)"); | ||||||
|             toolTip1.SetToolTip(btnFill, "Paint canvas black"); |  | ||||||
|             btnFill.UseVisualStyleBackColor = true; |             btnFill.UseVisualStyleBackColor = true; | ||||||
|             btnFill.Click += btnFill_Click; |             btnFill.Click += btnFill_Click; | ||||||
|             //  |             //  | ||||||
|             // btnClear |             // btnClear | ||||||
|             //  |             //  | ||||||
|             btnClear.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnClear.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|             btnClear.Location = new System.Drawing.Point(8, 9); |             btnClear.Image = Properties.Resources.Canvas_Clear; | ||||||
|  |             btnClear.Location = new System.Drawing.Point(7, 3); | ||||||
|             btnClear.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnClear.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnClear.Name = "btnClear"; |             btnClear.Name = "btnClear"; | ||||||
|             btnClear.Size = new System.Drawing.Size(35, 35); |             btnClear.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnClear.TabIndex = 7; |             btnClear.TabIndex = 7; | ||||||
|             btnClear.Text = "○"; |             toolTip1.SetToolTip(btnClear, "Paint canvas white (Ctrl+W)"); | ||||||
|             toolTip1.SetToolTip(btnClear, "Paint canvas white"); |  | ||||||
|             btnClear.UseVisualStyleBackColor = true; |             btnClear.UseVisualStyleBackColor = true; | ||||||
|             btnClear.Click += btnClear_Click; |             btnClear.Click += btnClear_Click; | ||||||
|             //  |             //  | ||||||
|             // btnMirrorY |             // btnMirrorY | ||||||
|             //  |             //  | ||||||
|             btnMirrorY.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnMirrorY.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|             btnMirrorY.Location = new System.Drawing.Point(92, 92); |             btnMirrorY.Image = Properties.Resources.Famfamfam_Silk_Shape_flip_vertical_16; | ||||||
|  |             btnMirrorY.Location = new System.Drawing.Point(91, 86); | ||||||
|             btnMirrorY.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnMirrorY.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnMirrorY.Name = "btnMirrorY"; |             btnMirrorY.Name = "btnMirrorY"; | ||||||
|             btnMirrorY.Size = new System.Drawing.Size(35, 35); |             btnMirrorY.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnMirrorY.TabIndex = 6; |             btnMirrorY.TabIndex = 6; | ||||||
|             btnMirrorY.Text = "⩥"; |  | ||||||
|             toolTip1.SetToolTip(btnMirrorY, "Mirror by Y axis (vertical)"); |             toolTip1.SetToolTip(btnMirrorY, "Mirror by Y axis (vertical)"); | ||||||
|             btnMirrorY.UseVisualStyleBackColor = true; |             btnMirrorY.UseVisualStyleBackColor = true; | ||||||
|             btnMirrorY.Click += btnMirrorY_Click; |             btnMirrorY.Click += btnMirrorY_Click; | ||||||
| @@ -271,12 +301,12 @@ | |||||||
|             // btnMirrorX |             // btnMirrorX | ||||||
|             //  |             //  | ||||||
|             btnMirrorX.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnMirrorX.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|             btnMirrorX.Location = new System.Drawing.Point(50, 92); |             btnMirrorX.Image = Properties.Resources.Famfamfam_Silk_Shape_flip_horizontal_16; | ||||||
|  |             btnMirrorX.Location = new System.Drawing.Point(49, 86); | ||||||
|             btnMirrorX.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnMirrorX.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnMirrorX.Name = "btnMirrorX"; |             btnMirrorX.Name = "btnMirrorX"; | ||||||
|             btnMirrorX.Size = new System.Drawing.Size(35, 35); |             btnMirrorX.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnMirrorX.TabIndex = 5; |             btnMirrorX.TabIndex = 5; | ||||||
|             btnMirrorX.Text = "◮"; |  | ||||||
|             toolTip1.SetToolTip(btnMirrorX, "Mirror by X axis (horizontal)"); |             toolTip1.SetToolTip(btnMirrorX, "Mirror by X axis (horizontal)"); | ||||||
|             btnMirrorX.UseVisualStyleBackColor = true; |             btnMirrorX.UseVisualStyleBackColor = true; | ||||||
|             btnMirrorX.Click += btnMirrorX_Click; |             btnMirrorX.Click += btnMirrorX_Click; | ||||||
| @@ -284,73 +314,72 @@ | |||||||
|             // btnInvert |             // btnInvert | ||||||
|             //  |             //  | ||||||
|             btnInvert.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnInvert.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|             btnInvert.Location = new System.Drawing.Point(8, 92); |             btnInvert.Image = Properties.Resources.z_contrast; | ||||||
|  |             btnInvert.Location = new System.Drawing.Point(7, 86); | ||||||
|             btnInvert.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnInvert.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnInvert.Name = "btnInvert"; |             btnInvert.Name = "btnInvert"; | ||||||
|             btnInvert.Size = new System.Drawing.Size(35, 35); |             btnInvert.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnInvert.TabIndex = 4; |             btnInvert.TabIndex = 4; | ||||||
|             btnInvert.Text = "◪"; |             toolTip1.SetToolTip(btnInvert, "Invert pixel colors (Ctrl+I)"); | ||||||
|             toolTip1.SetToolTip(btnInvert, "Invert pixel colors"); |  | ||||||
|             btnInvert.UseVisualStyleBackColor = true; |             btnInvert.UseVisualStyleBackColor = true; | ||||||
|             btnInvert.Click += btnInvert_Click; |             btnInvert.Click += btnInvert_Click; | ||||||
|             //  |             //  | ||||||
|             // btnShiftDown |             // btnShiftDown | ||||||
|             //  |             //  | ||||||
|             btnShiftDown.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnShiftDown.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|             btnShiftDown.Location = new System.Drawing.Point(50, 51); |             btnShiftDown.Image = Properties.Resources.z_down; | ||||||
|  |             btnShiftDown.Location = new System.Drawing.Point(49, 45); | ||||||
|             btnShiftDown.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnShiftDown.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnShiftDown.Name = "btnShiftDown"; |             btnShiftDown.Name = "btnShiftDown"; | ||||||
|             btnShiftDown.Size = new System.Drawing.Size(35, 35); |             btnShiftDown.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnShiftDown.TabIndex = 3; |             btnShiftDown.TabIndex = 3; | ||||||
|             btnShiftDown.Text = "▼"; |             toolTip1.SetToolTip(btnShiftDown, "Shift pixels down (Ctrl+Down)"); | ||||||
|             toolTip1.SetToolTip(btnShiftDown, "Shift pixels down"); |  | ||||||
|             btnShiftDown.UseVisualStyleBackColor = true; |             btnShiftDown.UseVisualStyleBackColor = true; | ||||||
|             btnShiftDown.Click += btnShiftDown_Click; |             btnShiftDown.Click += btnShiftDown_Click; | ||||||
|             //  |             //  | ||||||
|             // btnShiftUp |             // btnShiftUp | ||||||
|             //  |             //  | ||||||
|             btnShiftUp.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnShiftUp.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|             btnShiftUp.Location = new System.Drawing.Point(50, 9); |             btnShiftUp.Image = Properties.Resources.z_uo; | ||||||
|  |             btnShiftUp.Location = new System.Drawing.Point(49, 3); | ||||||
|             btnShiftUp.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnShiftUp.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnShiftUp.Name = "btnShiftUp"; |             btnShiftUp.Name = "btnShiftUp"; | ||||||
|             btnShiftUp.Size = new System.Drawing.Size(35, 35); |             btnShiftUp.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnShiftUp.TabIndex = 2; |             btnShiftUp.TabIndex = 2; | ||||||
|             btnShiftUp.Text = "▲"; |             toolTip1.SetToolTip(btnShiftUp, "Shift pixels up (Ctrl+Up)"); | ||||||
|             toolTip1.SetToolTip(btnShiftUp, "Shift pixels up"); |  | ||||||
|             btnShiftUp.UseVisualStyleBackColor = true; |             btnShiftUp.UseVisualStyleBackColor = true; | ||||||
|             btnShiftUp.Click += btnShiftUp_Click; |             btnShiftUp.Click += btnShiftUp_Click; | ||||||
|             //  |             //  | ||||||
|             // btnShiftRight |             // btnShiftRight | ||||||
|             //  |             //  | ||||||
|             btnShiftRight.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnShiftRight.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|             btnShiftRight.Location = new System.Drawing.Point(92, 51); |             btnShiftRight.Image = Properties.Resources.z_right; | ||||||
|  |             btnShiftRight.Location = new System.Drawing.Point(91, 45); | ||||||
|             btnShiftRight.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnShiftRight.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnShiftRight.Name = "btnShiftRight"; |             btnShiftRight.Name = "btnShiftRight"; | ||||||
|             btnShiftRight.Size = new System.Drawing.Size(35, 35); |             btnShiftRight.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnShiftRight.TabIndex = 1; |             btnShiftRight.TabIndex = 1; | ||||||
|             btnShiftRight.Text = "▶"; |             toolTip1.SetToolTip(btnShiftRight, "Shift pixels right (Ctrl+Right)"); | ||||||
|             toolTip1.SetToolTip(btnShiftRight, "Shift pixels right"); |  | ||||||
|             btnShiftRight.UseVisualStyleBackColor = true; |             btnShiftRight.UseVisualStyleBackColor = true; | ||||||
|             btnShiftRight.Click += btnShiftRight_Click; |             btnShiftRight.Click += btnShiftRight_Click; | ||||||
|             //  |             //  | ||||||
|             // btnShiftLeft |             // btnShiftLeft | ||||||
|             //  |             //  | ||||||
|             btnShiftLeft.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnShiftLeft.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|             btnShiftLeft.Location = new System.Drawing.Point(8, 51); |             btnShiftLeft.Image = Properties.Resources.z_left; | ||||||
|  |             btnShiftLeft.Location = new System.Drawing.Point(7, 45); | ||||||
|             btnShiftLeft.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnShiftLeft.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnShiftLeft.Name = "btnShiftLeft"; |             btnShiftLeft.Name = "btnShiftLeft"; | ||||||
|             btnShiftLeft.Size = new System.Drawing.Size(35, 35); |             btnShiftLeft.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnShiftLeft.TabIndex = 0; |             btnShiftLeft.TabIndex = 0; | ||||||
|             btnShiftLeft.Text = "◀"; |             toolTip1.SetToolTip(btnShiftLeft, "Shift pixels left (Ctrl+Left)"); | ||||||
|             toolTip1.SetToolTip(btnShiftLeft, "Shift pixels left"); |  | ||||||
|             btnShiftLeft.UseVisualStyleBackColor = true; |             btnShiftLeft.UseVisualStyleBackColor = true; | ||||||
|             btnShiftLeft.Click += btnShiftLeft_Click; |             btnShiftLeft.Click += btnShiftLeft_Click; | ||||||
|             //  |             //  | ||||||
|             // btnExport |             // btnExport | ||||||
|             //  |             //  | ||||||
|             btnExport.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |  | ||||||
|             btnExport.Image = Properties.Resources.z_export; |             btnExport.Image = Properties.Resources.z_export; | ||||||
|             btnExport.Location = new System.Drawing.Point(812, 126); |             btnExport.Location = new System.Drawing.Point(94, 109); | ||||||
|             btnExport.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnExport.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnExport.Name = "btnExport"; |             btnExport.Name = "btnExport"; | ||||||
|             btnExport.Size = new System.Drawing.Size(88, 27); |             btnExport.Size = new System.Drawing.Size(88, 27); | ||||||
| @@ -358,9 +387,9 @@ | |||||||
|             btnExport.Text = " Export"; |             btnExport.Text = " Export"; | ||||||
|             btnExport.TextAlign = System.Drawing.ContentAlignment.MiddleRight; |             btnExport.TextAlign = System.Drawing.ContentAlignment.MiddleRight; | ||||||
|             btnExport.TextImageRelation = System.Windows.Forms.TextImageRelation.ImageBeforeText; |             btnExport.TextImageRelation = System.Windows.Forms.TextImageRelation.ImageBeforeText; | ||||||
|             toolTip1.SetToolTip(btnExport, "Configure and export data"); |             toolTip1.SetToolTip(btnExport, "Configure and export data (Ctrl+E)"); | ||||||
|             btnExport.UseVisualStyleBackColor = true; |             btnExport.UseVisualStyleBackColor = true; | ||||||
|             btnExport.Click += button1_Click; |             btnExport.Click += Export_Click; | ||||||
|             //  |             //  | ||||||
|             // miniList |             // miniList | ||||||
|             //  |             //  | ||||||
| @@ -375,6 +404,7 @@ | |||||||
|             miniList.MultiSelect = false; |             miniList.MultiSelect = false; | ||||||
|             miniList.Name = "miniList"; |             miniList.Name = "miniList"; | ||||||
|             miniList.ShowGroups = false; |             miniList.ShowGroups = false; | ||||||
|  |             miniList.ShowItemToolTips = true; | ||||||
|             miniList.Size = new System.Drawing.Size(427, 455); |             miniList.Size = new System.Drawing.Size(427, 455); | ||||||
|             miniList.SmallImageList = ilMiniatures; |             miniList.SmallImageList = ilMiniatures; | ||||||
|             miniList.Sorting = System.Windows.Forms.SortOrder.Ascending; |             miniList.Sorting = System.Windows.Forms.SortOrder.Ascending; | ||||||
| @@ -466,9 +496,8 @@ | |||||||
|             //  |             //  | ||||||
|             // btnApply |             // btnApply | ||||||
|             //  |             //  | ||||||
|             btnApply.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |  | ||||||
|             btnApply.Image = Properties.Resources.z_tick; |             btnApply.Image = Properties.Resources.z_tick; | ||||||
|             btnApply.Location = new System.Drawing.Point(718, 126); |             btnApply.Location = new System.Drawing.Point(4, 109); | ||||||
|             btnApply.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnApply.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnApply.Name = "btnApply"; |             btnApply.Name = "btnApply"; | ||||||
|             btnApply.Size = new System.Drawing.Size(88, 27); |             btnApply.Size = new System.Drawing.Size(88, 27); | ||||||
| @@ -476,14 +505,17 @@ | |||||||
|             btnApply.Text = " Apply"; |             btnApply.Text = " Apply"; | ||||||
|             btnApply.TextAlign = System.Drawing.ContentAlignment.MiddleRight; |             btnApply.TextAlign = System.Drawing.ContentAlignment.MiddleRight; | ||||||
|             btnApply.TextImageRelation = System.Windows.Forms.TextImageRelation.ImageBeforeText; |             btnApply.TextImageRelation = System.Windows.Forms.TextImageRelation.ImageBeforeText; | ||||||
|             toolTip1.SetToolTip(btnApply, "Apply changes made to the symbol"); |             toolTip1.SetToolTip(btnApply, "Apply changes made to the symbol (Ctrl+Space)"); | ||||||
|             btnApply.UseVisualStyleBackColor = true; |             btnApply.UseVisualStyleBackColor = true; | ||||||
|             btnApply.Click += button2_Click; |             btnApply.Click += button2_Click; | ||||||
|             //  |             //  | ||||||
|             // hScroll |             // hScroll | ||||||
|             //  |             //  | ||||||
|             hScroll.Anchor = System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left | System.Windows.Forms.AnchorStyles.Right; |             hScroll.Anchor = System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left | System.Windows.Forms.AnchorStyles.Right; | ||||||
|  |             hScroll.Enabled = false; | ||||||
|  |             hScroll.LargeChange = 2; | ||||||
|             hScroll.Location = new System.Drawing.Point(14, 609); |             hScroll.Location = new System.Drawing.Point(14, 609); | ||||||
|  |             hScroll.Maximum = 1; | ||||||
|             hScroll.Name = "hScroll"; |             hScroll.Name = "hScroll"; | ||||||
|             hScroll.Size = new System.Drawing.Size(427, 21); |             hScroll.Size = new System.Drawing.Size(427, 21); | ||||||
|             hScroll.TabIndex = 14; |             hScroll.TabIndex = 14; | ||||||
| @@ -492,8 +524,10 @@ | |||||||
|             // vScroll |             // vScroll | ||||||
|             //  |             //  | ||||||
|             vScroll.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right; |             vScroll.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right; | ||||||
|             vScroll.LargeChange = 25; |             vScroll.Enabled = false; | ||||||
|  |             vScroll.LargeChange = 2; | ||||||
|             vScroll.Location = new System.Drawing.Point(444, 31); |             vScroll.Location = new System.Drawing.Point(444, 31); | ||||||
|  |             vScroll.Maximum = 1; | ||||||
|             vScroll.Name = "vScroll"; |             vScroll.Name = "vScroll"; | ||||||
|             vScroll.Size = new System.Drawing.Size(21, 575); |             vScroll.Size = new System.Drawing.Size(21, 575); | ||||||
|             vScroll.TabIndex = 15; |             vScroll.TabIndex = 15; | ||||||
| @@ -503,7 +537,7 @@ | |||||||
|             //  |             //  | ||||||
|             lblCoords.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |             lblCoords.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; | ||||||
|             lblCoords.AutoSize = true; |             lblCoords.AutoSize = true; | ||||||
|             lblCoords.Location = new System.Drawing.Point(616, 138); |             lblCoords.Location = new System.Drawing.Point(4, 114); | ||||||
|             lblCoords.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); |             lblCoords.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); | ||||||
|             lblCoords.Name = "lblCoords"; |             lblCoords.Name = "lblCoords"; | ||||||
|             lblCoords.Size = new System.Drawing.Size(24, 15); |             lblCoords.Size = new System.Drawing.Size(24, 15); | ||||||
| @@ -513,7 +547,7 @@ | |||||||
|             //  |             //  | ||||||
|             // menuStrip1 |             // menuStrip1 | ||||||
|             //  |             //  | ||||||
|             menuStrip1.Items.AddRange(new System.Windows.Forms.ToolStripItem[] { fileToolStripMenuItem, editToolStripMenuItem, fontToolStripMenuItem, canvasToolStripMenuItem, aboutToolStripMenuItem }); |             menuStrip1.Items.AddRange(new System.Windows.Forms.ToolStripItem[] { fileToolStripMenuItem, editToolStripMenuItem, fontToolStripMenuItem, canvasToolStripMenuItem, aboutToolStripMenuItem, toggleBarToolStripMenuItem }); | ||||||
|             menuStrip1.Location = new System.Drawing.Point(0, 0); |             menuStrip1.Location = new System.Drawing.Point(0, 0); | ||||||
|             menuStrip1.Name = "menuStrip1"; |             menuStrip1.Name = "menuStrip1"; | ||||||
|             menuStrip1.Padding = new System.Windows.Forms.Padding(7, 2, 0, 2); |             menuStrip1.Padding = new System.Windows.Forms.Padding(7, 2, 0, 2); | ||||||
| @@ -523,7 +557,7 @@ | |||||||
|             //  |             //  | ||||||
|             // fileToolStripMenuItem |             // fileToolStripMenuItem | ||||||
|             //  |             //  | ||||||
|             fileToolStripMenuItem.DropDownItems.AddRange(new System.Windows.Forms.ToolStripItem[] { newToolStripMenuItem, openToolStripMenuItem, saveToolStripMenuItem, saveAsToolStripMenuItem, importTextToolStripMenuItem1, importImageToolStripMenuItem, exportToolStripMenuItem, exitToolStripMenuItem }); |             fileToolStripMenuItem.DropDownItems.AddRange(new System.Windows.Forms.ToolStripItem[] { newToolStripMenuItem, openToolStripMenuItem, saveToolStripMenuItem, saveAsToolStripMenuItem, toolStripSeparator1, importTextToolStripMenuItem1, importImageToolStripMenuItem, exportToolStripMenuItem, exportFontLayoutPNGToolStripMenuItem, frameScreenshotToolStripMenuItem, toolStripSeparator2, exitToolStripMenuItem }); | ||||||
|             fileToolStripMenuItem.Name = "fileToolStripMenuItem"; |             fileToolStripMenuItem.Name = "fileToolStripMenuItem"; | ||||||
|             fileToolStripMenuItem.Size = new System.Drawing.Size(37, 20); |             fileToolStripMenuItem.Size = new System.Drawing.Size(37, 20); | ||||||
|             fileToolStripMenuItem.Text = "File"; |             fileToolStripMenuItem.Text = "File"; | ||||||
| @@ -572,12 +606,18 @@ | |||||||
|             saveAsToolStripMenuItem.ToolTipText = "Save changes to another file"; |             saveAsToolStripMenuItem.ToolTipText = "Save changes to another file"; | ||||||
|             saveAsToolStripMenuItem.Click += SaveToolStripMenuItem_Click; |             saveAsToolStripMenuItem.Click += SaveToolStripMenuItem_Click; | ||||||
|             //  |             //  | ||||||
|  |             // toolStripSeparator1 | ||||||
|  |             //  | ||||||
|  |             toolStripSeparator1.Name = "toolStripSeparator1"; | ||||||
|  |             toolStripSeparator1.Size = new System.Drawing.Size(221, 6); | ||||||
|  |             //  | ||||||
|             // importTextToolStripMenuItem1 |             // importTextToolStripMenuItem1 | ||||||
|             //  |             //  | ||||||
|             importTextToolStripMenuItem1.Image = Properties.Resources.folder_table; |             importTextToolStripMenuItem1.Image = Properties.Resources.folder_table; | ||||||
|             importTextToolStripMenuItem1.Name = "importTextToolStripMenuItem1"; |             importTextToolStripMenuItem1.Name = "importTextToolStripMenuItem1"; | ||||||
|             importTextToolStripMenuItem1.Size = new System.Drawing.Size(224, 22); |             importTextToolStripMenuItem1.Size = new System.Drawing.Size(224, 22); | ||||||
|             importTextToolStripMenuItem1.Text = "Import text file (very limited)"; |             importTextToolStripMenuItem1.Text = "Import text file (very limited)"; | ||||||
|  |             importTextToolStripMenuItem1.ToolTipText = "Import a font from a C array in a file"; | ||||||
|             importTextToolStripMenuItem1.Click += importTextToolStripMenuItem1_Click; |             importTextToolStripMenuItem1.Click += importTextToolStripMenuItem1_Click; | ||||||
|             //  |             //  | ||||||
|             // importImageToolStripMenuItem |             // importImageToolStripMenuItem | ||||||
| @@ -598,7 +638,31 @@ | |||||||
|             exportToolStripMenuItem.Size = new System.Drawing.Size(224, 22); |             exportToolStripMenuItem.Size = new System.Drawing.Size(224, 22); | ||||||
|             exportToolStripMenuItem.Text = "Export"; |             exportToolStripMenuItem.Text = "Export"; | ||||||
|             exportToolStripMenuItem.ToolTipText = "Configure and export data"; |             exportToolStripMenuItem.ToolTipText = "Configure and export data"; | ||||||
|             exportToolStripMenuItem.Click += button1_Click; |             exportToolStripMenuItem.Click += Export_Click; | ||||||
|  |             //  | ||||||
|  |             // exportFontLayoutPNGToolStripMenuItem | ||||||
|  |             //  | ||||||
|  |             exportFontLayoutPNGToolStripMenuItem.Image = Properties.Resources.picture_go; | ||||||
|  |             exportFontLayoutPNGToolStripMenuItem.Name = "exportFontLayoutPNGToolStripMenuItem"; | ||||||
|  |             exportFontLayoutPNGToolStripMenuItem.Size = new System.Drawing.Size(224, 22); | ||||||
|  |             exportFontLayoutPNGToolStripMenuItem.Text = "Export font layout PNG"; | ||||||
|  |             exportFontLayoutPNGToolStripMenuItem.ToolTipText = "Create an image with all a table showing all 256 symbols"; | ||||||
|  |             exportFontLayoutPNGToolStripMenuItem.Click += ExportPNG; | ||||||
|  |             //  | ||||||
|  |             // frameScreenshotToolStripMenuItem | ||||||
|  |             //  | ||||||
|  |             frameScreenshotToolStripMenuItem.Image = Properties.Resources.picture_go; | ||||||
|  |             frameScreenshotToolStripMenuItem.Name = "frameScreenshotToolStripMenuItem"; | ||||||
|  |             frameScreenshotToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.P; | ||||||
|  |             frameScreenshotToolStripMenuItem.Size = new System.Drawing.Size(224, 22); | ||||||
|  |             frameScreenshotToolStripMenuItem.Text = "Frame Screenshot"; | ||||||
|  |             frameScreenshotToolStripMenuItem.ToolTipText = "Make a screenshot of the current frame"; | ||||||
|  |             frameScreenshotToolStripMenuItem.Click += frameScreenshotToolStripMenuItem_Click; | ||||||
|  |             //  | ||||||
|  |             // toolStripSeparator2 | ||||||
|  |             //  | ||||||
|  |             toolStripSeparator2.Name = "toolStripSeparator2"; | ||||||
|  |             toolStripSeparator2.Size = new System.Drawing.Size(221, 6); | ||||||
|             //  |             //  | ||||||
|             // exitToolStripMenuItem |             // exitToolStripMenuItem | ||||||
|             //  |             //  | ||||||
| @@ -613,7 +677,7 @@ | |||||||
|             //  |             //  | ||||||
|             // editToolStripMenuItem |             // editToolStripMenuItem | ||||||
|             //  |             //  | ||||||
|             editToolStripMenuItem.DropDownItems.AddRange(new System.Windows.Forms.ToolStripItem[] { undoToolStripMenuItem, redoToolStripMenuItem, copyToolStripMenuItem, pasteToolStripMenuItem, selectToolStripMenuItem }); |             editToolStripMenuItem.DropDownItems.AddRange(new System.Windows.Forms.ToolStripItem[] { undoToolStripMenuItem, redoToolStripMenuItem, copyToolStripMenuItem, pasteToolStripMenuItem, selectToolStripMenuItem, selectAllToolStripMenuItem }); | ||||||
|             editToolStripMenuItem.Name = "editToolStripMenuItem"; |             editToolStripMenuItem.Name = "editToolStripMenuItem"; | ||||||
|             editToolStripMenuItem.Size = new System.Drawing.Size(39, 20); |             editToolStripMenuItem.Size = new System.Drawing.Size(39, 20); | ||||||
|             editToolStripMenuItem.Text = "Edit"; |             editToolStripMenuItem.Text = "Edit"; | ||||||
| @@ -624,7 +688,7 @@ | |||||||
|             undoToolStripMenuItem.Image = Properties.Resources.arrow_undo; |             undoToolStripMenuItem.Image = Properties.Resources.arrow_undo; | ||||||
|             undoToolStripMenuItem.Name = "undoToolStripMenuItem"; |             undoToolStripMenuItem.Name = "undoToolStripMenuItem"; | ||||||
|             undoToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.Z; |             undoToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.Z; | ||||||
|             undoToolStripMenuItem.Size = new System.Drawing.Size(144, 22); |             undoToolStripMenuItem.Size = new System.Drawing.Size(164, 22); | ||||||
|             undoToolStripMenuItem.Text = "Undo"; |             undoToolStripMenuItem.Text = "Undo"; | ||||||
|             undoToolStripMenuItem.ToolTipText = "Undo last canvas change"; |             undoToolStripMenuItem.ToolTipText = "Undo last canvas change"; | ||||||
|             undoToolStripMenuItem.Click += undoToolStripMenuItem_Click; |             undoToolStripMenuItem.Click += undoToolStripMenuItem_Click; | ||||||
| @@ -634,31 +698,29 @@ | |||||||
|             redoToolStripMenuItem.Image = Properties.Resources.arrow_redo; |             redoToolStripMenuItem.Image = Properties.Resources.arrow_redo; | ||||||
|             redoToolStripMenuItem.Name = "redoToolStripMenuItem"; |             redoToolStripMenuItem.Name = "redoToolStripMenuItem"; | ||||||
|             redoToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.Y; |             redoToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.Y; | ||||||
|             redoToolStripMenuItem.Size = new System.Drawing.Size(144, 22); |             redoToolStripMenuItem.Size = new System.Drawing.Size(164, 22); | ||||||
|             redoToolStripMenuItem.Text = "Redo"; |             redoToolStripMenuItem.Text = "Redo"; | ||||||
|             redoToolStripMenuItem.ToolTipText = "Redo canvas change"; |             redoToolStripMenuItem.ToolTipText = "Redo canvas change"; | ||||||
|             redoToolStripMenuItem.Click += redoToolStripMenuItem_Click; |             redoToolStripMenuItem.Click += redoToolStripMenuItem_Click; | ||||||
|             //  |             //  | ||||||
|             // copyToolStripMenuItem |             // copyToolStripMenuItem | ||||||
|             //  |             //  | ||||||
|             copyToolStripMenuItem.Enabled = false; |  | ||||||
|             copyToolStripMenuItem.Image = Properties.Resources.Famfamfam_Silk_Page_copy_16; |             copyToolStripMenuItem.Image = Properties.Resources.Famfamfam_Silk_Page_copy_16; | ||||||
|             copyToolStripMenuItem.Name = "copyToolStripMenuItem"; |             copyToolStripMenuItem.Name = "copyToolStripMenuItem"; | ||||||
|             copyToolStripMenuItem.ShortcutKeyDisplayString = ""; |             copyToolStripMenuItem.ShortcutKeyDisplayString = ""; | ||||||
|             copyToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.C; |             copyToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.C; | ||||||
|             copyToolStripMenuItem.Size = new System.Drawing.Size(144, 22); |             copyToolStripMenuItem.Size = new System.Drawing.Size(164, 22); | ||||||
|             copyToolStripMenuItem.Text = "Copy"; |             copyToolStripMenuItem.Text = "Copy"; | ||||||
|             copyToolStripMenuItem.ToolTipText = "Copy current symbol to clipboard"; |             copyToolStripMenuItem.ToolTipText = "Copy current symbol to clipboard"; | ||||||
|             copyToolStripMenuItem.Click += copyToolStripMenuItem_Click; |             copyToolStripMenuItem.Click += copyToolStripMenuItem_Click; | ||||||
|             //  |             //  | ||||||
|             // pasteToolStripMenuItem |             // pasteToolStripMenuItem | ||||||
|             //  |             //  | ||||||
|             pasteToolStripMenuItem.Enabled = false; |  | ||||||
|             pasteToolStripMenuItem.Image = Properties.Resources.Famfamfam_Silk_Page_paste_16; |             pasteToolStripMenuItem.Image = Properties.Resources.Famfamfam_Silk_Page_paste_16; | ||||||
|             pasteToolStripMenuItem.Name = "pasteToolStripMenuItem"; |             pasteToolStripMenuItem.Name = "pasteToolStripMenuItem"; | ||||||
|             pasteToolStripMenuItem.ShortcutKeyDisplayString = ""; |             pasteToolStripMenuItem.ShortcutKeyDisplayString = ""; | ||||||
|             pasteToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.V; |             pasteToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.V; | ||||||
|             pasteToolStripMenuItem.Size = new System.Drawing.Size(144, 22); |             pasteToolStripMenuItem.Size = new System.Drawing.Size(164, 22); | ||||||
|             pasteToolStripMenuItem.Text = "Paste"; |             pasteToolStripMenuItem.Text = "Paste"; | ||||||
|             pasteToolStripMenuItem.ToolTipText = "Paste from clipboard to current symbol"; |             pasteToolStripMenuItem.ToolTipText = "Paste from clipboard to current symbol"; | ||||||
|             pasteToolStripMenuItem.Click += pasteToolStripMenuItem_Click; |             pasteToolStripMenuItem.Click += pasteToolStripMenuItem_Click; | ||||||
| @@ -667,22 +729,36 @@ | |||||||
|             //  |             //  | ||||||
|             selectToolStripMenuItem.Image = Properties.Resources.fam_rectt; |             selectToolStripMenuItem.Image = Properties.Resources.fam_rectt; | ||||||
|             selectToolStripMenuItem.Name = "selectToolStripMenuItem"; |             selectToolStripMenuItem.Name = "selectToolStripMenuItem"; | ||||||
|             selectToolStripMenuItem.Size = new System.Drawing.Size(144, 22); |             selectToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.R; | ||||||
|  |             selectToolStripMenuItem.Size = new System.Drawing.Size(164, 22); | ||||||
|             selectToolStripMenuItem.Text = "Select"; |             selectToolStripMenuItem.Text = "Select"; | ||||||
|  |             selectToolStripMenuItem.ToolTipText = "Toggle Rectangle selection tool"; | ||||||
|             selectToolStripMenuItem.Click += selectToolStripMenuItem_Click; |             selectToolStripMenuItem.Click += selectToolStripMenuItem_Click; | ||||||
|             //  |             //  | ||||||
|  |             // selectAllToolStripMenuItem | ||||||
|  |             //  | ||||||
|  |             selectAllToolStripMenuItem.Enabled = false; | ||||||
|  |             selectAllToolStripMenuItem.Image = Properties.Resources.arrow_out; | ||||||
|  |             selectAllToolStripMenuItem.Name = "selectAllToolStripMenuItem"; | ||||||
|  |             selectAllToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.A; | ||||||
|  |             selectAllToolStripMenuItem.Size = new System.Drawing.Size(164, 22); | ||||||
|  |             selectAllToolStripMenuItem.Text = "Select All"; | ||||||
|  |             selectAllToolStripMenuItem.ToolTipText = "Select entire canvas"; | ||||||
|  |             selectAllToolStripMenuItem.Click += selectAllToolStripMenuItem_Click; | ||||||
|  |             //  | ||||||
|             // fontToolStripMenuItem |             // fontToolStripMenuItem | ||||||
|             //  |             //  | ||||||
|             fontToolStripMenuItem.DropDownItems.AddRange(new System.Windows.Forms.ToolStripItem[] { makeVarWidthToolStripMenuItem, prependSymbolToolStripMenuItem, appendSymbolToolStripMenuItem, removeSymbolToolStripMenuItem, removeBeforeToolStripMenuItem, removeAfterToolStripMenuItem, CodeShiftToolStripMenuItem }); |             fontToolStripMenuItem.DropDownItems.AddRange(new System.Windows.Forms.ToolStripItem[] { makeVarWidthToolStripMenuItem, prependSymbolToolStripMenuItem, appendSymbolToolStripMenuItem, removeSymbolToolStripMenuItem, removeBeforeToolStripMenuItem, removeAfterToolStripMenuItem, zerofyWidthToolStripMenuItem, CodeShiftToolStripMenuItem, toolStripSeparator3, previousSymbolToolStripMenuItem, nextSymbolToolStripMenuItem, toolStripSeparator4, testFontToolStripMenuItem }); | ||||||
|             fontToolStripMenuItem.Name = "fontToolStripMenuItem"; |             fontToolStripMenuItem.Name = "fontToolStripMenuItem"; | ||||||
|             fontToolStripMenuItem.Size = new System.Drawing.Size(43, 20); |             fontToolStripMenuItem.Size = new System.Drawing.Size(43, 20); | ||||||
|             fontToolStripMenuItem.Text = "Font"; |             fontToolStripMenuItem.Text = "Font"; | ||||||
|  |             fontToolStripMenuItem.DropDownOpening += fontToolStripMenuItem_DropDownOpening; | ||||||
|             //  |             //  | ||||||
|             // makeVarWidthToolStripMenuItem |             // makeVarWidthToolStripMenuItem | ||||||
|             //  |             //  | ||||||
|             makeVarWidthToolStripMenuItem.Image = Properties.Resources.z_asterisk; |             makeVarWidthToolStripMenuItem.Image = Properties.Resources.z_asterisk; | ||||||
|             makeVarWidthToolStripMenuItem.Name = "makeVarWidthToolStripMenuItem"; |             makeVarWidthToolStripMenuItem.Name = "makeVarWidthToolStripMenuItem"; | ||||||
|             makeVarWidthToolStripMenuItem.Size = new System.Drawing.Size(215, 22); |             makeVarWidthToolStripMenuItem.Size = new System.Drawing.Size(241, 22); | ||||||
|             makeVarWidthToolStripMenuItem.Text = "Make Variable Width"; |             makeVarWidthToolStripMenuItem.Text = "Make Variable Width"; | ||||||
|             makeVarWidthToolStripMenuItem.ToolTipText = "Make Font Variable width one"; |             makeVarWidthToolStripMenuItem.ToolTipText = "Make Font Variable width one"; | ||||||
|             makeVarWidthToolStripMenuItem.Visible = false; |             makeVarWidthToolStripMenuItem.Visible = false; | ||||||
| @@ -695,7 +771,7 @@ | |||||||
|             prependSymbolToolStripMenuItem.Name = "prependSymbolToolStripMenuItem"; |             prependSymbolToolStripMenuItem.Name = "prependSymbolToolStripMenuItem"; | ||||||
|             prependSymbolToolStripMenuItem.ShortcutKeyDisplayString = "Ctrl+Ins"; |             prependSymbolToolStripMenuItem.ShortcutKeyDisplayString = "Ctrl+Ins"; | ||||||
|             prependSymbolToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.Insert; |             prependSymbolToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.Insert; | ||||||
|             prependSymbolToolStripMenuItem.Size = new System.Drawing.Size(215, 22); |             prependSymbolToolStripMenuItem.Size = new System.Drawing.Size(241, 22); | ||||||
|             prependSymbolToolStripMenuItem.Text = "Prepend symbol"; |             prependSymbolToolStripMenuItem.Text = "Prepend symbol"; | ||||||
|             prependSymbolToolStripMenuItem.ToolTipText = "Add a symbol to the beginning of the sequence"; |             prependSymbolToolStripMenuItem.ToolTipText = "Add a symbol to the beginning of the sequence"; | ||||||
|             prependSymbolToolStripMenuItem.Click += prependSymbolToolStripMenuItem_Click; |             prependSymbolToolStripMenuItem.Click += prependSymbolToolStripMenuItem_Click; | ||||||
| @@ -707,7 +783,7 @@ | |||||||
|             appendSymbolToolStripMenuItem.Name = "appendSymbolToolStripMenuItem"; |             appendSymbolToolStripMenuItem.Name = "appendSymbolToolStripMenuItem"; | ||||||
|             appendSymbolToolStripMenuItem.ShortcutKeyDisplayString = ""; |             appendSymbolToolStripMenuItem.ShortcutKeyDisplayString = ""; | ||||||
|             appendSymbolToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.End; |             appendSymbolToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.End; | ||||||
|             appendSymbolToolStripMenuItem.Size = new System.Drawing.Size(215, 22); |             appendSymbolToolStripMenuItem.Size = new System.Drawing.Size(241, 22); | ||||||
|             appendSymbolToolStripMenuItem.Text = "Append symbol"; |             appendSymbolToolStripMenuItem.Text = "Append symbol"; | ||||||
|             appendSymbolToolStripMenuItem.ToolTipText = "Add a symbol to the end of the sequence"; |             appendSymbolToolStripMenuItem.ToolTipText = "Add a symbol to the end of the sequence"; | ||||||
|             appendSymbolToolStripMenuItem.Click += prependSymbolToolStripMenuItem_Click; |             appendSymbolToolStripMenuItem.Click += prependSymbolToolStripMenuItem_Click; | ||||||
| @@ -719,7 +795,7 @@ | |||||||
|             removeSymbolToolStripMenuItem.Name = "removeSymbolToolStripMenuItem"; |             removeSymbolToolStripMenuItem.Name = "removeSymbolToolStripMenuItem"; | ||||||
|             removeSymbolToolStripMenuItem.ShortcutKeyDisplayString = ""; |             removeSymbolToolStripMenuItem.ShortcutKeyDisplayString = ""; | ||||||
|             removeSymbolToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.Delete; |             removeSymbolToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.Delete; | ||||||
|             removeSymbolToolStripMenuItem.Size = new System.Drawing.Size(215, 22); |             removeSymbolToolStripMenuItem.Size = new System.Drawing.Size(241, 22); | ||||||
|             removeSymbolToolStripMenuItem.Text = "Remove symbol"; |             removeSymbolToolStripMenuItem.Text = "Remove symbol"; | ||||||
|             removeSymbolToolStripMenuItem.ToolTipText = "Remove current symbol (works only for first or last symbol in the sequence)"; |             removeSymbolToolStripMenuItem.ToolTipText = "Remove current symbol (works only for first or last symbol in the sequence)"; | ||||||
|             removeSymbolToolStripMenuItem.Click += removeSymbolToolStripMenuItem_Click; |             removeSymbolToolStripMenuItem.Click += removeSymbolToolStripMenuItem_Click; | ||||||
| @@ -729,7 +805,7 @@ | |||||||
|             removeBeforeToolStripMenuItem.Enabled = false; |             removeBeforeToolStripMenuItem.Enabled = false; | ||||||
|             removeBeforeToolStripMenuItem.Image = Properties.Resources.delete; |             removeBeforeToolStripMenuItem.Image = Properties.Resources.delete; | ||||||
|             removeBeforeToolStripMenuItem.Name = "removeBeforeToolStripMenuItem"; |             removeBeforeToolStripMenuItem.Name = "removeBeforeToolStripMenuItem"; | ||||||
|             removeBeforeToolStripMenuItem.Size = new System.Drawing.Size(215, 22); |             removeBeforeToolStripMenuItem.Size = new System.Drawing.Size(241, 22); | ||||||
|             removeBeforeToolStripMenuItem.Text = "Remove all before selected"; |             removeBeforeToolStripMenuItem.Text = "Remove all before selected"; | ||||||
|             removeBeforeToolStripMenuItem.ToolTipText = "Remove all symbols before current one"; |             removeBeforeToolStripMenuItem.ToolTipText = "Remove all symbols before current one"; | ||||||
|             removeBeforeToolStripMenuItem.Click += removeBeforeToolStripMenuItem_Click; |             removeBeforeToolStripMenuItem.Click += removeBeforeToolStripMenuItem_Click; | ||||||
| @@ -739,20 +815,69 @@ | |||||||
|             removeAfterToolStripMenuItem.Enabled = false; |             removeAfterToolStripMenuItem.Enabled = false; | ||||||
|             removeAfterToolStripMenuItem.Image = Properties.Resources.delete; |             removeAfterToolStripMenuItem.Image = Properties.Resources.delete; | ||||||
|             removeAfterToolStripMenuItem.Name = "removeAfterToolStripMenuItem"; |             removeAfterToolStripMenuItem.Name = "removeAfterToolStripMenuItem"; | ||||||
|             removeAfterToolStripMenuItem.Size = new System.Drawing.Size(215, 22); |             removeAfterToolStripMenuItem.Size = new System.Drawing.Size(241, 22); | ||||||
|             removeAfterToolStripMenuItem.Text = "Remove all after selected"; |             removeAfterToolStripMenuItem.Text = "Remove all after selected"; | ||||||
|             removeAfterToolStripMenuItem.ToolTipText = "Remove all symbols after current one"; |             removeAfterToolStripMenuItem.ToolTipText = "Remove all symbols after current one"; | ||||||
|             removeAfterToolStripMenuItem.Click += removeAfterToolStripMenuItem_Click; |             removeAfterToolStripMenuItem.Click += removeAfterToolStripMenuItem_Click; | ||||||
|             //  |             //  | ||||||
|  |             // zerofyWidthToolStripMenuItem | ||||||
|  |             //  | ||||||
|  |             zerofyWidthToolStripMenuItem.Enabled = false; | ||||||
|  |             zerofyWidthToolStripMenuItem.Image = Properties.Resources.text_letterspacing2; | ||||||
|  |             zerofyWidthToolStripMenuItem.Name = "zerofyWidthToolStripMenuItem"; | ||||||
|  |             zerofyWidthToolStripMenuItem.Size = new System.Drawing.Size(241, 22); | ||||||
|  |             zerofyWidthToolStripMenuItem.Text = "Make all blank symbols 0-width"; | ||||||
|  |             zerofyWidthToolStripMenuItem.ToolTipText = "Make width equals zero for all blank symbols (except code 32 (space))"; | ||||||
|  |             zerofyWidthToolStripMenuItem.Click += ZerofyBlankWidth; | ||||||
|  |             //  | ||||||
|             // CodeShiftToolStripMenuItem |             // CodeShiftToolStripMenuItem | ||||||
|             //  |             //  | ||||||
|             CodeShiftToolStripMenuItem.Image = Properties.Resources.z_align_center; |             CodeShiftToolStripMenuItem.Image = Properties.Resources.z_align_center; | ||||||
|             CodeShiftToolStripMenuItem.Name = "CodeShiftToolStripMenuItem"; |             CodeShiftToolStripMenuItem.Name = "CodeShiftToolStripMenuItem"; | ||||||
|             CodeShiftToolStripMenuItem.Size = new System.Drawing.Size(215, 22); |             CodeShiftToolStripMenuItem.Size = new System.Drawing.Size(241, 22); | ||||||
|             CodeShiftToolStripMenuItem.Text = "Code shift"; |             CodeShiftToolStripMenuItem.Text = "Code shift"; | ||||||
|             CodeShiftToolStripMenuItem.ToolTipText = "Shift the font on the code line"; |             CodeShiftToolStripMenuItem.ToolTipText = "Shift the font on the code line"; | ||||||
|             CodeShiftToolStripMenuItem.Click += CodeShiftToolStripMenuItem_Click; |             CodeShiftToolStripMenuItem.Click += CodeShiftToolStripMenuItem_Click; | ||||||
|             //  |             //  | ||||||
|  |             // toolStripSeparator3 | ||||||
|  |             //  | ||||||
|  |             toolStripSeparator3.Name = "toolStripSeparator3"; | ||||||
|  |             toolStripSeparator3.Size = new System.Drawing.Size(238, 6); | ||||||
|  |             //  | ||||||
|  |             // previousSymbolToolStripMenuItem | ||||||
|  |             //  | ||||||
|  |             previousSymbolToolStripMenuItem.Image = Properties.Resources.arrow_turn_left; | ||||||
|  |             previousSymbolToolStripMenuItem.Name = "previousSymbolToolStripMenuItem"; | ||||||
|  |             previousSymbolToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Alt | System.Windows.Forms.Keys.Left; | ||||||
|  |             previousSymbolToolStripMenuItem.Size = new System.Drawing.Size(241, 22); | ||||||
|  |             previousSymbolToolStripMenuItem.Text = "Previous Symbol"; | ||||||
|  |             previousSymbolToolStripMenuItem.ToolTipText = "Select previous symbol"; | ||||||
|  |             previousSymbolToolStripMenuItem.Click += previousSymbolToolStripMenuItem_Click; | ||||||
|  |             //  | ||||||
|  |             // nextSymbolToolStripMenuItem | ||||||
|  |             //  | ||||||
|  |             nextSymbolToolStripMenuItem.Image = Properties.Resources.arrow_turn_right; | ||||||
|  |             nextSymbolToolStripMenuItem.Name = "nextSymbolToolStripMenuItem"; | ||||||
|  |             nextSymbolToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Alt | System.Windows.Forms.Keys.Right; | ||||||
|  |             nextSymbolToolStripMenuItem.Size = new System.Drawing.Size(241, 22); | ||||||
|  |             nextSymbolToolStripMenuItem.Text = "Next symbol"; | ||||||
|  |             nextSymbolToolStripMenuItem.ToolTipText = "Select next symbol"; | ||||||
|  |             nextSymbolToolStripMenuItem.Click += nextSymbolToolStripMenuItem_Click; | ||||||
|  |             //  | ||||||
|  |             // toolStripSeparator4 | ||||||
|  |             //  | ||||||
|  |             toolStripSeparator4.Name = "toolStripSeparator4"; | ||||||
|  |             toolStripSeparator4.Size = new System.Drawing.Size(238, 6); | ||||||
|  |             //  | ||||||
|  |             // testFontToolStripMenuItem | ||||||
|  |             //  | ||||||
|  |             testFontToolStripMenuItem.Image = Properties.Resources.font; | ||||||
|  |             testFontToolStripMenuItem.Name = "testFontToolStripMenuItem"; | ||||||
|  |             testFontToolStripMenuItem.Size = new System.Drawing.Size(241, 22); | ||||||
|  |             testFontToolStripMenuItem.Text = "Test font"; | ||||||
|  |             testFontToolStripMenuItem.ToolTipText = "Open dialog where you can test the font with any text you type"; | ||||||
|  |             testFontToolStripMenuItem.Click += TestFont_Click; | ||||||
|  |             //  | ||||||
|             // canvasToolStripMenuItem |             // canvasToolStripMenuItem | ||||||
|             //  |             //  | ||||||
|             canvasToolStripMenuItem.DropDownItems.AddRange(new System.Windows.Forms.ToolStripItem[] { ClearToolStripMenuItem, FillToolStripMenuItem, shiftUpToolStripMenuItem, shiftDownToolStripMenuItem, shiftLeftToolStripMenuItem, shiftRightToolStripMenuItem, invertToolStripMenuItem, mirrorXToolStripMenuItem, mirrorYToolStripMenuItem, applyToolStripMenuItem }); |             canvasToolStripMenuItem.DropDownItems.AddRange(new System.Windows.Forms.ToolStripItem[] { ClearToolStripMenuItem, FillToolStripMenuItem, shiftUpToolStripMenuItem, shiftDownToolStripMenuItem, shiftLeftToolStripMenuItem, shiftRightToolStripMenuItem, invertToolStripMenuItem, mirrorXToolStripMenuItem, mirrorYToolStripMenuItem, applyToolStripMenuItem }); | ||||||
| @@ -874,6 +999,16 @@ | |||||||
|             aboutToolStripMenuItem.Text = "About"; |             aboutToolStripMenuItem.Text = "About"; | ||||||
|             aboutToolStripMenuItem.Click += aboutToolStripMenuItem_Click; |             aboutToolStripMenuItem.Click += aboutToolStripMenuItem_Click; | ||||||
|             //  |             //  | ||||||
|  |             // toggleBarToolStripMenuItem | ||||||
|  |             //  | ||||||
|  |             toggleBarToolStripMenuItem.Alignment = System.Windows.Forms.ToolStripItemAlignment.Right; | ||||||
|  |             toggleBarToolStripMenuItem.CheckOnClick = true; | ||||||
|  |             toggleBarToolStripMenuItem.Name = "toggleBarToolStripMenuItem"; | ||||||
|  |             toggleBarToolStripMenuItem.Size = new System.Drawing.Size(35, 20); | ||||||
|  |             toggleBarToolStripMenuItem.Text = ">>"; | ||||||
|  |             toggleBarToolStripMenuItem.ToolTipText = "Toggle side bar state"; | ||||||
|  |             toggleBarToolStripMenuItem.Click += toggleBarToolStripMenuItem_Click; | ||||||
|  |             //  | ||||||
|             // dlgSave |             // dlgSave | ||||||
|             //  |             //  | ||||||
|             dlgSave.DefaultExt = "mbf"; |             dlgSave.DefaultExt = "mbf"; | ||||||
| @@ -886,10 +1021,9 @@ | |||||||
|             //  |             //  | ||||||
|             // btnBaseline |             // btnBaseline | ||||||
|             //  |             //  | ||||||
|             btnBaseline.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |  | ||||||
|             btnBaseline.Image = Properties.Resources.fam_base; |             btnBaseline.Image = Properties.Resources.fam_base; | ||||||
|             btnBaseline.ImageAlign = System.Drawing.ContentAlignment.MiddleRight; |             btnBaseline.ImageAlign = System.Drawing.ContentAlignment.MiddleRight; | ||||||
|             btnBaseline.Location = new System.Drawing.Point(718, 92); |             btnBaseline.Location = new System.Drawing.Point(94, 81); | ||||||
|             btnBaseline.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnBaseline.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnBaseline.Name = "btnBaseline"; |             btnBaseline.Name = "btnBaseline"; | ||||||
|             btnBaseline.Size = new System.Drawing.Size(88, 27); |             btnBaseline.Size = new System.Drawing.Size(88, 27); | ||||||
| @@ -908,9 +1042,8 @@ | |||||||
|             //  |             //  | ||||||
|             // chkLeftSide |             // chkLeftSide | ||||||
|             //  |             //  | ||||||
|             chkLeftSide.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |  | ||||||
|             chkLeftSide.AutoSize = true; |             chkLeftSide.AutoSize = true; | ||||||
|             chkLeftSide.Location = new System.Drawing.Point(831, 33); |             chkLeftSide.Location = new System.Drawing.Point(113, 5); | ||||||
|             chkLeftSide.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             chkLeftSide.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             chkLeftSide.Name = "chkLeftSide"; |             chkLeftSide.Name = "chkLeftSide"; | ||||||
|             chkLeftSide.Size = new System.Drawing.Size(70, 19); |             chkLeftSide.Size = new System.Drawing.Size(70, 19); | ||||||
| @@ -921,9 +1054,8 @@ | |||||||
|             //  |             //  | ||||||
|             // chkTopSide |             // chkTopSide | ||||||
|             //  |             //  | ||||||
|             chkTopSide.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |  | ||||||
|             chkTopSide.AutoSize = true; |             chkTopSide.AutoSize = true; | ||||||
|             chkTopSide.Location = new System.Drawing.Point(831, 58); |             chkTopSide.Location = new System.Drawing.Point(113, 28); | ||||||
|             chkTopSide.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             chkTopSide.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             chkTopSide.Name = "chkTopSide"; |             chkTopSide.Name = "chkTopSide"; | ||||||
|             chkTopSide.Size = new System.Drawing.Size(70, 19); |             chkTopSide.Size = new System.Drawing.Size(70, 19); | ||||||
| @@ -936,7 +1068,7 @@ | |||||||
|             //  |             //  | ||||||
|             chkHexCodes.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |             chkHexCodes.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; | ||||||
|             chkHexCodes.AutoSize = true; |             chkHexCodes.AutoSize = true; | ||||||
|             chkHexCodes.Location = new System.Drawing.Point(618, 155); |             chkHexCodes.Location = new System.Drawing.Point(6, 131); | ||||||
|             chkHexCodes.Name = "chkHexCodes"; |             chkHexCodes.Name = "chkHexCodes"; | ||||||
|             chkHexCodes.Size = new System.Drawing.Size(95, 19); |             chkHexCodes.Size = new System.Drawing.Size(95, 19); | ||||||
|             chkHexCodes.TabIndex = 22; |             chkHexCodes.TabIndex = 22; | ||||||
| @@ -947,56 +1079,145 @@ | |||||||
|             //  |             //  | ||||||
|             // chkRectSelect |             // chkRectSelect | ||||||
|             //  |             //  | ||||||
|             chkRectSelect.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |  | ||||||
|             chkRectSelect.Appearance = System.Windows.Forms.Appearance.Button; |             chkRectSelect.Appearance = System.Windows.Forms.Appearance.Button; | ||||||
|             chkRectSelect.Image = Properties.Resources.fam_rectt; |             chkRectSelect.Image = Properties.Resources.fam_rectt; | ||||||
|             chkRectSelect.ImageAlign = System.Drawing.ContentAlignment.MiddleRight; |             chkRectSelect.ImageAlign = System.Drawing.ContentAlignment.MiddleRight; | ||||||
|             chkRectSelect.Location = new System.Drawing.Point(620, 92); |             chkRectSelect.Location = new System.Drawing.Point(4, 81); | ||||||
|             chkRectSelect.Name = "chkRectSelect"; |             chkRectSelect.Name = "chkRectSelect"; | ||||||
|             chkRectSelect.Size = new System.Drawing.Size(74, 27); |             chkRectSelect.Size = new System.Drawing.Size(88, 27); | ||||||
|             chkRectSelect.TabIndex = 23; |             chkRectSelect.TabIndex = 23; | ||||||
|             chkRectSelect.Text = " Select"; |             chkRectSelect.Text = " Select"; | ||||||
|             chkRectSelect.TextAlign = System.Drawing.ContentAlignment.MiddleCenter; |             chkRectSelect.TextAlign = System.Drawing.ContentAlignment.MiddleCenter; | ||||||
|             chkRectSelect.TextImageRelation = System.Windows.Forms.TextImageRelation.ImageBeforeText; |             chkRectSelect.TextImageRelation = System.Windows.Forms.TextImageRelation.ImageBeforeText; | ||||||
|             toolTip1.SetToolTip(chkRectSelect, "Turn on/off rectangle selection"); |             toolTip1.SetToolTip(chkRectSelect, "Turn on/off rectangle selection (Ctrl+R)"); | ||||||
|             chkRectSelect.UseVisualStyleBackColor = true; |             chkRectSelect.UseVisualStyleBackColor = true; | ||||||
|             chkRectSelect.CheckedChanged += chkRectSelect_CheckedChanged; |             chkRectSelect.CheckedChanged += chkRectSelect_CheckedChanged; | ||||||
|             //  |             //  | ||||||
|  |             // nudBrush | ||||||
|  |             //  | ||||||
|  |             nudBrush.Location = new System.Drawing.Point(59, 51); | ||||||
|  |             nudBrush.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|  |             nudBrush.Maximum = new decimal(new int[] { 32, 0, 0, 0 }); | ||||||
|  |             nudBrush.Minimum = new decimal(new int[] { 1, 0, 0, 0 }); | ||||||
|  |             nudBrush.Name = "nudBrush"; | ||||||
|  |             nudBrush.Size = new System.Drawing.Size(47, 23); | ||||||
|  |             nudBrush.TabIndex = 24; | ||||||
|  |             toolTip1.SetToolTip(nudBrush, "Symbol height (Alt+Scroll)"); | ||||||
|  |             nudBrush.Value = new decimal(new int[] { 1, 0, 0, 0 }); | ||||||
|  |             nudBrush.ValueChanged += nudBrush_ValueChanged; | ||||||
|  |             //  | ||||||
|             // label3 |             // label3 | ||||||
|             //  |             //  | ||||||
|             label3.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; |             label3.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; | ||||||
|             label3.AutoSize = true; |             label3.AutoSize = true; | ||||||
|             label3.Location = new System.Drawing.Point(615, 123); |             label3.Location = new System.Drawing.Point(3, 99); | ||||||
|             label3.Name = "label3"; |             label3.Name = "label3"; | ||||||
|             label3.Size = new System.Drawing.Size(45, 15); |             label3.Size = new System.Drawing.Size(45, 15); | ||||||
|             label3.TabIndex = 21; |             label3.TabIndex = 21; | ||||||
|             label3.Text = "Cursor:"; |             label3.Text = "Cursor:"; | ||||||
|             //  |             //  | ||||||
|  |             // lblSelectionLabel | ||||||
|  |             //  | ||||||
|  |             lblSelectionLabel.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; | ||||||
|  |             lblSelectionLabel.AutoSize = true; | ||||||
|  |             lblSelectionLabel.Location = new System.Drawing.Point(4, 69); | ||||||
|  |             lblSelectionLabel.Name = "lblSelectionLabel"; | ||||||
|  |             lblSelectionLabel.Size = new System.Drawing.Size(58, 15); | ||||||
|  |             lblSelectionLabel.TabIndex = 25; | ||||||
|  |             lblSelectionLabel.Text = "Selection:"; | ||||||
|  |             lblSelectionLabel.Visible = false; | ||||||
|  |             //  | ||||||
|  |             // lblSelection | ||||||
|  |             //  | ||||||
|  |             lblSelection.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; | ||||||
|  |             lblSelection.AutoSize = true; | ||||||
|  |             lblSelection.Location = new System.Drawing.Point(5, 84); | ||||||
|  |             lblSelection.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); | ||||||
|  |             lblSelection.Name = "lblSelection"; | ||||||
|  |             lblSelection.Size = new System.Drawing.Size(32, 15); | ||||||
|  |             lblSelection.TabIndex = 24; | ||||||
|  |             lblSelection.Text = "WxH"; | ||||||
|  |             lblSelection.TextAlign = System.Drawing.ContentAlignment.TopRight; | ||||||
|  |             lblSelection.Visible = false; | ||||||
|  |             //  | ||||||
|  |             // lblModified | ||||||
|  |             //  | ||||||
|  |             lblModified.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; | ||||||
|  |             lblModified.AutoSize = true; | ||||||
|  |             lblModified.Font = new System.Drawing.Font("Segoe UI Semibold", 9F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|  |             lblModified.ForeColor = System.Drawing.SystemColors.Highlight; | ||||||
|  |             lblModified.Location = new System.Drawing.Point(4, 54); | ||||||
|  |             lblModified.Name = "lblModified"; | ||||||
|  |             lblModified.Size = new System.Drawing.Size(91, 15); | ||||||
|  |             lblModified.TabIndex = 26; | ||||||
|  |             lblModified.Text = "Frame modified"; | ||||||
|  |             lblModified.Visible = false; | ||||||
|  |             //  | ||||||
|  |             // dlgSavePNG | ||||||
|  |             //  | ||||||
|  |             dlgSavePNG.DefaultExt = "png"; | ||||||
|  |             dlgSavePNG.Filter = "PNG Image|*.png;*.PNG"; | ||||||
|  |             //  | ||||||
|  |             // pnlRightButtons | ||||||
|  |             //  | ||||||
|  |             pnlRightButtons.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; | ||||||
|  |             pnlRightButtons.Controls.Add(nudBrush); | ||||||
|  |             pnlRightButtons.Controls.Add(lblBrush); | ||||||
|  |             pnlRightButtons.Controls.Add(chkLeftSide); | ||||||
|  |             pnlRightButtons.Controls.Add(nudX); | ||||||
|  |             pnlRightButtons.Controls.Add(nudY); | ||||||
|  |             pnlRightButtons.Controls.Add(lblWidth); | ||||||
|  |             pnlRightButtons.Controls.Add(lblHeight); | ||||||
|  |             pnlRightButtons.Controls.Add(chkRectSelect); | ||||||
|  |             pnlRightButtons.Controls.Add(lblType); | ||||||
|  |             pnlRightButtons.Controls.Add(btnExport); | ||||||
|  |             pnlRightButtons.Controls.Add(btnApply); | ||||||
|  |             pnlRightButtons.Controls.Add(chkTopSide); | ||||||
|  |             pnlRightButtons.Controls.Add(btnBaseline); | ||||||
|  |             pnlRightButtons.Location = new System.Drawing.Point(715, 24); | ||||||
|  |             pnlRightButtons.Margin = new System.Windows.Forms.Padding(0); | ||||||
|  |             pnlRightButtons.Name = "pnlRightButtons"; | ||||||
|  |             pnlRightButtons.Size = new System.Drawing.Size(184, 154); | ||||||
|  |             pnlRightButtons.TabIndex = 27; | ||||||
|  |             //  | ||||||
|  |             // lblBrush | ||||||
|  |             //  | ||||||
|  |             lblBrush.AutoSize = true; | ||||||
|  |             lblBrush.Location = new System.Drawing.Point(10, 54); | ||||||
|  |             lblBrush.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); | ||||||
|  |             lblBrush.Name = "lblBrush"; | ||||||
|  |             lblBrush.Size = new System.Drawing.Size(40, 15); | ||||||
|  |             lblBrush.TabIndex = 25; | ||||||
|  |             lblBrush.Text = "Brush:"; | ||||||
|  |             //  | ||||||
|  |             // pnlInfo | ||||||
|  |             //  | ||||||
|  |             pnlInfo.Anchor = System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right; | ||||||
|  |             pnlInfo.Controls.Add(label4); | ||||||
|  |             pnlInfo.Controls.Add(cbZoom); | ||||||
|  |             pnlInfo.Controls.Add(lblCoords); | ||||||
|  |             pnlInfo.Controls.Add(lblModified); | ||||||
|  |             pnlInfo.Controls.Add(label3); | ||||||
|  |             pnlInfo.Controls.Add(lblSelectionLabel); | ||||||
|  |             pnlInfo.Controls.Add(chkHexCodes); | ||||||
|  |             pnlInfo.Controls.Add(lblSelection); | ||||||
|  |             pnlInfo.Location = new System.Drawing.Point(615, 24); | ||||||
|  |             pnlInfo.Margin = new System.Windows.Forms.Padding(0); | ||||||
|  |             pnlInfo.Name = "pnlInfo"; | ||||||
|  |             pnlInfo.Size = new System.Drawing.Size(103, 154); | ||||||
|  |             pnlInfo.TabIndex = 28; | ||||||
|  |             //  | ||||||
|             // MainForm |             // MainForm | ||||||
|             //  |             //  | ||||||
|             AutoScaleDimensions = new System.Drawing.SizeF(7F, 15F); |             AutoScaleDimensions = new System.Drawing.SizeF(7F, 15F); | ||||||
|             AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; |             AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; | ||||||
|             ClientSize = new System.Drawing.Size(915, 647); |             ClientSize = new System.Drawing.Size(915, 647); | ||||||
|             Controls.Add(chkRectSelect); |             Controls.Add(pnlInfo); | ||||||
|             Controls.Add(chkHexCodes); |             Controls.Add(pnlRightButtons); | ||||||
|             Controls.Add(label3); |  | ||||||
|             Controls.Add(chkTopSide); |  | ||||||
|             Controls.Add(chkLeftSide); |  | ||||||
|             Controls.Add(btnBaseline); |  | ||||||
|             Controls.Add(btnApply); |  | ||||||
|             Controls.Add(btnExport); |  | ||||||
|             Controls.Add(lblCoords); |  | ||||||
|             Controls.Add(vScroll); |             Controls.Add(vScroll); | ||||||
|             Controls.Add(hScroll); |             Controls.Add(hScroll); | ||||||
|             Controls.Add(miniList); |             Controls.Add(miniList); | ||||||
|             Controls.Add(panel1); |             Controls.Add(panel1); | ||||||
|             Controls.Add(label4); |  | ||||||
|             Controls.Add(cbZoom); |  | ||||||
|             Controls.Add(lblType); |  | ||||||
|             Controls.Add(label2); |  | ||||||
|             Controls.Add(label1); |  | ||||||
|             Controls.Add(nudY); |  | ||||||
|             Controls.Add(nudX); |  | ||||||
|             Controls.Add(dotPanel); |             Controls.Add(dotPanel); | ||||||
|             Controls.Add(menuStrip1); |             Controls.Add(menuStrip1); | ||||||
|             Icon = (System.Drawing.Icon)resources.GetObject("$this.Icon"); |             Icon = (System.Drawing.Icon)resources.GetObject("$this.Icon"); | ||||||
| @@ -1011,9 +1232,15 @@ | |||||||
|             ((System.ComponentModel.ISupportInitialize)nudX).EndInit(); |             ((System.ComponentModel.ISupportInitialize)nudX).EndInit(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)nudY).EndInit(); |             ((System.ComponentModel.ISupportInitialize)nudY).EndInit(); | ||||||
|             panel1.ResumeLayout(false); |             panel1.ResumeLayout(false); | ||||||
|  |             panel1.PerformLayout(); | ||||||
|             cmMinilist.ResumeLayout(false); |             cmMinilist.ResumeLayout(false); | ||||||
|             menuStrip1.ResumeLayout(false); |             menuStrip1.ResumeLayout(false); | ||||||
|             menuStrip1.PerformLayout(); |             menuStrip1.PerformLayout(); | ||||||
|  |             ((System.ComponentModel.ISupportInitialize)nudBrush).EndInit(); | ||||||
|  |             pnlRightButtons.ResumeLayout(false); | ||||||
|  |             pnlRightButtons.PerformLayout(); | ||||||
|  |             pnlInfo.ResumeLayout(false); | ||||||
|  |             pnlInfo.PerformLayout(); | ||||||
|             ResumeLayout(false); |             ResumeLayout(false); | ||||||
|             PerformLayout(); |             PerformLayout(); | ||||||
|  |  | ||||||
| @@ -1022,10 +1249,8 @@ | |||||||
|         #endregion |         #endregion | ||||||
|  |  | ||||||
|         private System.Windows.Forms.Panel dotPanel; |         private System.Windows.Forms.Panel dotPanel; | ||||||
|         private System.Windows.Forms.NumericUpDown nudX; |         private System.Windows.Forms.Label lblWidth; | ||||||
|         private System.Windows.Forms.NumericUpDown nudY; |         private System.Windows.Forms.Label lblHeight; | ||||||
|         private System.Windows.Forms.Label label1; |  | ||||||
|         private System.Windows.Forms.Label label2; |  | ||||||
|         private System.Windows.Forms.Label lblType; |         private System.Windows.Forms.Label lblType; | ||||||
|         private System.Windows.Forms.ComboBox cbZoom; |         private System.Windows.Forms.ComboBox cbZoom; | ||||||
|         private System.Windows.Forms.Label label4; |         private System.Windows.Forms.Label label4; | ||||||
| @@ -1038,8 +1263,6 @@ | |||||||
|         private System.Windows.Forms.Button btnMirrorX; |         private System.Windows.Forms.Button btnMirrorX; | ||||||
|         private System.Windows.Forms.Button btnMirrorY; |         private System.Windows.Forms.Button btnMirrorY; | ||||||
|         private System.Windows.Forms.Button btnExport; |         private System.Windows.Forms.Button btnExport; | ||||||
|         private System.Windows.Forms.ListView miniList; |  | ||||||
|         private System.Windows.Forms.ImageList ilMiniatures; |  | ||||||
|         private System.Windows.Forms.Button btnApply; |         private System.Windows.Forms.Button btnApply; | ||||||
|         private System.Windows.Forms.HScrollBar hScroll; |         private System.Windows.Forms.HScrollBar hScroll; | ||||||
|         private System.Windows.Forms.VScrollBar vScroll; |         private System.Windows.Forms.VScrollBar vScroll; | ||||||
| @@ -1099,6 +1322,31 @@ | |||||||
|         private System.Windows.Forms.CheckBox chkRectSelect; |         private System.Windows.Forms.CheckBox chkRectSelect; | ||||||
|         private System.Windows.Forms.ToolStripMenuItem selectToolStripMenuItem; |         private System.Windows.Forms.ToolStripMenuItem selectToolStripMenuItem; | ||||||
|         private System.Windows.Forms.ToolStripMenuItem importTextToolStripMenuItem1; |         private System.Windows.Forms.ToolStripMenuItem importTextToolStripMenuItem1; | ||||||
|  |         private System.Windows.Forms.Label lblSelectionLabel; | ||||||
|  |         private System.Windows.Forms.Label lblSelection; | ||||||
|  |         private System.Windows.Forms.ToolStripMenuItem selectAllToolStripMenuItem; | ||||||
|  |         private System.Windows.Forms.Label lblModified; | ||||||
|  |         private System.Windows.Forms.ToolStripMenuItem testFontToolStripMenuItem; | ||||||
|  |         private System.Windows.Forms.ToolStripMenuItem exportFontLayoutPNGToolStripMenuItem; | ||||||
|  |         private System.Windows.Forms.SaveFileDialog dlgSavePNG; | ||||||
|  |         private System.Windows.Forms.ToolStripSeparator toolStripSeparator1; | ||||||
|  |         private System.Windows.Forms.ToolStripSeparator toolStripSeparator2; | ||||||
|  |         private System.Windows.Forms.ToolStripSeparator toolStripSeparator3; | ||||||
|  |         public System.Windows.Forms.ListView miniList; | ||||||
|  |         public System.Windows.Forms.ImageList ilMiniatures; | ||||||
|  |         public System.Windows.Forms.NumericUpDown nudX; | ||||||
|  |         public System.Windows.Forms.NumericUpDown nudY; | ||||||
|  |         private System.Windows.Forms.ToolStripMenuItem previousSymbolToolStripMenuItem; | ||||||
|  |         private System.Windows.Forms.ToolStripMenuItem nextSymbolToolStripMenuItem; | ||||||
|  |         private System.Windows.Forms.Panel pnlRightButtons; | ||||||
|  |         private System.Windows.Forms.Panel pnlInfo; | ||||||
|  |         private System.Windows.Forms.ToolStripMenuItem toggleBarToolStripMenuItem; | ||||||
|  |         private System.Windows.Forms.ToolStripSeparator toolStripSeparator4; | ||||||
|  |         private System.Windows.Forms.ToolStripMenuItem zerofyWidthToolStripMenuItem; | ||||||
|  |         public System.Windows.Forms.NumericUpDown nudBrush; | ||||||
|  |         private System.Windows.Forms.Label lblBrush; | ||||||
|  |         private System.Windows.Forms.ToolStripMenuItem frameScreenshotToolStripMenuItem; | ||||||
|  |         private System.Windows.Forms.TextBox tbFrameNote; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -135,6 +135,9 @@ | |||||||
|   <metadata name="dlgOpen.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"> |   <metadata name="dlgOpen.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"> | ||||||
|     <value>336, 17</value> |     <value>336, 17</value> | ||||||
|   </metadata> |   </metadata> | ||||||
|  |   <metadata name="dlgSavePNG.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"> | ||||||
|  |     <value>644, 17</value> | ||||||
|  |   </metadata> | ||||||
|   <assembly alias="System.Drawing" name="System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" /> |   <assembly alias="System.Drawing" name="System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" /> | ||||||
|   <data name="$this.Icon" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> |   <data name="$this.Icon" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> | ||||||
|     <value> |     <value> | ||||||
|   | |||||||
							
								
								
									
										147
									
								
								McBitFont/FrameScreenshot.Designer.cs
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,147 @@ | |||||||
|  | namespace McBitFont { | ||||||
|  |     partial class FrameScreenshot { | ||||||
|  |         /// <summary> | ||||||
|  |         /// Required designer variable. | ||||||
|  |         /// </summary> | ||||||
|  |         private System.ComponentModel.IContainer components = null; | ||||||
|  |  | ||||||
|  |         /// <summary> | ||||||
|  |         /// Clean up any resources being used. | ||||||
|  |         /// </summary> | ||||||
|  |         /// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param> | ||||||
|  |         protected override void Dispose(bool disposing) { | ||||||
|  |             if (disposing && (components != null)) { | ||||||
|  |                 components.Dispose(); | ||||||
|  |             } | ||||||
|  |             base.Dispose(disposing); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         #region Windows Form Designer generated code | ||||||
|  |  | ||||||
|  |         /// <summary> | ||||||
|  |         /// Required method for Designer support - do not modify | ||||||
|  |         /// the contents of this method with the code editor. | ||||||
|  |         /// </summary> | ||||||
|  |         private void InitializeComponent() { | ||||||
|  |             components = new System.ComponentModel.Container(); | ||||||
|  |             btnClose = new System.Windows.Forms.Button(); | ||||||
|  |             btnOK = new System.Windows.Forms.Button(); | ||||||
|  |             toolTip1 = new System.Windows.Forms.ToolTip(components); | ||||||
|  |             nudUpscale = new System.Windows.Forms.NumericUpDown(); | ||||||
|  |             chkTransparent = new System.Windows.Forms.CheckBox(); | ||||||
|  |             dlgSaveImage = new System.Windows.Forms.SaveFileDialog(); | ||||||
|  |             lblUpscale = new System.Windows.Forms.Label(); | ||||||
|  |             chkBlackBG = new System.Windows.Forms.CheckBox(); | ||||||
|  |             ((System.ComponentModel.ISupportInitialize)nudUpscale).BeginInit(); | ||||||
|  |             SuspendLayout(); | ||||||
|  |             //  | ||||||
|  |             // btnClose | ||||||
|  |             //  | ||||||
|  |             btnClose.Location = new System.Drawing.Point(144, 67); | ||||||
|  |             btnClose.Name = "btnClose"; | ||||||
|  |             btnClose.Size = new System.Drawing.Size(88, 27); | ||||||
|  |             btnClose.TabIndex = 3; | ||||||
|  |             btnClose.Text = "Close"; | ||||||
|  |             btnClose.UseVisualStyleBackColor = true; | ||||||
|  |             btnClose.Click += btnClose_Click; | ||||||
|  |             //  | ||||||
|  |             // btnOK | ||||||
|  |             //  | ||||||
|  |             btnOK.Location = new System.Drawing.Point(12, 67); | ||||||
|  |             btnOK.Name = "btnOK"; | ||||||
|  |             btnOK.Size = new System.Drawing.Size(88, 27); | ||||||
|  |             btnOK.TabIndex = 1; | ||||||
|  |             btnOK.Text = "Save"; | ||||||
|  |             btnOK.UseVisualStyleBackColor = true; | ||||||
|  |             btnOK.Click += btnOK_Click; | ||||||
|  |             //  | ||||||
|  |             // toolTip1 | ||||||
|  |             //  | ||||||
|  |             toolTip1.AutoPopDelay = 10000; | ||||||
|  |             toolTip1.InitialDelay = 500; | ||||||
|  |             toolTip1.ReshowDelay = 100; | ||||||
|  |             //  | ||||||
|  |             // nudUpscale | ||||||
|  |             //  | ||||||
|  |             nudUpscale.Location = new System.Drawing.Point(12, 27); | ||||||
|  |             nudUpscale.Maximum = new decimal(new int[] { 255, 0, 0, 0 }); | ||||||
|  |             nudUpscale.Minimum = new decimal(new int[] { 1, 0, 0, 0 }); | ||||||
|  |             nudUpscale.Name = "nudUpscale"; | ||||||
|  |             nudUpscale.Size = new System.Drawing.Size(51, 23); | ||||||
|  |             nudUpscale.TabIndex = 2; | ||||||
|  |             toolTip1.SetToolTip(nudUpscale, "Pixel upscale factor (4 means that for each frame pixel there will be 4x4 pixels generated)"); | ||||||
|  |             nudUpscale.Value = new decimal(new int[] { 4, 0, 0, 0 }); | ||||||
|  |             //  | ||||||
|  |             // chkTransparent | ||||||
|  |             //  | ||||||
|  |             chkTransparent.AutoSize = true; | ||||||
|  |             chkTransparent.Location = new System.Drawing.Point(85, 18); | ||||||
|  |             chkTransparent.Name = "chkTransparent"; | ||||||
|  |             chkTransparent.Size = new System.Drawing.Size(155, 19); | ||||||
|  |             chkTransparent.TabIndex = 5; | ||||||
|  |             chkTransparent.Text = "Transparent background"; | ||||||
|  |             toolTip1.SetToolTip(chkTransparent, "Make background transparent"); | ||||||
|  |             chkTransparent.UseVisualStyleBackColor = true; | ||||||
|  |             chkTransparent.CheckedChanged += chkTransparent_CheckedChanged; | ||||||
|  |             //  | ||||||
|  |             // dlgSaveImage | ||||||
|  |             //  | ||||||
|  |             dlgSaveImage.DefaultExt = "png"; | ||||||
|  |             dlgSaveImage.Filter = "PNG Image|*.png;*.PNG"; | ||||||
|  |             //  | ||||||
|  |             // lblUpscale | ||||||
|  |             //  | ||||||
|  |             lblUpscale.AutoSize = true; | ||||||
|  |             lblUpscale.Location = new System.Drawing.Point(12, 9); | ||||||
|  |             lblUpscale.Name = "lblUpscale"; | ||||||
|  |             lblUpscale.Size = new System.Drawing.Size(51, 15); | ||||||
|  |             lblUpscale.TabIndex = 4; | ||||||
|  |             lblUpscale.Text = "Upscale:"; | ||||||
|  |             //  | ||||||
|  |             // chkBlackBG | ||||||
|  |             //  | ||||||
|  |             chkBlackBG.AutoSize = true; | ||||||
|  |             chkBlackBG.Enabled = false; | ||||||
|  |             chkBlackBG.Location = new System.Drawing.Point(85, 35); | ||||||
|  |             chkBlackBG.Name = "chkBlackBG"; | ||||||
|  |             chkBlackBG.Size = new System.Drawing.Size(132, 19); | ||||||
|  |             chkBlackBG.TabIndex = 6; | ||||||
|  |             chkBlackBG.Text = "Background is black"; | ||||||
|  |             toolTip1.SetToolTip(chkBlackBG, "White color is considered as background by default. Check this to invert that"); | ||||||
|  |             chkBlackBG.UseVisualStyleBackColor = true; | ||||||
|  |             //  | ||||||
|  |             // FrameScreenshot | ||||||
|  |             //  | ||||||
|  |             AcceptButton = btnClose; | ||||||
|  |             AutoScaleDimensions = new System.Drawing.SizeF(7F, 15F); | ||||||
|  |             AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; | ||||||
|  |             CancelButton = btnClose; | ||||||
|  |             ClientSize = new System.Drawing.Size(244, 111); | ||||||
|  |             Controls.Add(chkBlackBG); | ||||||
|  |             Controls.Add(chkTransparent); | ||||||
|  |             Controls.Add(nudUpscale); | ||||||
|  |             Controls.Add(lblUpscale); | ||||||
|  |             Controls.Add(btnClose); | ||||||
|  |             Controls.Add(btnOK); | ||||||
|  |             FormBorderStyle = System.Windows.Forms.FormBorderStyle.FixedDialog; | ||||||
|  |             Name = "FrameScreenshot"; | ||||||
|  |             StartPosition = System.Windows.Forms.FormStartPosition.CenterParent; | ||||||
|  |             Text = "Frame Screenshot"; | ||||||
|  |             Load += FrameScreenshot_Load; | ||||||
|  |             ((System.ComponentModel.ISupportInitialize)nudUpscale).EndInit(); | ||||||
|  |             ResumeLayout(false); | ||||||
|  |             PerformLayout(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         #endregion | ||||||
|  |  | ||||||
|  |         private System.Windows.Forms.Button btnClose; | ||||||
|  |         private System.Windows.Forms.Button btnOK; | ||||||
|  |         private System.Windows.Forms.ToolTip toolTip1; | ||||||
|  |         private System.Windows.Forms.SaveFileDialog dlgSaveImage; | ||||||
|  |         private System.Windows.Forms.Label lblUpscale; | ||||||
|  |         private System.Windows.Forms.NumericUpDown nudUpscale; | ||||||
|  |         private System.Windows.Forms.CheckBox chkTransparent; | ||||||
|  |         private System.Windows.Forms.CheckBox chkBlackBG; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										69
									
								
								McBitFont/FrameScreenshot.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,69 @@ | |||||||
|  | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using System.ComponentModel; | ||||||
|  | using System.Data; | ||||||
|  | using System.Drawing; | ||||||
|  | using System.Drawing.Imaging; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Security.Policy; | ||||||
|  | using System.Text; | ||||||
|  | using System.Threading.Tasks; | ||||||
|  | using System.Windows.Forms; | ||||||
|  | using static McBitFont.MainForm; | ||||||
|  |  | ||||||
|  | namespace McBitFont { | ||||||
|  |     public partial class FrameScreenshot : Form { | ||||||
|  |  | ||||||
|  |         private FrameMiniature f; | ||||||
|  |  | ||||||
|  |         public FrameScreenshot(FrameMiniature frame) { | ||||||
|  |             InitializeComponent(); | ||||||
|  |             f = frame; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private void btnOK_Click(object sender, EventArgs e) { | ||||||
|  |             if (dlgSaveImage.ShowDialog() == DialogResult.OK) { | ||||||
|  |                 int upscale = (int)nudUpscale.Value; | ||||||
|  |                 int x, y; | ||||||
|  |                 bool transp  = chkTransparent.Checked; | ||||||
|  |                 bool blackBG = chkBlackBG.Checked; | ||||||
|  |  | ||||||
|  |                 Bitmap bmp = new(f.width * upscale, f.height * upscale); | ||||||
|  |                 SolidBrush bb = new(Color.Black); | ||||||
|  |                 SolidBrush bw = new(Color.White); | ||||||
|  |                 using (Graphics g = Graphics.FromImage(bmp)) { | ||||||
|  |                     for (x = 0; x < f.width; x++) { | ||||||
|  |                         for (y = 0; y < f.height; y++) { | ||||||
|  |                             if (f.data[x, y]) { | ||||||
|  |                                 if (!transp || (transp && !blackBG)) g.FillRectangle(bb, x * upscale, y * upscale, upscale, upscale); | ||||||
|  |                             } else | ||||||
|  |                                 if (!transp || (transp && blackBG)) g.FillRectangle(bw, x * upscale, y * upscale, upscale, upscale); | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 bool err = false; | ||||||
|  |                 try { | ||||||
|  |                     bmp.Save(dlgSaveImage.FileName, ImageFormat.Png); | ||||||
|  |                 } | ||||||
|  |                 catch (Exception ex) { | ||||||
|  |                     err = true; | ||||||
|  |                     MessageBox.Show("There was an error during image save: " + ex.Message, "Error!", MessageBoxButtons.OK, MessageBoxIcon.Error); | ||||||
|  |                 } | ||||||
|  |                 if (!err) MessageBox.Show("Screenshot has been saved!", "Success!", MessageBoxButtons.OK, MessageBoxIcon.Information); | ||||||
|  |  | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private void FrameScreenshot_Load(object sender, EventArgs e) { | ||||||
|  |             btnOK.Focus(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private void btnClose_Click(object sender, EventArgs e) { | ||||||
|  |             DialogResult = DialogResult.OK; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private void chkTransparent_CheckedChanged(object sender, EventArgs e) { | ||||||
|  |             chkBlackBG.Enabled = chkTransparent.Checked; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										126
									
								
								McBitFont/FrameScreenshot.resx
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,126 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <root> | ||||||
|  |   <!-- | ||||||
|  |     Microsoft ResX Schema | ||||||
|  |  | ||||||
|  |     Version 2.0 | ||||||
|  |  | ||||||
|  |     The primary goals of this format is to allow a simple XML format | ||||||
|  |     that is mostly human readable. The generation and parsing of the | ||||||
|  |     various data types are done through the TypeConverter classes | ||||||
|  |     associated with the data types. | ||||||
|  |  | ||||||
|  |     Example: | ||||||
|  |  | ||||||
|  |     ... ado.net/XML headers & schema ... | ||||||
|  |     <resheader name="resmimetype">text/microsoft-resx</resheader> | ||||||
|  |     <resheader name="version">2.0</resheader> | ||||||
|  |     <resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader> | ||||||
|  |     <resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader> | ||||||
|  |     <data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data> | ||||||
|  |     <data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data> | ||||||
|  |     <data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64"> | ||||||
|  |         <value>[base64 mime encoded serialized .NET Framework object]</value> | ||||||
|  |     </data> | ||||||
|  |     <data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> | ||||||
|  |         <value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value> | ||||||
|  |         <comment>This is a comment</comment> | ||||||
|  |     </data> | ||||||
|  |  | ||||||
|  |     There are any number of "resheader" rows that contain simple | ||||||
|  |     name/value pairs. | ||||||
|  |  | ||||||
|  |     Each data row contains a name, and value. The row also contains a | ||||||
|  |     type or mimetype. Type corresponds to a .NET class that support | ||||||
|  |     text/value conversion through the TypeConverter architecture. | ||||||
|  |     Classes that don't support this are serialized and stored with the | ||||||
|  |     mimetype set. | ||||||
|  |  | ||||||
|  |     The mimetype is used for serialized objects, and tells the | ||||||
|  |     ResXResourceReader how to depersist the object. This is currently not | ||||||
|  |     extensible. For a given mimetype the value must be set accordingly: | ||||||
|  |  | ||||||
|  |     Note - application/x-microsoft.net.object.binary.base64 is the format | ||||||
|  |     that the ResXResourceWriter will generate, however the reader can | ||||||
|  |     read any of the formats listed below. | ||||||
|  |  | ||||||
|  |     mimetype: application/x-microsoft.net.object.binary.base64 | ||||||
|  |     value   : The object must be serialized with | ||||||
|  |             : System.Runtime.Serialization.Formatters.Binary.BinaryFormatter | ||||||
|  |             : and then encoded with base64 encoding. | ||||||
|  |  | ||||||
|  |     mimetype: application/x-microsoft.net.object.soap.base64 | ||||||
|  |     value   : The object must be serialized with | ||||||
|  |             : System.Runtime.Serialization.Formatters.Soap.SoapFormatter | ||||||
|  |             : and then encoded with base64 encoding. | ||||||
|  |  | ||||||
|  |     mimetype: application/x-microsoft.net.object.bytearray.base64 | ||||||
|  |     value   : The object must be serialized into a byte array | ||||||
|  |             : using a System.ComponentModel.TypeConverter | ||||||
|  |             : and then encoded with base64 encoding. | ||||||
|  |     --> | ||||||
|  |   <xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"> | ||||||
|  |     <xsd:import namespace="http://www.w3.org/XML/1998/namespace" /> | ||||||
|  |     <xsd:element name="root" msdata:IsDataSet="true"> | ||||||
|  |       <xsd:complexType> | ||||||
|  |         <xsd:choice maxOccurs="unbounded"> | ||||||
|  |           <xsd:element name="metadata"> | ||||||
|  |             <xsd:complexType> | ||||||
|  |               <xsd:sequence> | ||||||
|  |                 <xsd:element name="value" type="xsd:string" minOccurs="0" /> | ||||||
|  |               </xsd:sequence> | ||||||
|  |               <xsd:attribute name="name" use="required" type="xsd:string" /> | ||||||
|  |               <xsd:attribute name="type" type="xsd:string" /> | ||||||
|  |               <xsd:attribute name="mimetype" type="xsd:string" /> | ||||||
|  |               <xsd:attribute ref="xml:space" /> | ||||||
|  |             </xsd:complexType> | ||||||
|  |           </xsd:element> | ||||||
|  |           <xsd:element name="assembly"> | ||||||
|  |             <xsd:complexType> | ||||||
|  |               <xsd:attribute name="alias" type="xsd:string" /> | ||||||
|  |               <xsd:attribute name="name" type="xsd:string" /> | ||||||
|  |             </xsd:complexType> | ||||||
|  |           </xsd:element> | ||||||
|  |           <xsd:element name="data"> | ||||||
|  |             <xsd:complexType> | ||||||
|  |               <xsd:sequence> | ||||||
|  |                 <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" /> | ||||||
|  |                 <xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" /> | ||||||
|  |               </xsd:sequence> | ||||||
|  |               <xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" /> | ||||||
|  |               <xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" /> | ||||||
|  |               <xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" /> | ||||||
|  |               <xsd:attribute ref="xml:space" /> | ||||||
|  |             </xsd:complexType> | ||||||
|  |           </xsd:element> | ||||||
|  |           <xsd:element name="resheader"> | ||||||
|  |             <xsd:complexType> | ||||||
|  |               <xsd:sequence> | ||||||
|  |                 <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" /> | ||||||
|  |               </xsd:sequence> | ||||||
|  |               <xsd:attribute name="name" type="xsd:string" use="required" /> | ||||||
|  |             </xsd:complexType> | ||||||
|  |           </xsd:element> | ||||||
|  |         </xsd:choice> | ||||||
|  |       </xsd:complexType> | ||||||
|  |     </xsd:element> | ||||||
|  |   </xsd:schema> | ||||||
|  |   <resheader name="resmimetype"> | ||||||
|  |     <value>text/microsoft-resx</value> | ||||||
|  |   </resheader> | ||||||
|  |   <resheader name="version"> | ||||||
|  |     <value>2.0</value> | ||||||
|  |   </resheader> | ||||||
|  |   <resheader name="reader"> | ||||||
|  |     <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | ||||||
|  |   </resheader> | ||||||
|  |   <resheader name="writer"> | ||||||
|  |     <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | ||||||
|  |   </resheader> | ||||||
|  |   <metadata name="toolTip1.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"> | ||||||
|  |     <value>17, 17</value> | ||||||
|  |   </metadata> | ||||||
|  |   <metadata name="dlgSaveImage.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"> | ||||||
|  |     <value>115, 17</value> | ||||||
|  |   </metadata> | ||||||
|  | </root> | ||||||
							
								
								
									
										2
									
								
								McBitFont/ImageImporter.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						| @@ -377,7 +377,7 @@ | |||||||
|             Name = "ImageImporter"; |             Name = "ImageImporter"; | ||||||
|             ShowIcon = false; |             ShowIcon = false; | ||||||
|             ShowInTaskbar = false; |             ShowInTaskbar = false; | ||||||
|             StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen; |             StartPosition = System.Windows.Forms.FormStartPosition.CenterParent; | ||||||
|             Text = "Import Image"; |             Text = "Import Image"; | ||||||
|             Paint += ImageImporter_Paint; |             Paint += ImageImporter_Paint; | ||||||
|             ((System.ComponentModel.ISupportInitialize)pbOriginal).EndInit(); |             ((System.ComponentModel.ISupportInitialize)pbOriginal).EndInit(); | ||||||
|   | |||||||
| @@ -123,7 +123,4 @@ | |||||||
|   <metadata name="dlgLoadImage.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"> |   <metadata name="dlgLoadImage.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"> | ||||||
|     <value>17, 17</value> |     <value>17, 17</value> | ||||||
|   </metadata> |   </metadata> | ||||||
|   <metadata name="toolTip1.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"> |  | ||||||
|     <value>147, 17</value> |  | ||||||
|   </metadata> |  | ||||||
| </root> | </root> | ||||||
| @@ -20,8 +20,10 @@ | |||||||
|     <UseWindowsForms>true</UseWindowsForms> |     <UseWindowsForms>true</UseWindowsForms> | ||||||
|     <ImportWindowsDesktopTargets>true</ImportWindowsDesktopTargets> |     <ImportWindowsDesktopTargets>true</ImportWindowsDesktopTargets> | ||||||
|     <ApplicationIcon>icon_64.ico</ApplicationIcon> |     <ApplicationIcon>icon_64.ico</ApplicationIcon> | ||||||
|     <AssemblyVersion>2.0.0.0</AssemblyVersion> |     <AssemblyVersion>2.8.0.0</AssemblyVersion> | ||||||
|     <FileVersion>2.0.0.0</FileVersion> |     <FileVersion>2.8.0.0</FileVersion> | ||||||
|  |     <Version>$(VersionPrefix)2.8.0</Version> | ||||||
|  |     <Copyright>Anton Mukhin</Copyright> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'"> |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'"> | ||||||
|     <DebugType>portable</DebugType> |     <DebugType>portable</DebugType> | ||||||
|   | |||||||
							
								
								
									
										131
									
								
								McBitFont/McCursor.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,131 @@ | |||||||
|  | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using System.Drawing; | ||||||
|  | using System.Drawing.Drawing2D; | ||||||
|  | using System.Drawing.Imaging; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Runtime.CompilerServices; | ||||||
|  | using System.Runtime.InteropServices; | ||||||
|  | using System.Text; | ||||||
|  | using System.Threading.Tasks; | ||||||
|  | using System.Windows.Forms; | ||||||
|  |  | ||||||
|  | namespace McBitFont { | ||||||
|  |     internal class McCursor { | ||||||
|  |  | ||||||
|  |         public struct IconInfo { | ||||||
|  |             public bool fIcon; | ||||||
|  |             public int xHotspot; | ||||||
|  |             public int yHotspot; | ||||||
|  |             public IntPtr hbmMask; | ||||||
|  |             public IntPtr hbmColor; | ||||||
|  |         } | ||||||
|  |         [DllImport("user32.dll")] | ||||||
|  |         [return: MarshalAs(UnmanagedType.Bool)] | ||||||
|  |         public static extern bool GetIconInfo(IntPtr hIcon, ref IconInfo pIconInfo); | ||||||
|  |         [DllImport("user32.dll")] | ||||||
|  |         public static extern IntPtr CreateIconIndirect(ref IconInfo icon); | ||||||
|  |  | ||||||
|  |         /// <summary> | ||||||
|  |         /// Create a cursor from a bitmap without resizing and with the specified | ||||||
|  |         /// hot spot | ||||||
|  |         /// </summary> | ||||||
|  |         public static Cursor CreateCursorNoResize(Bitmap bmp, int xHotSpot, int yHotSpot) { | ||||||
|  |             IntPtr ptr = bmp.GetHicon(); | ||||||
|  |             IconInfo tmp = new IconInfo(); | ||||||
|  |             GetIconInfo(ptr, ref tmp); | ||||||
|  |             tmp.xHotspot = xHotSpot; | ||||||
|  |             tmp.yHotspot = yHotSpot; | ||||||
|  |             tmp.fIcon = false; | ||||||
|  |             ptr = CreateIconIndirect(ref tmp); | ||||||
|  |             return new Cursor(ptr); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         /// <summary> | ||||||
|  |         /// Create a 32x32 cursor from a bitmap, with the hot spot in the middle | ||||||
|  |         /// </summary> | ||||||
|  |         public static Cursor CreateCursor(Bitmap bmp) { | ||||||
|  |             int xHotSpot = 16; | ||||||
|  |             int yHotSpot = 16; | ||||||
|  |  | ||||||
|  |             IntPtr ptr = ((Bitmap)ResizeImage(bmp, 32, 32)).GetHicon(); | ||||||
|  |             IconInfo tmp = new IconInfo(); | ||||||
|  |             GetIconInfo(ptr, ref tmp); | ||||||
|  |             tmp.xHotspot = xHotSpot; | ||||||
|  |             tmp.yHotspot = yHotSpot; | ||||||
|  |             tmp.fIcon = false; | ||||||
|  |             ptr = CreateIconIndirect(ref tmp); | ||||||
|  |             return new Cursor(ptr); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         /// <summary> | ||||||
|  |         /// Resize the image to the specified width and height. | ||||||
|  |         /// </summary> | ||||||
|  |         /// <param name="image">The image to resize.</param> | ||||||
|  |         /// <param name="width">The width to resize to.</param> | ||||||
|  |         /// <param name="height">The height to resize to.</param> | ||||||
|  |         /// <returns>The resized image.</returns> | ||||||
|  |         public static Bitmap ResizeImage(Image image, int width, int height) { | ||||||
|  |             var destRect = new Rectangle(0, 0, width, height); | ||||||
|  |             var destImage = new Bitmap(width, height); | ||||||
|  |  | ||||||
|  |             destImage.SetResolution(image.HorizontalResolution, image.VerticalResolution); | ||||||
|  |  | ||||||
|  |             using (var graphics = Graphics.FromImage(destImage)) { | ||||||
|  |                 graphics.CompositingMode = CompositingMode.SourceCopy; | ||||||
|  |                 graphics.CompositingQuality = CompositingQuality.HighQuality; | ||||||
|  |                 graphics.InterpolationMode = InterpolationMode.HighQualityBicubic; | ||||||
|  |                 graphics.SmoothingMode = SmoothingMode.HighQuality; | ||||||
|  |                 graphics.PixelOffsetMode = PixelOffsetMode.HighQuality; | ||||||
|  |  | ||||||
|  |                 using (var wrapMode = new ImageAttributes()) { | ||||||
|  |                     wrapMode.SetWrapMode(WrapMode.TileFlipXY); | ||||||
|  |                     graphics.DrawImage(image, destRect, 0, 0, image.Width, image.Height, GraphicsUnit.Pixel, wrapMode); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             return destImage; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         public static Cursor GetCursor(int penSize, int cellSize, int gap) { | ||||||
|  |             int size = (cellSize + gap) * penSize; | ||||||
|  |  | ||||||
|  |             Bitmap bmp = new(size, size); | ||||||
|  |             Pen pb = new(Color.Black, 1); | ||||||
|  |             SolidBrush bw = new(Color.FromArgb(160, Color.White)); | ||||||
|  |             using (Graphics g = Graphics.FromImage(bmp)) { | ||||||
|  |                 g.DrawRectangle(pb, 0, 0, size-1, size-1); | ||||||
|  |                 g.FillRectangle(bw, 1, 1, size - 2, size - 2); | ||||||
|  |             } | ||||||
|  |             return CreateCursorNoResize(bmp, cellSize / 2, cellSize / 2); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         public static Cursor GetCursorSelect() { | ||||||
|  |             Point[] arrow   = { new(1, 1), new(12, 12), new(11, 13), new(6, 13), new(2, 17), new(1, 16) }; | ||||||
|  |             Point[] corner1 = { new(13, 6), new(20, 6), new(20, 13), new(17, 13), new(17, 9), new(13, 9) }; | ||||||
|  |             Point[] corner2 = { new(17, 16), new(20, 16), new(20, 23), new(13, 23), new(13, 20), new(17, 20) }; | ||||||
|  |             Point[] corner3 = { new(3, 16), new(6, 16), new(6, 20), new(10, 20), new(10, 23), new(3, 23) }; | ||||||
|  |             Point[] corner4 = { new(6, 6), new(10, 6), new(10, 9), new(6, 9) }; | ||||||
|  |  | ||||||
|  |             Bitmap bmp = new(21, 24); | ||||||
|  |             Pen pb  = new(Color.Black, 1); | ||||||
|  |             SolidBrush bw = new (Color.White); | ||||||
|  |             using (Graphics g = Graphics.FromImage(bmp)) { | ||||||
|  |                 g.FillPolygon(bw, corner1); | ||||||
|  |                 g.DrawPolygon(pb, corner1); | ||||||
|  |                 g.FillPolygon(bw, corner2); | ||||||
|  |                 g.DrawPolygon(pb, corner2); | ||||||
|  |                 g.FillPolygon(bw, corner3); | ||||||
|  |                 g.DrawPolygon(pb, corner3); | ||||||
|  |                 g.FillPolygon(bw, corner4); | ||||||
|  |                 g.DrawPolygon(pb, corner4); | ||||||
|  |                 g.FillPolygon(bw, arrow); | ||||||
|  |                 g.DrawPolygon(pb, arrow); | ||||||
|  |             } | ||||||
|  |             return CreateCursorNoResize(bmp, 1, 1); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										686
									
								
								McBitFont/New.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						| @@ -23,469 +23,421 @@ | |||||||
|         /// the contents of this method with the code editor. |         /// the contents of this method with the code editor. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         private void InitializeComponent() { |         private void InitializeComponent() { | ||||||
|             this.components = new System.ComponentModel.Container(); |             components = new System.ComponentModel.Container(); | ||||||
|             this.nudNewX = new System.Windows.Forms.NumericUpDown(); |             nudNewX = new System.Windows.Forms.NumericUpDown(); | ||||||
|             this.nudNewY = new System.Windows.Forms.NumericUpDown(); |             nudNewY = new System.Windows.Forms.NumericUpDown(); | ||||||
|             this.label1 = new System.Windows.Forms.Label(); |             label1 = new System.Windows.Forms.Label(); | ||||||
|             this.label2 = new System.Windows.Forms.Label(); |             label2 = new System.Windows.Forms.Label(); | ||||||
|             this.rbMono = new System.Windows.Forms.RadioButton(); |             rbMono = new System.Windows.Forms.RadioButton(); | ||||||
|             this.rbVar = new System.Windows.Forms.RadioButton(); |             rbVar = new System.Windows.Forms.RadioButton(); | ||||||
|             this.cbNotPrintable = new System.Windows.Forms.CheckBox(); |             cbNotPrintable = new System.Windows.Forms.CheckBox(); | ||||||
|             this.cbLatin = new System.Windows.Forms.CheckBox(); |             cbLatin = new System.Windows.Forms.CheckBox(); | ||||||
|             this.cbExtended = new System.Windows.Forms.CheckBox(); |             cbExtended = new System.Windows.Forms.CheckBox(); | ||||||
|             this.btnOK = new System.Windows.Forms.Button(); |             btnOK = new System.Windows.Forms.Button(); | ||||||
|             this.btnCancel = new System.Windows.Forms.Button(); |             btnCancel = new System.Windows.Forms.Button(); | ||||||
|             this.cbSingle = new System.Windows.Forms.CheckBox(); |             cbSingle = new System.Windows.Forms.CheckBox(); | ||||||
|             this.toolTip1 = new System.Windows.Forms.ToolTip(this.components); |             toolTip1 = new System.Windows.Forms.ToolTip(components); | ||||||
|             this.cbEncoding = new System.Windows.Forms.ComboBox(); |             cbEncoding = new System.Windows.Forms.ComboBox(); | ||||||
|             this.panel1 = new System.Windows.Forms.Panel(); |             panel1 = new System.Windows.Forms.Panel(); | ||||||
|             this.pbChar2 = new System.Windows.Forms.PictureBox(); |             pbChar2 = new System.Windows.Forms.PictureBox(); | ||||||
|             this.pbChar1 = new System.Windows.Forms.PictureBox(); |             pbChar1 = new System.Windows.Forms.PictureBox(); | ||||||
|             this.btnFont = new System.Windows.Forms.Button(); |             btnFont = new System.Windows.Forms.Button(); | ||||||
|             this.dlgFont = new System.Windows.Forms.FontDialog(); |             dlgFont = new System.Windows.Forms.FontDialog(); | ||||||
|             this.cbFontBased = new System.Windows.Forms.CheckBox(); |             cbFontBased = new System.Windows.Forms.CheckBox(); | ||||||
|             this.lblFont = new System.Windows.Forms.Label(); |             lblFont = new System.Windows.Forms.Label(); | ||||||
|             this.nudShiftX = new System.Windows.Forms.NumericUpDown(); |             nudShiftX = new System.Windows.Forms.NumericUpDown(); | ||||||
|             this.nudShiftY = new System.Windows.Forms.NumericUpDown(); |             nudShiftY = new System.Windows.Forms.NumericUpDown(); | ||||||
|             this.lblShiftX = new System.Windows.Forms.Label(); |             lblShiftX = new System.Windows.Forms.Label(); | ||||||
|             this.lblShiftY = new System.Windows.Forms.Label(); |             lblShiftY = new System.Windows.Forms.Label(); | ||||||
|             this.pnlFont = new System.Windows.Forms.Panel(); |             pnlFont = new System.Windows.Forms.Panel(); | ||||||
|             this.label4 = new System.Windows.Forms.Label(); |             label4 = new System.Windows.Forms.Label(); | ||||||
|             this.label3 = new System.Windows.Forms.Label(); |             label3 = new System.Windows.Forms.Label(); | ||||||
|             this.nudChar2 = new System.Windows.Forms.NumericUpDown(); |             nudChar2 = new System.Windows.Forms.NumericUpDown(); | ||||||
|             this.nudChar1 = new System.Windows.Forms.NumericUpDown(); |             nudChar1 = new System.Windows.Forms.NumericUpDown(); | ||||||
|             this.cbDigits = new System.Windows.Forms.CheckBox(); |             cbDigits = new System.Windows.Forms.CheckBox(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.nudNewX)).BeginInit(); |             ((System.ComponentModel.ISupportInitialize)nudNewX).BeginInit(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.nudNewY)).BeginInit(); |             ((System.ComponentModel.ISupportInitialize)nudNewY).BeginInit(); | ||||||
|             this.panel1.SuspendLayout(); |             panel1.SuspendLayout(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.pbChar2)).BeginInit(); |             ((System.ComponentModel.ISupportInitialize)pbChar2).BeginInit(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.pbChar1)).BeginInit(); |             ((System.ComponentModel.ISupportInitialize)pbChar1).BeginInit(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.nudShiftX)).BeginInit(); |             ((System.ComponentModel.ISupportInitialize)nudShiftX).BeginInit(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.nudShiftY)).BeginInit(); |             ((System.ComponentModel.ISupportInitialize)nudShiftY).BeginInit(); | ||||||
|             this.pnlFont.SuspendLayout(); |             pnlFont.SuspendLayout(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.nudChar2)).BeginInit(); |             ((System.ComponentModel.ISupportInitialize)nudChar2).BeginInit(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.nudChar1)).BeginInit(); |             ((System.ComponentModel.ISupportInitialize)nudChar1).BeginInit(); | ||||||
|             this.SuspendLayout(); |             SuspendLayout(); | ||||||
|             //  |             //  | ||||||
|             // nudNewX |             // nudNewX | ||||||
|             //  |             //  | ||||||
|             this.nudNewX.Location = new System.Drawing.Point(68, 32); |             nudNewX.Location = new System.Drawing.Point(68, 32); | ||||||
|             this.nudNewX.Maximum = new decimal(new int[] { |             nudNewX.Maximum = new decimal(new int[] { 255, 0, 0, 0 }); | ||||||
|             255, |             nudNewX.Minimum = new decimal(new int[] { 1, 0, 0, 0 }); | ||||||
|             0, |             nudNewX.Name = "nudNewX"; | ||||||
|             0, |             nudNewX.Size = new System.Drawing.Size(57, 23); | ||||||
|             0}); |             nudNewX.TabIndex = 0; | ||||||
|             this.nudNewX.Minimum = new decimal(new int[] { |             nudNewX.Value = new decimal(new int[] { 32, 0, 0, 0 }); | ||||||
|             1, |             nudNewX.ValueChanged += nudNewX_ValueChanged; | ||||||
|             0, |             nudNewX.Enter += nudFocus; | ||||||
|             0, |  | ||||||
|             0}); |  | ||||||
|             this.nudNewX.Name = "nudNewX"; |  | ||||||
|             this.nudNewX.Size = new System.Drawing.Size(57, 20); |  | ||||||
|             this.nudNewX.TabIndex = 0; |  | ||||||
|             this.nudNewX.Value = new decimal(new int[] { |  | ||||||
|             32, |  | ||||||
|             0, |  | ||||||
|             0, |  | ||||||
|             0}); |  | ||||||
|             this.nudNewX.ValueChanged += new System.EventHandler(this.nudNewX_ValueChanged); |  | ||||||
|             this.nudNewX.Enter += new System.EventHandler(this.nudFocus); |  | ||||||
|             //  |             //  | ||||||
|             // nudNewY |             // nudNewY | ||||||
|             //  |             //  | ||||||
|             this.nudNewY.Location = new System.Drawing.Point(68, 58); |             nudNewY.Location = new System.Drawing.Point(68, 58); | ||||||
|             this.nudNewY.Maximum = new decimal(new int[] { |             nudNewY.Maximum = new decimal(new int[] { 255, 0, 0, 0 }); | ||||||
|             255, |             nudNewY.Minimum = new decimal(new int[] { 1, 0, 0, 0 }); | ||||||
|             0, |             nudNewY.Name = "nudNewY"; | ||||||
|             0, |             nudNewY.Size = new System.Drawing.Size(57, 23); | ||||||
|             0}); |             nudNewY.TabIndex = 1; | ||||||
|             this.nudNewY.Minimum = new decimal(new int[] { |             nudNewY.Value = new decimal(new int[] { 32, 0, 0, 0 }); | ||||||
|             1, |             nudNewY.ValueChanged += nudNewX_ValueChanged; | ||||||
|             0, |             nudNewY.Enter += nudFocus; | ||||||
|             0, |  | ||||||
|             0}); |  | ||||||
|             this.nudNewY.Name = "nudNewY"; |  | ||||||
|             this.nudNewY.Size = new System.Drawing.Size(57, 20); |  | ||||||
|             this.nudNewY.TabIndex = 1; |  | ||||||
|             this.nudNewY.Value = new decimal(new int[] { |  | ||||||
|             32, |  | ||||||
|             0, |  | ||||||
|             0, |  | ||||||
|             0}); |  | ||||||
|             this.nudNewY.ValueChanged += new System.EventHandler(this.nudNewX_ValueChanged); |  | ||||||
|             this.nudNewY.Enter += new System.EventHandler(this.nudFocus); |  | ||||||
|             //  |             //  | ||||||
|             // label1 |             // label1 | ||||||
|             //  |             //  | ||||||
|             this.label1.AutoSize = true; |             label1.AutoSize = true; | ||||||
|             this.label1.Location = new System.Drawing.Point(24, 34); |             label1.Location = new System.Drawing.Point(24, 34); | ||||||
|             this.label1.Name = "label1"; |             label1.Name = "label1"; | ||||||
|             this.label1.Size = new System.Drawing.Size(38, 13); |             label1.Size = new System.Drawing.Size(42, 15); | ||||||
|             this.label1.TabIndex = 2; |             label1.TabIndex = 2; | ||||||
|             this.label1.Text = "Width:"; |             label1.Text = "Width:"; | ||||||
|             this.label1.TextAlign = System.Drawing.ContentAlignment.MiddleRight; |             label1.TextAlign = System.Drawing.ContentAlignment.MiddleRight; | ||||||
|             //  |             //  | ||||||
|             // label2 |             // label2 | ||||||
|             //  |             //  | ||||||
|             this.label2.AutoSize = true; |             label2.AutoSize = true; | ||||||
|             this.label2.Location = new System.Drawing.Point(21, 60); |             label2.Location = new System.Drawing.Point(21, 60); | ||||||
|             this.label2.Name = "label2"; |             label2.Name = "label2"; | ||||||
|             this.label2.Size = new System.Drawing.Size(41, 13); |             label2.Size = new System.Drawing.Size(46, 15); | ||||||
|             this.label2.TabIndex = 3; |             label2.TabIndex = 3; | ||||||
|             this.label2.Text = "Height:"; |             label2.Text = "Height:"; | ||||||
|             this.label2.TextAlign = System.Drawing.ContentAlignment.MiddleRight; |             label2.TextAlign = System.Drawing.ContentAlignment.MiddleRight; | ||||||
|             //  |             //  | ||||||
|             // rbMono |             // rbMono | ||||||
|             //  |             //  | ||||||
|             this.rbMono.AutoSize = true; |             rbMono.AutoSize = true; | ||||||
|             this.rbMono.Checked = true; |             rbMono.Checked = true; | ||||||
|             this.rbMono.Location = new System.Drawing.Point(24, 84); |             rbMono.Location = new System.Drawing.Point(24, 84); | ||||||
|             this.rbMono.Name = "rbMono"; |             rbMono.Name = "rbMono"; | ||||||
|             this.rbMono.Size = new System.Drawing.Size(87, 17); |             rbMono.Size = new System.Drawing.Size(94, 19); | ||||||
|             this.rbMono.TabIndex = 4; |             rbMono.TabIndex = 4; | ||||||
|             this.rbMono.TabStop = true; |             rbMono.TabStop = true; | ||||||
|             this.rbMono.Text = "Monospaced"; |             rbMono.Text = "Monospaced"; | ||||||
|             this.rbMono.UseVisualStyleBackColor = true; |             rbMono.UseVisualStyleBackColor = true; | ||||||
|             //  |             //  | ||||||
|             // rbVar |             // rbVar | ||||||
|             //  |             //  | ||||||
|             this.rbVar.AutoSize = true; |             rbVar.AutoSize = true; | ||||||
|             this.rbVar.Location = new System.Drawing.Point(24, 107); |             rbVar.Location = new System.Drawing.Point(24, 107); | ||||||
|             this.rbVar.Name = "rbVar"; |             rbVar.Name = "rbVar"; | ||||||
|             this.rbVar.Size = new System.Drawing.Size(91, 17); |             rbVar.Size = new System.Drawing.Size(99, 19); | ||||||
|             this.rbVar.TabIndex = 5; |             rbVar.TabIndex = 5; | ||||||
|             this.rbVar.Text = "Variable width"; |             rbVar.Text = "Variable width"; | ||||||
|             this.rbVar.UseVisualStyleBackColor = true; |             rbVar.UseVisualStyleBackColor = true; | ||||||
|             //  |             //  | ||||||
|             // cbNotPrintable |             // cbNotPrintable | ||||||
|             //  |             //  | ||||||
|             this.cbNotPrintable.AutoSize = true; |             cbNotPrintable.AutoSize = true; | ||||||
|             this.cbNotPrintable.Location = new System.Drawing.Point(140, 77); |             cbNotPrintable.Location = new System.Drawing.Point(140, 77); | ||||||
|             this.cbNotPrintable.Name = "cbNotPrintable"; |             cbNotPrintable.Name = "cbNotPrintable"; | ||||||
|             this.cbNotPrintable.Size = new System.Drawing.Size(116, 17); |             cbNotPrintable.Size = new System.Drawing.Size(130, 19); | ||||||
|             this.cbNotPrintable.TabIndex = 7; |             cbNotPrintable.TabIndex = 7; | ||||||
|             this.cbNotPrintable.Text = "0-31 (Not printable)"; |             cbNotPrintable.Text = "0-31 (Not printable)"; | ||||||
|             this.cbNotPrintable.UseVisualStyleBackColor = true; |             cbNotPrintable.UseVisualStyleBackColor = true; | ||||||
|             this.cbNotPrintable.CheckedChanged += new System.EventHandler(this.checkboxChanged); |             cbNotPrintable.CheckedChanged += checkboxChanged; | ||||||
|             //  |             //  | ||||||
|             // cbLatin |             // cbLatin | ||||||
|             //  |             //  | ||||||
|             this.cbLatin.AutoSize = true; |             cbLatin.AutoSize = true; | ||||||
|             this.cbLatin.Checked = true; |             cbLatin.Checked = true; | ||||||
|             this.cbLatin.CheckState = System.Windows.Forms.CheckState.Checked; |             cbLatin.CheckState = System.Windows.Forms.CheckState.Checked; | ||||||
|             this.cbLatin.Location = new System.Drawing.Point(140, 100); |             cbLatin.Location = new System.Drawing.Point(140, 100); | ||||||
|             this.cbLatin.Name = "cbLatin"; |             cbLatin.Name = "cbLatin"; | ||||||
|             this.cbLatin.Size = new System.Drawing.Size(91, 17); |             cbLatin.Size = new System.Drawing.Size(98, 19); | ||||||
|             this.cbLatin.TabIndex = 8; |             cbLatin.TabIndex = 8; | ||||||
|             this.cbLatin.Text = "32-127 (Latin)"; |             cbLatin.Text = "32-127 (Latin)"; | ||||||
|             this.cbLatin.UseVisualStyleBackColor = true; |             cbLatin.UseVisualStyleBackColor = true; | ||||||
|             this.cbLatin.CheckedChanged += new System.EventHandler(this.checkboxChanged); |             cbLatin.CheckedChanged += checkboxChanged; | ||||||
|             //  |             //  | ||||||
|             // cbExtended |             // cbExtended | ||||||
|             //  |             //  | ||||||
|             this.cbExtended.AutoSize = true; |             cbExtended.AutoSize = true; | ||||||
|             this.cbExtended.Location = new System.Drawing.Point(140, 123); |             cbExtended.Location = new System.Drawing.Point(140, 123); | ||||||
|             this.cbExtended.Name = "cbExtended"; |             cbExtended.Name = "cbExtended"; | ||||||
|             this.cbExtended.Size = new System.Drawing.Size(119, 17); |             cbExtended.Size = new System.Drawing.Size(126, 19); | ||||||
|             this.cbExtended.TabIndex = 9; |             cbExtended.TabIndex = 9; | ||||||
|             this.cbExtended.Text = "128-255 (Extended)"; |             cbExtended.Text = "128-255 (Extended)"; | ||||||
|             this.cbExtended.UseVisualStyleBackColor = true; |             cbExtended.UseVisualStyleBackColor = true; | ||||||
|             this.cbExtended.CheckedChanged += new System.EventHandler(this.checkboxChanged); |             cbExtended.CheckedChanged += checkboxChanged; | ||||||
|             //  |             //  | ||||||
|             // btnOK |             // btnOK | ||||||
|             //  |             //  | ||||||
|             this.btnOK.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); |             btnOK.Anchor = System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left; | ||||||
|             this.btnOK.Location = new System.Drawing.Point(47, 178); |             btnOK.Location = new System.Drawing.Point(47, 178); | ||||||
|             this.btnOK.Name = "btnOK"; |             btnOK.Name = "btnOK"; | ||||||
|             this.btnOK.Size = new System.Drawing.Size(75, 23); |             btnOK.Size = new System.Drawing.Size(75, 23); | ||||||
|             this.btnOK.TabIndex = 10; |             btnOK.TabIndex = 10; | ||||||
|             this.btnOK.Text = "OK"; |             btnOK.Text = "OK"; | ||||||
|             this.btnOK.UseVisualStyleBackColor = true; |             btnOK.UseVisualStyleBackColor = true; | ||||||
|             this.btnOK.Click += new System.EventHandler(this.btnOK_Click); |             btnOK.Click += btnOK_Click; | ||||||
|             //  |             //  | ||||||
|             // btnCancel |             // btnCancel | ||||||
|             //  |             //  | ||||||
|             this.btnCancel.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); |             btnCancel.Anchor = System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left; | ||||||
|             this.btnCancel.DialogResult = System.Windows.Forms.DialogResult.Cancel; |             btnCancel.DialogResult = System.Windows.Forms.DialogResult.Cancel; | ||||||
|             this.btnCancel.Location = new System.Drawing.Point(140, 178); |             btnCancel.Location = new System.Drawing.Point(140, 178); | ||||||
|             this.btnCancel.Name = "btnCancel"; |             btnCancel.Name = "btnCancel"; | ||||||
|             this.btnCancel.Size = new System.Drawing.Size(75, 23); |             btnCancel.Size = new System.Drawing.Size(75, 23); | ||||||
|             this.btnCancel.TabIndex = 11; |             btnCancel.TabIndex = 11; | ||||||
|             this.btnCancel.Text = "Cancel"; |             btnCancel.Text = "Cancel"; | ||||||
|             this.btnCancel.UseVisualStyleBackColor = true; |             btnCancel.UseVisualStyleBackColor = true; | ||||||
|             this.btnCancel.Click += new System.EventHandler(this.btnCancel_Click); |             btnCancel.Click += btnCancel_Click; | ||||||
|             //  |             //  | ||||||
|             // cbSingle |             // cbSingle | ||||||
|             //  |             //  | ||||||
|             this.cbSingle.AutoSize = true; |             cbSingle.AutoSize = true; | ||||||
|             this.cbSingle.Location = new System.Drawing.Point(140, 31); |             cbSingle.Location = new System.Drawing.Point(140, 31); | ||||||
|             this.cbSingle.Name = "cbSingle"; |             cbSingle.Name = "cbSingle"; | ||||||
|             this.cbSingle.Size = new System.Drawing.Size(84, 17); |             cbSingle.Size = new System.Drawing.Size(92, 19); | ||||||
|             this.cbSingle.TabIndex = 12; |             cbSingle.TabIndex = 12; | ||||||
|             this.cbSingle.Text = "Single frame"; |             cbSingle.Text = "Single frame"; | ||||||
|             this.cbSingle.UseVisualStyleBackColor = true; |             cbSingle.UseVisualStyleBackColor = true; | ||||||
|             this.cbSingle.CheckedChanged += new System.EventHandler(this.checkboxChanged); |             cbSingle.CheckedChanged += checkboxChanged; | ||||||
|             //  |             //  | ||||||
|             // toolTip1 |             // toolTip1 | ||||||
|             //  |             //  | ||||||
|             this.toolTip1.AutoPopDelay = 10000; |             toolTip1.AutoPopDelay = 10000; | ||||||
|             this.toolTip1.InitialDelay = 500; |             toolTip1.InitialDelay = 500; | ||||||
|             this.toolTip1.ReshowDelay = 100; |             toolTip1.ReshowDelay = 100; | ||||||
|             this.toolTip1.ToolTipTitle = "Info"; |             toolTip1.ToolTipTitle = "Info"; | ||||||
|             //  |             //  | ||||||
|             // cbEncoding |             // cbEncoding | ||||||
|             //  |             //  | ||||||
|             this.cbEncoding.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList; |             cbEncoding.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList; | ||||||
|             this.cbEncoding.Enabled = false; |             cbEncoding.Enabled = false; | ||||||
|             this.cbEncoding.FormattingEnabled = true; |             cbEncoding.FormattingEnabled = true; | ||||||
|             this.cbEncoding.Location = new System.Drawing.Point(140, 146); |             cbEncoding.Location = new System.Drawing.Point(140, 146); | ||||||
|             this.cbEncoding.Name = "cbEncoding"; |             cbEncoding.Name = "cbEncoding"; | ||||||
|             this.cbEncoding.Size = new System.Drawing.Size(121, 21); |             cbEncoding.Size = new System.Drawing.Size(121, 23); | ||||||
|             this.cbEncoding.TabIndex = 13; |             cbEncoding.TabIndex = 13; | ||||||
|             //  |             //  | ||||||
|             // panel1 |             // panel1 | ||||||
|             //  |             //  | ||||||
|             this.panel1.Controls.Add(this.pbChar2); |             panel1.Controls.Add(pbChar2); | ||||||
|             this.panel1.Controls.Add(this.pbChar1); |             panel1.Controls.Add(pbChar1); | ||||||
|             this.panel1.Location = new System.Drawing.Point(6, 24); |             panel1.Location = new System.Drawing.Point(6, 24); | ||||||
|             this.panel1.Name = "panel1"; |             panel1.Name = "panel1"; | ||||||
|             this.panel1.Size = new System.Drawing.Size(200, 124); |             panel1.Size = new System.Drawing.Size(200, 124); | ||||||
|             this.panel1.TabIndex = 14; |             panel1.TabIndex = 14; | ||||||
|             //  |             //  | ||||||
|             // pbChar2 |             // pbChar2 | ||||||
|             //  |             //  | ||||||
|             this.pbChar2.BorderStyle = System.Windows.Forms.BorderStyle.FixedSingle; |             pbChar2.BorderStyle = System.Windows.Forms.BorderStyle.FixedSingle; | ||||||
|             this.pbChar2.Location = new System.Drawing.Point(100, 0); |             pbChar2.Location = new System.Drawing.Point(100, 0); | ||||||
|             this.pbChar2.Name = "pbChar2"; |             pbChar2.Name = "pbChar2"; | ||||||
|             this.pbChar2.Size = new System.Drawing.Size(100, 124); |             pbChar2.Size = new System.Drawing.Size(100, 124); | ||||||
|             this.pbChar2.SizeMode = System.Windows.Forms.PictureBoxSizeMode.Zoom; |             pbChar2.SizeMode = System.Windows.Forms.PictureBoxSizeMode.Zoom; | ||||||
|             this.pbChar2.TabIndex = 1; |             pbChar2.TabIndex = 1; | ||||||
|             this.pbChar2.TabStop = false; |             pbChar2.TabStop = false; | ||||||
|             //  |             //  | ||||||
|             // pbChar1 |             // pbChar1 | ||||||
|             //  |             //  | ||||||
|             this.pbChar1.BorderStyle = System.Windows.Forms.BorderStyle.FixedSingle; |             pbChar1.BorderStyle = System.Windows.Forms.BorderStyle.FixedSingle; | ||||||
|             this.pbChar1.Location = new System.Drawing.Point(0, 0); |             pbChar1.Location = new System.Drawing.Point(0, 0); | ||||||
|             this.pbChar1.Name = "pbChar1"; |             pbChar1.Name = "pbChar1"; | ||||||
|             this.pbChar1.Size = new System.Drawing.Size(100, 124); |             pbChar1.Size = new System.Drawing.Size(100, 124); | ||||||
|             this.pbChar1.SizeMode = System.Windows.Forms.PictureBoxSizeMode.Zoom; |             pbChar1.SizeMode = System.Windows.Forms.PictureBoxSizeMode.Zoom; | ||||||
|             this.pbChar1.TabIndex = 0; |             pbChar1.TabIndex = 0; | ||||||
|             this.pbChar1.TabStop = false; |             pbChar1.TabStop = false; | ||||||
|             //  |             //  | ||||||
|             // btnFont |             // btnFont | ||||||
|             //  |             //  | ||||||
|             this.btnFont.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); |             btnFont.Anchor = System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left; | ||||||
|             this.btnFont.Location = new System.Drawing.Point(6, 178); |             btnFont.Location = new System.Drawing.Point(6, 178); | ||||||
|             this.btnFont.Name = "btnFont"; |             btnFont.Name = "btnFont"; | ||||||
|             this.btnFont.Size = new System.Drawing.Size(71, 23); |             btnFont.Size = new System.Drawing.Size(71, 23); | ||||||
|             this.btnFont.TabIndex = 15; |             btnFont.TabIndex = 15; | ||||||
|             this.btnFont.Text = "Font ..."; |             btnFont.Text = "Font ..."; | ||||||
|             this.btnFont.UseVisualStyleBackColor = true; |             btnFont.UseVisualStyleBackColor = true; | ||||||
|             this.btnFont.Click += new System.EventHandler(this.btnFont_Click); |             btnFont.Click += btnFont_Click; | ||||||
|             //  |             //  | ||||||
|             // dlgFont |             // dlgFont | ||||||
|             //  |             //  | ||||||
|             this.dlgFont.Font = new System.Drawing.Font("Courier New", 15.75F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, ((byte)(204))); |             dlgFont.Font = new System.Drawing.Font("Courier New", 15.75F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|             this.dlgFont.ShowEffects = false; |             dlgFont.ShowEffects = false; | ||||||
|             //  |             //  | ||||||
|             // cbFontBased |             // cbFontBased | ||||||
|             //  |             //  | ||||||
|             this.cbFontBased.AutoSize = true; |             cbFontBased.AutoSize = true; | ||||||
|             this.cbFontBased.Location = new System.Drawing.Point(24, 130); |             cbFontBased.Location = new System.Drawing.Point(24, 130); | ||||||
|             this.cbFontBased.Name = "cbFontBased"; |             cbFontBased.Name = "cbFontBased"; | ||||||
|             this.cbFontBased.Size = new System.Drawing.Size(101, 17); |             cbFontBased.Size = new System.Drawing.Size(108, 19); | ||||||
|             this.cbFontBased.TabIndex = 16; |             cbFontBased.TabIndex = 16; | ||||||
|             this.cbFontBased.Text = "Based on a font"; |             cbFontBased.Text = "Based on a font"; | ||||||
|             this.cbFontBased.UseVisualStyleBackColor = true; |             cbFontBased.UseVisualStyleBackColor = true; | ||||||
|             this.cbFontBased.CheckedChanged += new System.EventHandler(this.checkboxChanged); |             cbFontBased.CheckedChanged += checkboxChanged; | ||||||
|             //  |             //  | ||||||
|             // lblFont |             // lblFont | ||||||
|             //  |             //  | ||||||
|             this.lblFont.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); |             lblFont.Anchor = System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left; | ||||||
|             this.lblFont.Location = new System.Drawing.Point(83, 183); |             lblFont.Location = new System.Drawing.Point(83, 183); | ||||||
|             this.lblFont.Name = "lblFont"; |             lblFont.Name = "lblFont"; | ||||||
|             this.lblFont.Size = new System.Drawing.Size(123, 18); |             lblFont.Size = new System.Drawing.Size(123, 18); | ||||||
|             this.lblFont.TabIndex = 17; |             lblFont.TabIndex = 17; | ||||||
|             this.lblFont.Text = "font"; |             lblFont.Text = "font"; | ||||||
|             //  |             //  | ||||||
|             // nudShiftX |             // nudShiftX | ||||||
|             //  |             //  | ||||||
|             this.nudShiftX.Location = new System.Drawing.Point(61, 2); |             nudShiftX.Location = new System.Drawing.Point(61, 2); | ||||||
|             this.nudShiftX.Minimum = new decimal(new int[] { |             nudShiftX.Minimum = new decimal(new int[] { 100, 0, 0, int.MinValue }); | ||||||
|             100, |             nudShiftX.Name = "nudShiftX"; | ||||||
|             0, |             nudShiftX.Size = new System.Drawing.Size(45, 23); | ||||||
|             0, |             nudShiftX.TabIndex = 18; | ||||||
|             -2147483648}); |             nudShiftX.ValueChanged += nudNewX_ValueChanged; | ||||||
|             this.nudShiftX.Name = "nudShiftX"; |  | ||||||
|             this.nudShiftX.Size = new System.Drawing.Size(45, 20); |  | ||||||
|             this.nudShiftX.TabIndex = 18; |  | ||||||
|             this.nudShiftX.ValueChanged += new System.EventHandler(this.nudNewX_ValueChanged); |  | ||||||
|             //  |             //  | ||||||
|             // nudShiftY |             // nudShiftY | ||||||
|             //  |             //  | ||||||
|             this.nudShiftY.Location = new System.Drawing.Point(161, 2); |             nudShiftY.Location = new System.Drawing.Point(161, 2); | ||||||
|             this.nudShiftY.Minimum = new decimal(new int[] { |             nudShiftY.Minimum = new decimal(new int[] { 100, 0, 0, int.MinValue }); | ||||||
|             100, |             nudShiftY.Name = "nudShiftY"; | ||||||
|             0, |             nudShiftY.Size = new System.Drawing.Size(45, 23); | ||||||
|             0, |             nudShiftY.TabIndex = 19; | ||||||
|             -2147483648}); |             nudShiftY.ValueChanged += nudNewX_ValueChanged; | ||||||
|             this.nudShiftY.Name = "nudShiftY"; |  | ||||||
|             this.nudShiftY.Size = new System.Drawing.Size(45, 20); |  | ||||||
|             this.nudShiftY.TabIndex = 19; |  | ||||||
|             this.nudShiftY.ValueChanged += new System.EventHandler(this.nudNewX_ValueChanged); |  | ||||||
|             //  |             //  | ||||||
|             // lblShiftX |             // lblShiftX | ||||||
|             //  |             //  | ||||||
|             this.lblShiftX.AutoSize = true; |             lblShiftX.AutoSize = true; | ||||||
|             this.lblShiftX.Location = new System.Drawing.Point(14, 4); |             lblShiftX.Location = new System.Drawing.Point(14, 4); | ||||||
|             this.lblShiftX.Name = "lblShiftX"; |             lblShiftX.Name = "lblShiftX"; | ||||||
|             this.lblShiftX.Size = new System.Drawing.Size(41, 13); |             lblShiftX.Size = new System.Drawing.Size(44, 15); | ||||||
|             this.lblShiftX.TabIndex = 20; |             lblShiftX.TabIndex = 20; | ||||||
|             this.lblShiftX.Text = "Shift X:"; |             lblShiftX.Text = "Shift X:"; | ||||||
|             this.lblShiftX.TextAlign = System.Drawing.ContentAlignment.MiddleRight; |             lblShiftX.TextAlign = System.Drawing.ContentAlignment.MiddleRight; | ||||||
|             //  |             //  | ||||||
|             // lblShiftY |             // lblShiftY | ||||||
|             //  |             //  | ||||||
|             this.lblShiftY.AutoSize = true; |             lblShiftY.AutoSize = true; | ||||||
|             this.lblShiftY.Location = new System.Drawing.Point(114, 4); |             lblShiftY.Location = new System.Drawing.Point(114, 4); | ||||||
|             this.lblShiftY.Name = "lblShiftY"; |             lblShiftY.Name = "lblShiftY"; | ||||||
|             this.lblShiftY.Size = new System.Drawing.Size(41, 13); |             lblShiftY.Size = new System.Drawing.Size(44, 15); | ||||||
|             this.lblShiftY.TabIndex = 21; |             lblShiftY.TabIndex = 21; | ||||||
|             this.lblShiftY.Text = "Shift Y:"; |             lblShiftY.Text = "Shift Y:"; | ||||||
|             this.lblShiftY.TextAlign = System.Drawing.ContentAlignment.MiddleRight; |             lblShiftY.TextAlign = System.Drawing.ContentAlignment.MiddleRight; | ||||||
|             //  |             //  | ||||||
|             // pnlFont |             // pnlFont | ||||||
|             //  |             //  | ||||||
|             this.pnlFont.Controls.Add(this.label4); |             pnlFont.Controls.Add(label4); | ||||||
|             this.pnlFont.Controls.Add(this.label3); |             pnlFont.Controls.Add(label3); | ||||||
|             this.pnlFont.Controls.Add(this.nudChar2); |             pnlFont.Controls.Add(nudChar2); | ||||||
|             this.pnlFont.Controls.Add(this.nudChar1); |             pnlFont.Controls.Add(nudChar1); | ||||||
|             this.pnlFont.Controls.Add(this.lblShiftX); |             pnlFont.Controls.Add(lblShiftX); | ||||||
|             this.pnlFont.Controls.Add(this.lblShiftY); |             pnlFont.Controls.Add(lblShiftY); | ||||||
|             this.pnlFont.Controls.Add(this.panel1); |             pnlFont.Controls.Add(panel1); | ||||||
|             this.pnlFont.Controls.Add(this.btnFont); |             pnlFont.Controls.Add(btnFont); | ||||||
|             this.pnlFont.Controls.Add(this.nudShiftY); |             pnlFont.Controls.Add(nudShiftY); | ||||||
|             this.pnlFont.Controls.Add(this.lblFont); |             pnlFont.Controls.Add(lblFont); | ||||||
|             this.pnlFont.Controls.Add(this.nudShiftX); |             pnlFont.Controls.Add(nudShiftX); | ||||||
|             this.pnlFont.Dock = System.Windows.Forms.DockStyle.Right; |             pnlFont.Dock = System.Windows.Forms.DockStyle.Right; | ||||||
|             this.pnlFont.Location = new System.Drawing.Point(270, 0); |             pnlFont.Location = new System.Drawing.Point(270, 0); | ||||||
|             this.pnlFont.Name = "pnlFont"; |             pnlFont.Name = "pnlFont"; | ||||||
|             this.pnlFont.Size = new System.Drawing.Size(214, 211); |             pnlFont.Size = new System.Drawing.Size(214, 211); | ||||||
|             this.pnlFont.TabIndex = 22; |             pnlFont.TabIndex = 22; | ||||||
|             this.pnlFont.Visible = false; |             pnlFont.Visible = false; | ||||||
|             //  |             //  | ||||||
|             // label4 |             // label4 | ||||||
|             //  |             //  | ||||||
|             this.label4.AutoSize = true; |             label4.AutoSize = true; | ||||||
|             this.label4.Location = new System.Drawing.Point(112, 152); |             label4.Location = new System.Drawing.Point(112, 152); | ||||||
|             this.label4.Name = "label4"; |             label4.Name = "label4"; | ||||||
|             this.label4.Size = new System.Drawing.Size(45, 13); |             label4.Size = new System.Drawing.Size(49, 15); | ||||||
|             this.label4.TabIndex = 25; |             label4.TabIndex = 25; | ||||||
|             this.label4.Text = "Sample:"; |             label4.Text = "Sample:"; | ||||||
|             this.label4.TextAlign = System.Drawing.ContentAlignment.MiddleRight; |             label4.TextAlign = System.Drawing.ContentAlignment.MiddleRight; | ||||||
|             //  |             //  | ||||||
|             // label3 |             // label3 | ||||||
|             //  |             //  | ||||||
|             this.label3.AutoSize = true; |             label3.AutoSize = true; | ||||||
|             this.label3.Location = new System.Drawing.Point(14, 152); |             label3.Location = new System.Drawing.Point(14, 152); | ||||||
|             this.label3.Name = "label3"; |             label3.Name = "label3"; | ||||||
|             this.label3.Size = new System.Drawing.Size(45, 13); |             label3.Size = new System.Drawing.Size(49, 15); | ||||||
|             this.label3.TabIndex = 24; |             label3.TabIndex = 24; | ||||||
|             this.label3.Text = "Sample:"; |             label3.Text = "Sample:"; | ||||||
|             this.label3.TextAlign = System.Drawing.ContentAlignment.MiddleRight; |             label3.TextAlign = System.Drawing.ContentAlignment.MiddleRight; | ||||||
|             //  |             //  | ||||||
|             // nudChar2 |             // nudChar2 | ||||||
|             //  |             //  | ||||||
|             this.nudChar2.Location = new System.Drawing.Point(161, 149); |             nudChar2.Location = new System.Drawing.Point(161, 149); | ||||||
|             this.nudChar2.Maximum = new decimal(new int[] { |             nudChar2.Maximum = new decimal(new int[] { 255, 0, 0, 0 }); | ||||||
|             255, |             nudChar2.Name = "nudChar2"; | ||||||
|             0, |             nudChar2.Size = new System.Drawing.Size(45, 23); | ||||||
|             0, |             nudChar2.TabIndex = 23; | ||||||
|             0}); |             nudChar2.Value = new decimal(new int[] { 97, 0, 0, 0 }); | ||||||
|             this.nudChar2.Name = "nudChar2"; |             nudChar2.ValueChanged += nudNewX_ValueChanged; | ||||||
|             this.nudChar2.Size = new System.Drawing.Size(45, 20); |  | ||||||
|             this.nudChar2.TabIndex = 23; |  | ||||||
|             this.nudChar2.Value = new decimal(new int[] { |  | ||||||
|             97, |  | ||||||
|             0, |  | ||||||
|             0, |  | ||||||
|             0}); |  | ||||||
|             this.nudChar2.ValueChanged += new System.EventHandler(this.nudNewX_ValueChanged); |  | ||||||
|             //  |             //  | ||||||
|             // nudChar1 |             // nudChar1 | ||||||
|             //  |             //  | ||||||
|             this.nudChar1.Location = new System.Drawing.Point(61, 149); |             nudChar1.Location = new System.Drawing.Point(61, 149); | ||||||
|             this.nudChar1.Maximum = new decimal(new int[] { |             nudChar1.Maximum = new decimal(new int[] { 255, 0, 0, 0 }); | ||||||
|             255, |             nudChar1.Name = "nudChar1"; | ||||||
|             0, |             nudChar1.Size = new System.Drawing.Size(45, 23); | ||||||
|             0, |             nudChar1.TabIndex = 22; | ||||||
|             0}); |             nudChar1.Value = new decimal(new int[] { 65, 0, 0, 0 }); | ||||||
|             this.nudChar1.Name = "nudChar1"; |             nudChar1.ValueChanged += nudNewX_ValueChanged; | ||||||
|             this.nudChar1.Size = new System.Drawing.Size(45, 20); |  | ||||||
|             this.nudChar1.TabIndex = 22; |  | ||||||
|             this.nudChar1.Value = new decimal(new int[] { |  | ||||||
|             65, |  | ||||||
|             0, |  | ||||||
|             0, |  | ||||||
|             0}); |  | ||||||
|             this.nudChar1.ValueChanged += new System.EventHandler(this.nudNewX_ValueChanged); |  | ||||||
|             //  |             //  | ||||||
|             // cbDigits |             // cbDigits | ||||||
|             //  |             //  | ||||||
|             this.cbDigits.AutoSize = true; |             cbDigits.AutoSize = true; | ||||||
|             this.cbDigits.Location = new System.Drawing.Point(140, 54); |             cbDigits.Location = new System.Drawing.Point(140, 54); | ||||||
|             this.cbDigits.Name = "cbDigits"; |             cbDigits.Name = "cbDigits"; | ||||||
|             this.cbDigits.Size = new System.Drawing.Size(74, 17); |             cbDigits.Size = new System.Drawing.Size(82, 19); | ||||||
|             this.cbDigits.TabIndex = 23; |             cbDigits.TabIndex = 23; | ||||||
|             this.cbDigits.Text = "Digits only"; |             cbDigits.Text = "Digits only"; | ||||||
|             this.cbDigits.UseVisualStyleBackColor = true; |             cbDigits.UseVisualStyleBackColor = true; | ||||||
|             this.cbDigits.CheckedChanged += new System.EventHandler(this.checkboxChanged); |             cbDigits.CheckedChanged += checkboxChanged; | ||||||
|             //  |             //  | ||||||
|             // New |             // New | ||||||
|             //  |             //  | ||||||
|             this.AcceptButton = this.btnOK; |             AcceptButton = btnOK; | ||||||
|             this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.None; |             AutoScaleMode = System.Windows.Forms.AutoScaleMode.None; | ||||||
|             this.CancelButton = this.btnCancel; |             CancelButton = btnCancel; | ||||||
|             this.ClientSize = new System.Drawing.Size(484, 211); |             ClientSize = new System.Drawing.Size(484, 211); | ||||||
|             this.Controls.Add(this.cbDigits); |             Controls.Add(cbDigits); | ||||||
|             this.Controls.Add(this.pnlFont); |             Controls.Add(pnlFont); | ||||||
|             this.Controls.Add(this.cbFontBased); |             Controls.Add(cbFontBased); | ||||||
|             this.Controls.Add(this.cbEncoding); |             Controls.Add(cbEncoding); | ||||||
|             this.Controls.Add(this.cbSingle); |             Controls.Add(cbSingle); | ||||||
|             this.Controls.Add(this.btnCancel); |             Controls.Add(btnCancel); | ||||||
|             this.Controls.Add(this.btnOK); |             Controls.Add(btnOK); | ||||||
|             this.Controls.Add(this.cbExtended); |             Controls.Add(cbExtended); | ||||||
|             this.Controls.Add(this.cbLatin); |             Controls.Add(cbLatin); | ||||||
|             this.Controls.Add(this.cbNotPrintable); |             Controls.Add(cbNotPrintable); | ||||||
|             this.Controls.Add(this.rbVar); |             Controls.Add(rbVar); | ||||||
|             this.Controls.Add(this.rbMono); |             Controls.Add(rbMono); | ||||||
|             this.Controls.Add(this.label2); |             Controls.Add(label2); | ||||||
|             this.Controls.Add(this.label1); |             Controls.Add(label1); | ||||||
|             this.Controls.Add(this.nudNewY); |             Controls.Add(nudNewY); | ||||||
|             this.Controls.Add(this.nudNewX); |             Controls.Add(nudNewX); | ||||||
|             this.FormBorderStyle = System.Windows.Forms.FormBorderStyle.FixedDialog; |             FormBorderStyle = System.Windows.Forms.FormBorderStyle.FixedDialog; | ||||||
|             this.MaximizeBox = false; |             MaximizeBox = false; | ||||||
|             this.MinimizeBox = false; |             MinimizeBox = false; | ||||||
|             this.MinimumSize = new System.Drawing.Size(300, 220); |             MinimumSize = new System.Drawing.Size(300, 220); | ||||||
|             this.Name = "New"; |             Name = "New"; | ||||||
|             this.ShowIcon = false; |             ShowIcon = false; | ||||||
|             this.ShowInTaskbar = false; |             ShowInTaskbar = false; | ||||||
|             this.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen; |             StartPosition = System.Windows.Forms.FormStartPosition.CenterParent; | ||||||
|             this.Text = "New"; |             Text = "New"; | ||||||
|             this.Load += new System.EventHandler(this.New_Load); |             Load += New_Load; | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.nudNewX)).EndInit(); |             ((System.ComponentModel.ISupportInitialize)nudNewX).EndInit(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.nudNewY)).EndInit(); |             ((System.ComponentModel.ISupportInitialize)nudNewY).EndInit(); | ||||||
|             this.panel1.ResumeLayout(false); |             panel1.ResumeLayout(false); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.pbChar2)).EndInit(); |             ((System.ComponentModel.ISupportInitialize)pbChar2).EndInit(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.pbChar1)).EndInit(); |             ((System.ComponentModel.ISupportInitialize)pbChar1).EndInit(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.nudShiftX)).EndInit(); |             ((System.ComponentModel.ISupportInitialize)nudShiftX).EndInit(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.nudShiftY)).EndInit(); |             ((System.ComponentModel.ISupportInitialize)nudShiftY).EndInit(); | ||||||
|             this.pnlFont.ResumeLayout(false); |             pnlFont.ResumeLayout(false); | ||||||
|             this.pnlFont.PerformLayout(); |             pnlFont.PerformLayout(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.nudChar2)).EndInit(); |             ((System.ComponentModel.ISupportInitialize)nudChar2).EndInit(); | ||||||
|             ((System.ComponentModel.ISupportInitialize)(this.nudChar1)).EndInit(); |             ((System.ComponentModel.ISupportInitialize)nudChar1).EndInit(); | ||||||
|             this.ResumeLayout(false); |             ResumeLayout(false); | ||||||
|             this.PerformLayout(); |             PerformLayout(); | ||||||
|  |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -108,8 +108,8 @@ namespace McBitFont { | |||||||
|  |  | ||||||
|             Bitmap bmp, result; |             Bitmap bmp, result; | ||||||
|             Graphics g; |             Graphics g; | ||||||
|             chars[0] = mainForm.decodeSymbol((int)nudChar1.Value); |             chars[0] = mainForm.DecodeSymbol((int)nudChar1.Value); | ||||||
|             chars[1] = mainForm.decodeSymbol((int)nudChar2.Value); |             chars[1] = mainForm.DecodeSymbol((int)nudChar2.Value); | ||||||
|             for (int i = 0; i < 2; i++) { |             for (int i = 0; i < 2; i++) { | ||||||
|                 bmp = new Bitmap((int)nudNewX.Value, (int)nudNewY.Value); |                 bmp = new Bitmap((int)nudNewX.Value, (int)nudNewY.Value); | ||||||
|                 g = Graphics.FromImage(bmp); |                 g = Graphics.FromImage(bmp); | ||||||
|   | |||||||
| @@ -1,17 +1,17 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <root> | <root> | ||||||
|   <!--  |   <!-- | ||||||
|     Microsoft ResX Schema  |     Microsoft ResX Schema | ||||||
|      |  | ||||||
|     Version 2.0 |     Version 2.0 | ||||||
|      |  | ||||||
|     The primary goals of this format is to allow a simple XML format  |     The primary goals of this format is to allow a simple XML format | ||||||
|     that is mostly human readable. The generation and parsing of the  |     that is mostly human readable. The generation and parsing of the | ||||||
|     various data types are done through the TypeConverter classes  |     various data types are done through the TypeConverter classes | ||||||
|     associated with the data types. |     associated with the data types. | ||||||
|      |  | ||||||
|     Example: |     Example: | ||||||
|      |  | ||||||
|     ... ado.net/XML headers & schema ... |     ... ado.net/XML headers & schema ... | ||||||
|     <resheader name="resmimetype">text/microsoft-resx</resheader> |     <resheader name="resmimetype">text/microsoft-resx</resheader> | ||||||
|     <resheader name="version">2.0</resheader> |     <resheader name="version">2.0</resheader> | ||||||
| @@ -26,36 +26,36 @@ | |||||||
|         <value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value> |         <value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value> | ||||||
|         <comment>This is a comment</comment> |         <comment>This is a comment</comment> | ||||||
|     </data> |     </data> | ||||||
|                  |  | ||||||
|     There are any number of "resheader" rows that contain simple  |     There are any number of "resheader" rows that contain simple | ||||||
|     name/value pairs. |     name/value pairs. | ||||||
|      |  | ||||||
|     Each data row contains a name, and value. The row also contains a  |     Each data row contains a name, and value. The row also contains a | ||||||
|     type or mimetype. Type corresponds to a .NET class that support  |     type or mimetype. Type corresponds to a .NET class that support | ||||||
|     text/value conversion through the TypeConverter architecture.  |     text/value conversion through the TypeConverter architecture. | ||||||
|     Classes that don't support this are serialized and stored with the  |     Classes that don't support this are serialized and stored with the | ||||||
|     mimetype set. |     mimetype set. | ||||||
|      |  | ||||||
|     The mimetype is used for serialized objects, and tells the  |     The mimetype is used for serialized objects, and tells the | ||||||
|     ResXResourceReader how to depersist the object. This is currently not  |     ResXResourceReader how to depersist the object. This is currently not | ||||||
|     extensible. For a given mimetype the value must be set accordingly: |     extensible. For a given mimetype the value must be set accordingly: | ||||||
|      |  | ||||||
|     Note - application/x-microsoft.net.object.binary.base64 is the format  |     Note - application/x-microsoft.net.object.binary.base64 is the format | ||||||
|     that the ResXResourceWriter will generate, however the reader can  |     that the ResXResourceWriter will generate, however the reader can | ||||||
|     read any of the formats listed below. |     read any of the formats listed below. | ||||||
|      |  | ||||||
|     mimetype: application/x-microsoft.net.object.binary.base64 |     mimetype: application/x-microsoft.net.object.binary.base64 | ||||||
|     value   : The object must be serialized with  |     value   : The object must be serialized with | ||||||
|             : System.Runtime.Serialization.Formatters.Binary.BinaryFormatter |             : System.Runtime.Serialization.Formatters.Binary.BinaryFormatter | ||||||
|             : and then encoded with base64 encoding. |             : and then encoded with base64 encoding. | ||||||
|      |  | ||||||
|     mimetype: application/x-microsoft.net.object.soap.base64 |     mimetype: application/x-microsoft.net.object.soap.base64 | ||||||
|     value   : The object must be serialized with  |     value   : The object must be serialized with | ||||||
|             : System.Runtime.Serialization.Formatters.Soap.SoapFormatter |             : System.Runtime.Serialization.Formatters.Soap.SoapFormatter | ||||||
|             : and then encoded with base64 encoding. |             : and then encoded with base64 encoding. | ||||||
|  |  | ||||||
|     mimetype: application/x-microsoft.net.object.bytearray.base64 |     mimetype: application/x-microsoft.net.object.bytearray.base64 | ||||||
|     value   : The object must be serialized into a byte array  |     value   : The object must be serialized into a byte array | ||||||
|             : using a System.ComponentModel.TypeConverter |             : using a System.ComponentModel.TypeConverter | ||||||
|             : and then encoded with base64 encoding. |             : and then encoded with base64 encoding. | ||||||
|     --> |     --> | ||||||
|   | |||||||
							
								
								
									
										60
									
								
								McBitFont/Properties/Resources.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						| @@ -80,6 +80,16 @@ namespace McBitFont.Properties { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|          |          | ||||||
|  |         /// <summary> | ||||||
|  |         ///   Looks up a localized resource of type System.Drawing.Bitmap. | ||||||
|  |         /// </summary> | ||||||
|  |         internal static System.Drawing.Bitmap arrow_out { | ||||||
|  |             get { | ||||||
|  |                 object obj = ResourceManager.GetObject("arrow_out", resourceCulture); | ||||||
|  |                 return ((System.Drawing.Bitmap)(obj)); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |          | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         ///   Looks up a localized resource of type System.Drawing.Bitmap. |         ///   Looks up a localized resource of type System.Drawing.Bitmap. | ||||||
|         /// </summary> |         /// </summary> | ||||||
| @@ -90,6 +100,26 @@ namespace McBitFont.Properties { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|          |          | ||||||
|  |         /// <summary> | ||||||
|  |         ///   Looks up a localized resource of type System.Drawing.Bitmap. | ||||||
|  |         /// </summary> | ||||||
|  |         internal static System.Drawing.Bitmap arrow_turn_left { | ||||||
|  |             get { | ||||||
|  |                 object obj = ResourceManager.GetObject("arrow_turn_left", resourceCulture); | ||||||
|  |                 return ((System.Drawing.Bitmap)(obj)); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         /// <summary> | ||||||
|  |         ///   Looks up a localized resource of type System.Drawing.Bitmap. | ||||||
|  |         /// </summary> | ||||||
|  |         internal static System.Drawing.Bitmap arrow_turn_right { | ||||||
|  |             get { | ||||||
|  |                 object obj = ResourceManager.GetObject("arrow_turn_right", resourceCulture); | ||||||
|  |                 return ((System.Drawing.Bitmap)(obj)); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |          | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         ///   Looks up a localized resource of type System.Drawing.Bitmap. |         ///   Looks up a localized resource of type System.Drawing.Bitmap. | ||||||
|         /// </summary> |         /// </summary> | ||||||
| @@ -260,6 +290,16 @@ namespace McBitFont.Properties { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|          |          | ||||||
|  |         /// <summary> | ||||||
|  |         ///   Looks up a localized resource of type System.Drawing.Bitmap. | ||||||
|  |         /// </summary> | ||||||
|  |         internal static System.Drawing.Bitmap font { | ||||||
|  |             get { | ||||||
|  |                 object obj = ResourceManager.GetObject("font", resourceCulture); | ||||||
|  |                 return ((System.Drawing.Bitmap)(obj)); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |          | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         ///   Looks up a localized resource of type System.Drawing.Bitmap. |         ///   Looks up a localized resource of type System.Drawing.Bitmap. | ||||||
|         /// </summary> |         /// </summary> | ||||||
| @@ -290,6 +330,26 @@ namespace McBitFont.Properties { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|          |          | ||||||
|  |         /// <summary> | ||||||
|  |         ///   Looks up a localized resource of type System.Drawing.Bitmap. | ||||||
|  |         /// </summary> | ||||||
|  |         internal static System.Drawing.Bitmap picture_go { | ||||||
|  |             get { | ||||||
|  |                 object obj = ResourceManager.GetObject("picture_go", resourceCulture); | ||||||
|  |                 return ((System.Drawing.Bitmap)(obj)); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         /// <summary> | ||||||
|  |         ///   Looks up a localized resource of type System.Drawing.Bitmap. | ||||||
|  |         /// </summary> | ||||||
|  |         internal static System.Drawing.Bitmap text_letterspacing2 { | ||||||
|  |             get { | ||||||
|  |                 object obj = ResourceManager.GetObject("text_letterspacing2", resourceCulture); | ||||||
|  |                 return ((System.Drawing.Bitmap)(obj)); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |          | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         ///   Looks up a localized resource of type System.Drawing.Bitmap. |         ///   Looks up a localized resource of type System.Drawing.Bitmap. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|   | |||||||
| @@ -136,9 +136,15 @@ | |||||||
|   <data name="Famfamfam-Silk-Page-copy.16" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="Famfamfam-Silk-Page-copy.16" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\Famfamfam-Silk-Page-copy.16.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\Famfamfam-Silk-Page-copy.16.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
|  |   <data name="picture_go" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|  |     <value>..\Resources\picture_go.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|  |   </data> | ||||||
|   <data name="arrow_inout" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="arrow_inout" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\arrow_inout.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\arrow_inout.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
|  |   <data name="font" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|  |     <value>..\Resources\font.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|  |   </data> | ||||||
|   <data name="arrow_redo" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="arrow_redo" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\redo.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\redo.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
| @@ -175,20 +181,20 @@ | |||||||
|   <data name="z_shading" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="z_shading" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\shading.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\shading.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
|  |   <data name="arrow_turn_left" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|  |     <value>..\Resources\arrow_turn_left.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|  |   </data> | ||||||
|   <data name="add" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="add" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\add.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\add.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
|   <data name="icon_32" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="icon_32" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\icon_32.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\icon_32.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
|   <data name="z_undo" type="System.Resources.ResXFileRef, System.Windows.Forms"> |  | ||||||
|     <value>..\Resources\arrow_undo.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |  | ||||||
|   </data> |  | ||||||
|   <data name="z_tick" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="z_tick" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\tick.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\tick.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
|   <data name="delete" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="z_undo" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\delete.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\arrow_undo.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
|   <data name="z_redo" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="z_redo" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\arrow_redo.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\arrow_redo.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
| @@ -202,9 +208,18 @@ | |||||||
|   <data name="Famfamfam-Silk-Page-white.16" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="Famfamfam-Silk-Page-white.16" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\Famfamfam-Silk-Page-white.16.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\Famfamfam-Silk-Page-white.16.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
|  |   <data name="delete" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|  |     <value>..\Resources\delete.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|  |   </data> | ||||||
|  |   <data name="arrow_turn_right" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|  |     <value>..\Resources\arrow_turn_right.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|  |   </data> | ||||||
|   <data name="Famfamfam-Silk-Disk.16" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="Famfamfam-Silk-Disk.16" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\Famfamfam-Silk-Disk.16.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\Famfamfam-Silk-Disk.16.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
|  |   <data name="folder_table" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|  |     <value>..\Resources\folder_table.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|  |   </data> | ||||||
|   <data name="Canvas_Fill" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="Canvas_Fill" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\Canvas_Fill.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\Canvas_Fill.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
| @@ -220,10 +235,13 @@ | |||||||
|   <data name="arrow_undo" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="arrow_undo" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\undo.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\undo.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
|  |   <data name="arrow_out" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|  |     <value>..\Resources\arrow_out.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|  |   </data> | ||||||
|   <data name="icon_64" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="icon_64" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\icon_64.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\icon_64.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
|   <data name="folder_table" type="System.Resources.ResXFileRef, System.Windows.Forms"> |   <data name="text_letterspacing2" type="System.Resources.ResXFileRef, System.Windows.Forms"> | ||||||
|     <value>..\Resources\folder_table.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> |     <value>..\Resources\text_letterspacing2.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value> | ||||||
|   </data> |   </data> | ||||||
| </root> | </root> | ||||||
							
								
								
									
										
											BIN
										
									
								
								McBitFont/Resources/arrow_out.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 594 B | 
							
								
								
									
										
											BIN
										
									
								
								McBitFont/Resources/arrow_turn_left.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 512 B | 
							
								
								
									
										
											BIN
										
									
								
								McBitFont/Resources/arrow_turn_right.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 489 B | 
							
								
								
									
										
											BIN
										
									
								
								McBitFont/Resources/font.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 567 B | 
							
								
								
									
										
											BIN
										
									
								
								McBitFont/Resources/picture_go.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 758 B | 
							
								
								
									
										
											BIN
										
									
								
								McBitFont/Resources/text_letterspacing2.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 357 B | 
							
								
								
									
										21
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @@ -8,6 +8,9 @@ Features: | |||||||
| - Import an image | - Import an image | ||||||
| - Save / Load your project for later edits | - Save / Load your project for later edits | ||||||
| - Export as a C array in different formats | - Export as a C array in different formats | ||||||
|  | - Import from text C array | ||||||
|  | - Export to a PNG image showing all the characters in a table | ||||||
|  | - Test your font in special dialog | ||||||
|  |  | ||||||
| Requires: | Requires: | ||||||
| - Windows 7+ | - Windows 7+ | ||||||
| @@ -17,12 +20,17 @@ Some basic hints on the interface: | |||||||
| - Mouse 1 to mark a pixel black | - Mouse 1 to mark a pixel black | ||||||
| - Mouse 2 to mark a pixel white | - Mouse 2 to mark a pixel white | ||||||
| - Drag the mouse holding a button to draw pixels | - Drag the mouse holding a button to draw pixels | ||||||
|  | - Hold Shift to constrain painting horizontally | ||||||
|  | - Hold Ctrl to constrain painting vertically | ||||||
| - Mouse Scroll to scroll up and down | - Mouse Scroll to scroll up and down | ||||||
| - Shift + scroll to scroll left and right | - Shift + scroll to scroll left and right | ||||||
| - Crtl + scroll to zoom | - Crtl + scroll to zoom | ||||||
|  | - Alt + Scroll to change painting brush size | ||||||
|  |  | ||||||
| Download in the [Releases](https://gitea.mcflyer.ru/McFLY/McBitFont/releases) section! | Download in the [Releases](https://gitea.mcflyer.ru/McFLY/McBitFont/releases) section! | ||||||
|  |  | ||||||
|  | Library example instructions to implement to STM32 code: [mctext](STM32_HAL_Lib/README.md) | ||||||
|  |  | ||||||
| #### Important: | #### Important: | ||||||
| **Since v2.0 new save file format is implemented. You can use [McBitFont v1.7](https://gitea.mcflyer.ru/McFLY/McBitFont/releases/tag/v1.7) to convert old saved files to the new format.** | **Since v2.0 new save file format is implemented. You can use [McBitFont v1.7](https://gitea.mcflyer.ru/McFLY/McBitFont/releases/tag/v1.7) to convert old saved files to the new format.** | ||||||
|  |  | ||||||
| @@ -37,6 +45,10 @@ New project dialog | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Font test dialog | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| Export dialog | Export dialog | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -48,3 +60,12 @@ Import Image dialog | |||||||
| Code Shift dialog | Code Shift dialog | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Font PNG export example | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Frame screenshot dialog | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								STM32_HAL_Lib/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,13 @@ | |||||||
|  | # McText Library | ||||||
|  |  | ||||||
|  | - The library uses "Left to Right, Top to bottom" scan and "LSB Top" for pixels alignment | ||||||
|  |  | ||||||
|  | #### Instructions | ||||||
|  |  | ||||||
|  | To use the library you have to have a display driver with a function that paints a single pixel with X and Y coordinates and 0/1 color.<br> | ||||||
|  | Find "SET A FUNCTION NAME HERE!" text in *mctext.c* file and change the function name that suits your driver.<br> | ||||||
|  | **Note:** it is possible that you will have to change parameters in the function to match your driver. | ||||||
|  |  | ||||||
|  | **Note:** check the "include" in *mctext.h* file to match your HAL. (stm32f1xx_hal.h is fo STM32F1 MCU series) | ||||||
|  |  | ||||||
|  | Now use **mct_String** function to draw a string of text. | ||||||
							
								
								
									
										113
									
								
								STM32_HAL_Lib/mctext.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,113 @@ | |||||||
|  | /* | ||||||
|  |  * mctext.c | ||||||
|  |  * | ||||||
|  |  *  Created on: May 16, 2025 | ||||||
|  |  *      Author: User | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #include "mctext.h" | ||||||
|  | #include "ST7565.h" | ||||||
|  |  | ||||||
|  | //=========================== SET A FUNCTION NAME HERE! ===========================// | ||||||
|  | // A function from display driver to set a pixel (x, y, color) | ||||||
|  | void (*mct_SetPixel)(uint8_t, uint8_t, uint8_t) = ST7565_SetPixel; | ||||||
|  | //=================================================================================// | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // Draw a single character. Returns width of drawn character | ||||||
|  | uint8_t mct_CharT(uint8_t x, uint8_t y, unsigned char c, uint8_t color, const uint8_t *font, uint8_t transp) { | ||||||
|  |   uint8_t pk = font[0]; // Is it a packed font? | ||||||
|  |   uint8_t w  = font[1]; // Font char width | ||||||
|  |   uint8_t h  = font[2]; // Font char height | ||||||
|  |   uint8_t fc = font[4]; // First char code in the font | ||||||
|  |   uint8_t lc = font[5]; // Last char code in the font | ||||||
|  |   uint8_t i, j, p, s, b, seg; // i-cur.column, j-cur.row of 8, p-rows of 8, s-height in cur.row of 8, b-cur.bit in cur.row, seg-byte.segment | ||||||
|  |   uint8_t bps;          // Bytes per symbol for packed fonts | ||||||
|  |   uint16_t o;           // Current offset | ||||||
|  |  | ||||||
|  |   if (c < fc || c > lc) return 0; | ||||||
|  |   if (x > LCDWIDTH) return 0; | ||||||
|  |   if (y+h > LCDHEIGHT) return 0; | ||||||
|  |  | ||||||
|  |   // Calc the offset for desired symbol | ||||||
|  |   if (pk) { // The font is packed | ||||||
|  |     if (w) { // The font is monospaced | ||||||
|  |       bps = w*h/8;                      // Bytes per symbol | ||||||
|  |       if ((w*h)%8 > 0) bps++;           // Correction for the last byte | ||||||
|  |       o = FONT_HEADER+(c-fc)*bps;       // Offset for desired symbol | ||||||
|  |     } else { // The font is not monospaced | ||||||
|  |       o = FONT_HEADER;                  // Starting offset | ||||||
|  |       for (i=0; i<c-fc; i++) {          // Going through every symbol | ||||||
|  |         bps = font[o]*h/8;              // Bytes per current symbol | ||||||
|  |         if ((font[o]*h)%8 > 0) bps++;   // Correction for the last byte | ||||||
|  |         o += bps + 1;                   // Adding symbol's width to the offset (+ width byte) | ||||||
|  |       } | ||||||
|  |       w = font[o];                      // Desired symbol's width | ||||||
|  |       o++;                              // Offset for desired symbol's data | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // Draw the packed symbol! | ||||||
|  |     bps = w*h/8;                        // Bytes per current symbol | ||||||
|  |     if ((w*h)%8 > 0) bps++;             // Correction for the last byte | ||||||
|  |     b = 0;                              // bit indexer in "current" byte | ||||||
|  |     for (i=0; i<w; i++) {               // Going through columns | ||||||
|  |       if (x+i > LCDWIDTH) return i-1;   // Check if we're out of display size | ||||||
|  |       for (j=0; j<h; j++) {             // Going through rows in column [i] | ||||||
|  |         if (b == 0) seg = font[o]; | ||||||
|  |         if ((seg>>b) & 1) mct_SetPixel(x+i, y+j, color); // Paint the pixel | ||||||
|  |         if (b < 7) b++; else {b = 0; o++;} // Track bits and bytes | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |   } else { // The font is not packed | ||||||
|  |     p = (h%8 > 0) ? h/8 + 1 : h/8;      // Bytes in one column | ||||||
|  |     if (w) { // The font is monospaced | ||||||
|  |       o = FONT_HEADER+(c-fc)*w*p;       // Offset for desired symbol | ||||||
|  |     } else { // The font is not monospaced | ||||||
|  |       o = FONT_HEADER;                  // Starting offset | ||||||
|  |       for (i=0; i<c-fc; i++) {          // Going through every symbol | ||||||
|  |         o += font[o]*p + 1;             // Adding symbol's width to the offset | ||||||
|  |       } | ||||||
|  |       w = font[o];                      // Desired symbol's width | ||||||
|  |       o++;                              // Offset for desired symbol's data | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // Draw the symbol | ||||||
|  |     for (i=0; i<w; i++) {               // Going through columns | ||||||
|  |       if (x+i > LCDWIDTH) return i-1;   // Check if we're out of display size | ||||||
|  |       for (j=0; j<p; j++) {             // Going through bytes in single column | ||||||
|  |         s = (h - j*8 >= 8) ? 8 : (h - j*8) % 8; // Clac the amount of pixels in current byte | ||||||
|  |  | ||||||
|  |         seg = font[o]; | ||||||
|  |         for (b=0; b<s; b++) {           // Going through the byte and paint the pixel if the bit is 1 | ||||||
|  |           if ((seg>>b) & 1) mct_SetPixel(x+i, y+j*8+b, color); | ||||||
|  |           else if (!transp) mct_SetPixel(x+i, y+j*8+b, !color); | ||||||
|  |         } | ||||||
|  |         o++; | ||||||
|  |       } | ||||||
|  |       //mct_SetPixel(x+i, y, color);   // For testing purposes | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return w; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Draw a single character. Transparent background. Returns width of drawn character | ||||||
|  | uint8_t mct_Char(uint8_t x, uint8_t y, unsigned char c, uint8_t color, const uint8_t *font) { | ||||||
|  |   return mct_CharT(x, y, c, color, font, 1); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Draw a string of characters | ||||||
|  | void mct_String(uint8_t x, uint8_t y, const char *c, uint8_t color, const uint8_t *font) { | ||||||
|  |   uint8_t w  = font[1]; // Font char width | ||||||
|  |   uint8_t h  = font[2]; // Font char height | ||||||
|  |   uint8_t s  = font[3]; // Font space between characters | ||||||
|  |  | ||||||
|  |   if (y+h > LCDHEIGHT) return; | ||||||
|  |   while (c[0] != 0) { | ||||||
|  |     if (x+w > LCDWIDTH) return; | ||||||
|  |     w = mct_Char(x, y, (unsigned char)*c, color, font); | ||||||
|  |     c++; | ||||||
|  |     x += w + s; | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										21
									
								
								STM32_HAL_Lib/mctext.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,21 @@ | |||||||
|  | /* | ||||||
|  |  * mctext.h | ||||||
|  |  * | ||||||
|  |  *  Created on: May 16, 2025 | ||||||
|  |  *      Author: User | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #ifndef INC_MCTEXT_H_ | ||||||
|  | #define INC_MCTEXT_H_ | ||||||
|  |  | ||||||
|  | #include "stm32f1xx_hal.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // Draw a single character. Returns width of drawn character | ||||||
|  | uint8_t mct_Char(uint8_t x, uint8_t y, unsigned char c, uint8_t color, const uint8_t *font); | ||||||
|  |  | ||||||
|  | // Draw a string of characters | ||||||
|  | void mct_String(uint8_t x, uint8_t y, const char *c, uint8_t color, const uint8_t *font); | ||||||
|  |  | ||||||
|  | #endif /* INC_MCTEXT_H_ */ | ||||||
							
								
								
									
										28
									
								
								TODO.txt
									
									
									
									
									
								
							
							
						
						| @@ -1,28 +1,10 @@ | |||||||
| Application: | Application: | ||||||
| V Migrate from .Net Framework 4.7 to .NET 9 | - Consider migrating to WPF in order to make DPI aware UI | ||||||
| V New Save file format! Use McBitFont v1.7 to convert old save files to the new format. |  | ||||||
| V Better quality pictures in symbol list |  | ||||||
| V Spinning cursor when application is busy |  | ||||||
| V Change Menu icons |  | ||||||
| V Re-arranged menu items |  | ||||||
| V Option to display codes in Hex numbers |  | ||||||
| V Make symbol list wider to display 8 characters instead of 7 |  | ||||||
|  |  | ||||||
| Functionality: | Functionality: | ||||||
| V Fill canvas button | V Screensot a frame function | ||||||
| V Context menu in symbol navigator | V Frame note field to store a frame description | ||||||
| V Delete symbols before/after selected | - Show note field in Export comments | ||||||
| V Shift all symbols on code line (change symbol codes) |  | ||||||
| V Specify starting code (extends the shift) |  | ||||||
| V Ability to make monospaced font a variable width one |  | ||||||
| V Undo/Redo for canvas changes |  | ||||||
| V Image import from a file |  | ||||||
| V Import from a text array |  | ||||||
| V Rectangle selection to mass-paint, shift and mirror pixels etc... |  | ||||||
| V "Packed" fonts export |  | ||||||
| V "Bytes total comment in export |  | ||||||
|  |  | ||||||
| Bugs: | Bugs: | ||||||
| V Improper bytes count for 16 or 32 bit numbers export |  | ||||||
| V Exception on Code Shift when nothing is selected in Symbols List |  | ||||||
| V Wrongly mark Project as modified on symbol selection |  | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								examples/46PixVN3_vw_cyr.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/Cyrillic-pixel-7.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/Font_3x3_mono_Latin.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/Font_3x5_Latin.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/Font_4x6_vw_cyr.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/Font_5x7_vw_narrow.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/Font_9x17_Alagard_cyr_vw.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/Font_Minecraft_Rus_5x7_vw.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/SelectionCursor.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/Standard_narrow_Latin1.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/Standard_wide_Latin1.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/basis33_vw_cyr.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/icons_14x14.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/pixel_3x5_Cyr.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/tests/flipper.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/tests/flipper_1.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								examples/tests/flipper_3.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								icons/famfamfam/arrow_out.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 594 B | 
							
								
								
									
										
											BIN
										
									
								
								icons/famfamfam/arrow_turn_left.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 512 B | 
							
								
								
									
										
											BIN
										
									
								
								icons/famfamfam/arrow_turn_right.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 489 B | 
							
								
								
									
										
											BIN
										
									
								
								icons/famfamfam/font.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 567 B | 
							
								
								
									
										
											BIN
										
									
								
								icons/famfamfam/picture_go.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 758 B | 
							
								
								
									
										
											BIN
										
									
								
								icons/famfamfam/text_letterspacing2.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 357 B | 
							
								
								
									
										
											BIN
										
									
								
								images/Font_Minecraft_Rus_5x7_vw.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 43 KiB | 
							
								
								
									
										
											BIN
										
									
								
								images/Screenshot_Font-tester.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 12 KiB | 
							
								
								
									
										
											BIN
										
									
								
								images/Screenshot_Frame-screenshot.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 7.3 KiB | 
| Before Width: | Height: | Size: 49 KiB After Width: | Height: | Size: 54 KiB |