Compare commits
	
		
			2 Commits
		
	
	
		
			fc60991d85
			...
			ceddd5f66f
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | ceddd5f66f | ||
|  | 84561f1ac1 | 
| @@ -8,6 +8,7 @@ using System.Text; | ||||
| using System.Text.RegularExpressions; | ||||
| using System.Threading.Tasks; | ||||
| using System.Windows.Forms; | ||||
| using System.Xml.Linq; | ||||
|  | ||||
| namespace McBitFont { | ||||
|     public partial class Export : Form { | ||||
| @@ -73,80 +74,31 @@ namespace McBitFont { | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         void ParseLine(string line) { | ||||
|             Regex r = new Regex("([ \\t{}():;])"); | ||||
|             string[] tokens = r.Split(line); | ||||
|  | ||||
|             string[] keywords = { "const", "array", "char", "byte" }; | ||||
|             string[] datatypes = { "uint8_t", "uint16_t", "uint32_t" }; | ||||
|             foreach (string token in tokens) { | ||||
|                 // Set the tokens default color and font.   | ||||
|                 txtOutput.SelectionColor = Color.Black; | ||||
|                 txtOutput.SelectionFont = new Font("Courier New", (float)9.75, FontStyle.Regular); | ||||
|  | ||||
|                 // Check for a comment. | ||||
|                 if (token == "//" || token.StartsWith("//")) { | ||||
|                     // Find the start of the comment and then extract the whole comment. | ||||
|                     int index = line.IndexOf("//"); | ||||
|                     string comment = line.Substring(index, line.Length - index); | ||||
|                     txtOutput.SelectionColor = Color.FromArgb(0xFF, 0x3F, 0x7F, 0x5F); | ||||
|                     txtOutput.SelectionFont = new Font("Courier New", (float)9.75, FontStyle.Regular); | ||||
|                     txtOutput.SelectedText = comment; | ||||
|                     break; | ||||
|                 } | ||||
|  | ||||
|                 // Check whether the token is a keyword.    | ||||
|                 for (int i = 0; i < keywords.Length; i++) { | ||||
|                     if (keywords[i] == token) { | ||||
|                         // Apply alternative color and font to highlight keyword.   | ||||
|                         txtOutput.SelectionColor = Color.FromArgb(0xFF, 0x7F, 0x00, 0x55); | ||||
|                         txtOutput.SelectionFont = new Font("Courier New", (float)9.75, FontStyle.Bold); | ||||
|                         break; | ||||
|                     } | ||||
|                 } | ||||
|                 for (int i = 0; i < datatypes.Length; i++) { | ||||
|                     if (datatypes[i] == token) { | ||||
|                         // Apply alternative color and font to highlight data type.   | ||||
|                         txtOutput.SelectionColor = Color.FromArgb(0xFF, 0x00, 0x50, 0x32); ; | ||||
|                         txtOutput.SelectionFont = new Font("Courier New", (float)9.75, FontStyle.Regular); | ||||
|                         break; | ||||
|                     } | ||||
|                 } | ||||
|                 txtOutput.SelectedText = token; | ||||
|             } | ||||
|             txtOutput.SelectedText = "\n"; | ||||
|         } | ||||
|  | ||||
|         void ParseText() { | ||||
|             foreach (string l in txtOutput.Lines) { | ||||
|                 ParseLine(l); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         private void btnGenerate_Click(object sender, EventArgs e) { | ||||
|             //string output = ""; | ||||
|             string output = ""; | ||||
|             txtOutput.Clear(); | ||||
|             bool com = cbComments.Checked; | ||||
|             bool hdr = cbHeader.Checked; | ||||
|             int lines = cbLines.SelectedIndex; | ||||
|             int format = cbFormat.SelectedIndex; | ||||
|  | ||||
|             if (com) { | ||||
|                 //Header comments | ||||
|                 txtOutput.AppendText(comments["header"]); | ||||
|                 txtOutput.AppendText(comments["scan_order"] + cbOrder.Text + "\n"); | ||||
|                 txtOutput.AppendText(comments["scan_hdir"] + cbHDir.Text + "\n"); | ||||
|                 txtOutput.AppendText(comments["scan_vdir"] + cbVDir.Text + "\n\n"); | ||||
|                 output += comments["header"]; | ||||
|                 output += comments["scan_order"] + cbOrder.Text + "\n"; | ||||
|                 output += comments["scan_hdir"] + cbHDir.Text + "\n"; | ||||
|                 output += comments["scan_vdir"] + cbVDir.Text + "\n\n"; | ||||
|  | ||||
|                 txtOutput.AppendText(comments["num_bit_order"] + cbBitOrder.Text + "\n"); | ||||
|                 txtOutput.AppendText(comments["num_base"] + cbNumBase.Text + "\n"); | ||||
|                 txtOutput.AppendText(comments["num_size"] + cbNumSize.Text + "\n\n"); | ||||
|                 output += comments["num_bit_order"] + cbBitOrder.Text + "\n"; | ||||
|                 output += comments["num_base"] + cbNumBase.Text + "\n"; | ||||
|                 output += comments["num_size"] + cbNumSize.Text + "\n\n"; | ||||
|  | ||||
|                 txtOutput.AppendText(comments["text_format"] + cbFormat.Text + "\n"); | ||||
|                 txtOutput.AppendText(comments["text_lines"] + cbLines.Text + "\n\n"); | ||||
|                 output += comments["text_format"] + cbFormat.Text + "\n"; | ||||
|                 output += comments["text_lines"] + cbLines.Text + "\n\n"; | ||||
|  | ||||
|                 if (hdr) { | ||||
|                     // comment about meta header map | ||||
|                     txtOutput.AppendText(comments["font_header_map"] + "\n\n"); | ||||
|                     output += comments["font_header_map"] + "\n\n"; | ||||
|                 } | ||||
|             } | ||||
|  | ||||
| @@ -239,23 +191,39 @@ namespace McBitFont { | ||||
|                     break; | ||||
|             } | ||||
|  | ||||
|             //Array definition | ||||
|             txtOutput.AppendText("const " + dataType + " " + mainForm.prjName + "[] = {\n"); | ||||
|             // Array definition | ||||
|             if ( format == 0 || format == 1 ) output += "const " + dataType + " " + mainForm.prjName + "[] = {\n"; | ||||
|              | ||||
|             if (com) txtOutput.AppendText("  // Data:\n"); | ||||
|             // Brackets for 2D array definition | ||||
|             string obracket = format == 1 ? "{ " : ""; | ||||
|             string cbracket = format == 1 ? " }" : ""; | ||||
|  | ||||
|             // Number output counter | ||||
|             int numcount = 0; | ||||
|              | ||||
|             if (com) output += "  // Data:\n"; | ||||
|             foreach ( MainForm.FrameMiniature f in mainForm.frames) { | ||||
|                 // For each frame | ||||
|                 string str; | ||||
|                 uint b = 0; | ||||
|                 uint b = 0;     // current number bits | ||||
|                 int t, x, y;    // t - calculated bit number; x - actual x; y - actual y | ||||
|  | ||||
|                 if (com && lines != 1) { | ||||
|                     // Comments enabled and other than "1 symbol per line" selected | ||||
|                     // Print a symbol comment before its data | ||||
|                     txtOutput.AppendText("  // " + f.code.ToString() + " --> \n"); | ||||
|                     output += "  // " + f.code.ToString() + " --> " + mainForm.decodeSymbol(f.code) + "\n"; | ||||
|                 } | ||||
|                 if (lines == 1) { | ||||
|                     // "1 symbol per line" - new line offset | ||||
|                     output += "  "; | ||||
|                     numcount = 0; | ||||
|                 } | ||||
|                 for (int i = imin; i != imax; i += idir) { | ||||
|                     str = "  "; | ||||
|                     if (lines == 0) { | ||||
|                         // "Column/Row per line" - new line offset | ||||
|                         output += "  " + obracket; | ||||
|                         numcount = 0; | ||||
|                     } | ||||
|                     for (int j = jmin; j != jmax; j += jdir) { | ||||
|                         if (jdir < 0) t = jmin - j; | ||||
|                         else t = j; | ||||
| @@ -278,21 +246,37 @@ namespace McBitFont { | ||||
|                              | ||||
|                         } | ||||
|                         if (((t + 1) % bits == 0) || j + jdir == jmax) { | ||||
|                             if (str.Length > 2) str += " "; | ||||
|                             // we have filled a number with bits - let's post it | ||||
|  | ||||
|                             // should we post a comma before the number? | ||||
|                             output += numcount == 0 ? "" : ", "; | ||||
|  | ||||
|                             // should we post a prefix to the number? | ||||
|                             pref = (!cbZeroes.Checked && ((b < 10 && nbase == 16) || (b < 2 && nbase == 2))) ? "" : prefix; | ||||
|                             str += pref + Convert.ToString(b, nbase).PadLeft(pad, '0') + ','; | ||||
|                             output += pref + Convert.ToString(b, nbase).PadLeft(pad, '0'); | ||||
|  | ||||
|                             // count posted numbers | ||||
|                             numcount++; | ||||
|                         } | ||||
|                     } | ||||
|                     txtOutput.AppendText(str); | ||||
|                     txtOutput.AppendText(Environment.NewLine); | ||||
|                     if (lines == 0) { | ||||
|                         // "Column/Row per line" - closing line | ||||
|                         output += cbracket + (i+idir!=imax ? "," : "") + "\n"; | ||||
|                     } | ||||
|                 } | ||||
|                 if (lines == 1) { | ||||
|                     // "1 symbol per line" - closing line | ||||
|                     if (com) { | ||||
|                         //...with a comment | ||||
|                         output += " // " + f.code.ToString() + " --> " + mainForm.decodeSymbol(f.code); | ||||
|                     } | ||||
|                     output += "\n"; | ||||
|                 } | ||||
|                 txtOutput.AppendText(Environment.NewLine); | ||||
|             } | ||||
|             // Close array definition | ||||
|             txtOutput.AppendText("};\n"); | ||||
|             output += "};\n"; | ||||
|  | ||||
|             txtOutput.SelectAll(); | ||||
|             ParseText(); | ||||
|             txtOutput.Text = output; | ||||
|             txtOutput.SelectionStart = 0; | ||||
|             txtOutput.ScrollToCaret(); | ||||
|         } | ||||
| @@ -302,6 +286,12 @@ namespace McBitFont { | ||||
|                 MessageBox.Show("Cannot pack the font meta header into 2D array!\nChoose 1D array or disable the meta header.\n(Setting array format to 1D array)", "No header in 2D array!", MessageBoxButtons.OK, MessageBoxIcon.Information); | ||||
|                 cbFormat.SelectedIndex = 0; | ||||
|             } | ||||
|             if (cbFormat.SelectedIndex == 1) { | ||||
|                 cbLines.SelectedIndex = 0; | ||||
|                 cbLines.Enabled = false; | ||||
|             } else { | ||||
|                 cbLines.Enabled = true; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -35,6 +35,7 @@ namespace McBitFont { | ||||
|         [Serializable] | ||||
|         public struct SaveBlock { | ||||
|             public bool monospaced; | ||||
|             public int codepage; | ||||
|             public List<FrameMiniature> frames; | ||||
|         } | ||||
|  | ||||
| @@ -50,6 +51,7 @@ namespace McBitFont { | ||||
|         bool prjModified = false; | ||||
|         public const string version = "1.0"; | ||||
|         public string prjName = "Untitled"; | ||||
|         public int codepage = 1251; | ||||
|  | ||||
|         public MainForm() { | ||||
|             InitializeComponent(); | ||||
| @@ -441,6 +443,12 @@ namespace McBitFont { | ||||
|             Application.Exit(); | ||||
|         } | ||||
|  | ||||
|         public string decodeSymbol(int code) { | ||||
|             var enc = Encoding.GetEncoding(codepage); | ||||
|             if (code < 32) return ""; | ||||
|             return enc.GetString(new byte[] { (byte)code }); | ||||
|         } | ||||
|  | ||||
|         private void newToolStripMenuItem_Click(object sender, EventArgs e) { | ||||
|             if (prjModified) { | ||||
|                 if (MessageBox.Show("The project is modified.\nDo you want to save it first?", "Project was modified!", MessageBoxButtons.YesNo, MessageBoxIcon.Question) == DialogResult.Yes) { | ||||
| @@ -457,6 +465,8 @@ namespace McBitFont { | ||||
|                 string append = ""; | ||||
|                 int neww = (int)form.nudNewX.Value; | ||||
|                 int newh = (int)form.nudNewY.Value; | ||||
|                 nudX.Value = neww; | ||||
|                 nudY.Value = newh; | ||||
|                 if (form.cbSingle.Checked) { | ||||
|                     frames.Add( new FrameMiniature(0, neww, newh)); | ||||
|                     //f = frames.Find(x => x.code == 0); | ||||
| @@ -482,12 +492,10 @@ namespace McBitFont { | ||||
|                 foreach (FrameMiniature ff in frames) { | ||||
|                     var s = ff.code.ToString(); | ||||
|                     ilMiniatures.Images.Add(s, (Image)getMiniPictue(ff)); | ||||
|                     var enc = Encoding.GetEncoding((form.cbEncoding.SelectedItem as New.EncodingItem).Code); | ||||
|                     var sss = enc.GetString(new byte[] { (byte)ff.code }); | ||||
|                     codepage =(form.cbEncoding.SelectedItem as New.EncodingItem).Code; | ||||
|                     var sss = decodeSymbol(ff.code); | ||||
|                     miniList.Items.Add(s, s+' '+append+sss, s); | ||||
|                 } | ||||
|                 nudX.Value =neww; | ||||
|                 nudY.Value = newh; | ||||
|                 f = copyFrame(frames.First()); | ||||
|                 dotPanel.Refresh(); | ||||
|                 miniList.Refresh(); | ||||
| @@ -523,6 +531,7 @@ namespace McBitFont { | ||||
|                 SaveBlock sav; | ||||
|                 sav.monospaced = monospaced; | ||||
|                 sav.frames = frames; | ||||
|                 sav.codepage = codepage; | ||||
|                 BinaryFormatter formatter = new BinaryFormatter(); | ||||
|                 using (Stream ms = File.OpenWrite(dlgSave.FileName)) { | ||||
|                     formatter.Serialize(ms, sav); | ||||
| @@ -542,7 +551,6 @@ namespace McBitFont { | ||||
|                 } | ||||
|             } | ||||
|             if (dlgOpen.ShowDialog() == DialogResult.OK) { | ||||
|                 //MessageBox.Show(dlgOpen.FileName); | ||||
|                 SaveBlock sav; | ||||
|                 BinaryFormatter formatter = new BinaryFormatter(); | ||||
|  | ||||
| @@ -551,6 +559,7 @@ namespace McBitFont { | ||||
|                     fs.Close(); | ||||
|                 } | ||||
|                 monospaced = sav.monospaced; | ||||
|                 codepage = sav.codepage; | ||||
|                 lblType.Text = monospaced ? "Monospaced" : "Variable width / Single"; | ||||
|                 frames = sav.frames; | ||||
|                 miniList.Items.Clear(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user