Compare commits
21 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
e0a4a6194c | ||
|
6971686f88 | ||
|
ac2e345397 | ||
|
d1d653bc34 | ||
1c034fded1 | |||
|
a05352acf7 | ||
2f86598a2a | |||
|
313f35bb3e | ||
|
679b4fc61d | ||
|
eda7af8f67 | ||
|
4381d6d911 | ||
|
8d34e34326 | ||
|
92027a0ee3 | ||
6c32edac6e | |||
f9c9d440ec | |||
|
f8b53f2dab | ||
|
2a4b36d368 | ||
083ede5985 | |||
5208d40a92 | |||
519720f2ef | |||
88ee72567e |
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();
|
||||||
|
@@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
|
private 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);
|
||||||
|
197
McBitFont/FontTester.Designer.cs
generated
Normal file
@@ -0,0 +1,197 @@
|
|||||||
|
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);
|
||||||
|
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 = 1;
|
||||||
|
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 = 3;
|
||||||
|
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, 125);
|
||||||
|
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[] { "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 = 19;
|
||||||
|
cbZoom.TabStop = false;
|
||||||
|
toolTip1.SetToolTip(cbZoom, "Zoom level");
|
||||||
|
cbZoom.SelectedIndexChanged += ZoomChanged;
|
||||||
|
//
|
||||||
|
// toolTip1
|
||||||
|
//
|
||||||
|
toolTip1.AutoPopDelay = 10000;
|
||||||
|
toolTip1.InitialDelay = 500;
|
||||||
|
toolTip1.ReshowDelay = 100;
|
||||||
|
//
|
||||||
|
// 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 = 20;
|
||||||
|
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, 221);
|
||||||
|
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(260, 260);
|
||||||
|
Name = "FontTester";
|
||||||
|
ShowIcon = false;
|
||||||
|
ShowInTaskbar = false;
|
||||||
|
StartPosition = System.Windows.Forms.FormStartPosition.CenterParent;
|
||||||
|
Text = "Font Tester";
|
||||||
|
Load += FontTester_Load;
|
||||||
|
((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;
|
||||||
|
}
|
||||||
|
}
|
166
McBitFont/FontTester.cs
Normal file
@@ -0,0 +1,166 @@
|
|||||||
|
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;
|
||||||
|
|
||||||
|
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 suck 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();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
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>
|
70
McBitFont/Form1.Designer.cs
generated
@@ -64,9 +64,12 @@
|
|||||||
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();
|
||||||
|
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();
|
||||||
@@ -83,6 +86,8 @@
|
|||||||
removeBeforeToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
removeBeforeToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||||
removeAfterToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
removeAfterToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||||
CodeShiftToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
CodeShiftToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||||
|
toolStripSeparator3 = 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();
|
||||||
@@ -107,6 +112,7 @@
|
|||||||
lblSelectionLabel = new System.Windows.Forms.Label();
|
lblSelectionLabel = new System.Windows.Forms.Label();
|
||||||
lblSelection = new System.Windows.Forms.Label();
|
lblSelection = new System.Windows.Forms.Label();
|
||||||
lblModified = new System.Windows.Forms.Label();
|
lblModified = new System.Windows.Forms.Label();
|
||||||
|
dlgSavePNG = new System.Windows.Forms.SaveFileDialog();
|
||||||
((System.ComponentModel.ISupportInitialize)nudX).BeginInit();
|
((System.ComponentModel.ISupportInitialize)nudX).BeginInit();
|
||||||
((System.ComponentModel.ISupportInitialize)nudY).BeginInit();
|
((System.ComponentModel.ISupportInitialize)nudY).BeginInit();
|
||||||
panel1.SuspendLayout();
|
panel1.SuspendLayout();
|
||||||
@@ -364,7 +370,7 @@
|
|||||||
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");
|
||||||
btnExport.UseVisualStyleBackColor = true;
|
btnExport.UseVisualStyleBackColor = true;
|
||||||
btnExport.Click += button1_Click;
|
btnExport.Click += Export_Click;
|
||||||
//
|
//
|
||||||
// miniList
|
// miniList
|
||||||
//
|
//
|
||||||
@@ -527,7 +533,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, 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";
|
||||||
@@ -576,12 +582,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
|
||||||
@@ -602,7 +614,21 @@
|
|||||||
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;
|
||||||
|
//
|
||||||
|
// toolStripSeparator2
|
||||||
|
//
|
||||||
|
toolStripSeparator2.Name = "toolStripSeparator2";
|
||||||
|
toolStripSeparator2.Size = new System.Drawing.Size(221, 6);
|
||||||
//
|
//
|
||||||
// exitToolStripMenuItem
|
// exitToolStripMenuItem
|
||||||
//
|
//
|
||||||
@@ -656,7 +682,6 @@
|
|||||||
//
|
//
|
||||||
// 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 = "";
|
||||||
@@ -673,6 +698,7 @@
|
|||||||
selectToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.R;
|
selectToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.R;
|
||||||
selectToolStripMenuItem.Size = new System.Drawing.Size(164, 22);
|
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
|
||||||
@@ -683,11 +709,12 @@
|
|||||||
selectAllToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.A;
|
selectAllToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.A;
|
||||||
selectAllToolStripMenuItem.Size = new System.Drawing.Size(164, 22);
|
selectAllToolStripMenuItem.Size = new System.Drawing.Size(164, 22);
|
||||||
selectAllToolStripMenuItem.Text = "Select All";
|
selectAllToolStripMenuItem.Text = "Select All";
|
||||||
|
selectAllToolStripMenuItem.ToolTipText = "Select entire canvas";
|
||||||
selectAllToolStripMenuItem.Click += selectAllToolStripMenuItem_Click;
|
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, CodeShiftToolStripMenuItem, toolStripSeparator3, 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";
|
||||||
@@ -767,6 +794,20 @@
|
|||||||
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(212, 6);
|
||||||
|
//
|
||||||
|
// testFontToolStripMenuItem
|
||||||
|
//
|
||||||
|
testFontToolStripMenuItem.Image = Properties.Resources.font;
|
||||||
|
testFontToolStripMenuItem.Name = "testFontToolStripMenuItem";
|
||||||
|
testFontToolStripMenuItem.Size = new System.Drawing.Size(215, 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 });
|
||||||
@@ -1023,6 +1064,11 @@
|
|||||||
lblModified.Text = "Frame modified";
|
lblModified.Text = "Frame modified";
|
||||||
lblModified.Visible = false;
|
lblModified.Visible = false;
|
||||||
//
|
//
|
||||||
|
// dlgSavePNG
|
||||||
|
//
|
||||||
|
dlgSavePNG.DefaultExt = "png";
|
||||||
|
dlgSavePNG.Filter = "PNG Image|*.png;*.PNG";
|
||||||
|
//
|
||||||
// MainForm
|
// MainForm
|
||||||
//
|
//
|
||||||
AutoScaleDimensions = new System.Drawing.SizeF(7F, 15F);
|
AutoScaleDimensions = new System.Drawing.SizeF(7F, 15F);
|
||||||
@@ -1076,8 +1122,6 @@
|
|||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
private System.Windows.Forms.Panel dotPanel;
|
private System.Windows.Forms.Panel dotPanel;
|
||||||
private System.Windows.Forms.NumericUpDown nudX;
|
|
||||||
private System.Windows.Forms.NumericUpDown nudY;
|
|
||||||
private System.Windows.Forms.Label label1;
|
private System.Windows.Forms.Label label1;
|
||||||
private System.Windows.Forms.Label label2;
|
private System.Windows.Forms.Label label2;
|
||||||
private System.Windows.Forms.Label lblType;
|
private System.Windows.Forms.Label lblType;
|
||||||
@@ -1092,8 +1136,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;
|
||||||
@@ -1157,6 +1199,16 @@
|
|||||||
private System.Windows.Forms.Label lblSelection;
|
private System.Windows.Forms.Label lblSelection;
|
||||||
private System.Windows.Forms.ToolStripMenuItem selectAllToolStripMenuItem;
|
private System.Windows.Forms.ToolStripMenuItem selectAllToolStripMenuItem;
|
||||||
private System.Windows.Forms.Label lblModified;
|
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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -3,6 +3,7 @@ using System;
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Drawing;
|
using System.Drawing;
|
||||||
using System.Drawing.Drawing2D;
|
using System.Drawing.Drawing2D;
|
||||||
|
using System.Drawing.Imaging;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
@@ -46,23 +47,24 @@ namespace McBitFont {
|
|||||||
public List<FrameMiniature> frames;
|
public List<FrameMiniature> frames;
|
||||||
}
|
}
|
||||||
|
|
||||||
private FrameMiniature f;
|
public FrameMiniature f;
|
||||||
public List<FrameMiniature> frames = new List<FrameMiniature>();
|
public List<FrameMiniature> frames = new List<FrameMiniature>();
|
||||||
private CanvasHistory history = new();
|
//private CanvasHistory history = new();
|
||||||
|
private ChangeHistory history;
|
||||||
private int cellSize = 10;
|
private int cellSize = 10;
|
||||||
public int dotWidth, dotHeight;
|
public int dotWidth, dotHeight;
|
||||||
private int pixelOffset = 5;
|
private readonly int pixelOffset = 5;
|
||||||
private int gap;
|
private int gap;
|
||||||
private int w, h;
|
private int w, h;
|
||||||
public bool monospaced = false;
|
public bool monospaced = false;
|
||||||
private bool modified = false;
|
private bool modified = false;
|
||||||
private bool prjModified = false;
|
private bool prjModified = false;
|
||||||
public const string version = "2.2";
|
public const string version = "2.4";
|
||||||
public string prjName = "Untitled";
|
public string prjName = "Untitled";
|
||||||
public string prjFileName = "";
|
public string prjFileName = "";
|
||||||
private int codepage = 1251;
|
public int codepage = 1251;
|
||||||
private FrameMiniature fbuf;
|
private FrameMiniature fbuf;
|
||||||
private bool fbuffer = false;
|
private readonly DataFormats.Format clpbFormat = DataFormats.GetFormat("McBitFontFrame");
|
||||||
private int baseline = 0;
|
private int baseline = 0;
|
||||||
private bool set_base = false;
|
private bool set_base = false;
|
||||||
private Point selection1, selection2;
|
private Point selection1, selection2;
|
||||||
@@ -74,7 +76,7 @@ namespace McBitFont {
|
|||||||
this.dotPanel.MouseWheel += new MouseEventHandler(this.DotPanel_MouseWheel);
|
this.dotPanel.MouseWheel += new MouseEventHandler(this.DotPanel_MouseWheel);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SetNewWH() {
|
public void SetNewWH() {
|
||||||
w = pixelOffset + dotWidth * (cellSize + gap);
|
w = pixelOffset + dotWidth * (cellSize + gap);
|
||||||
h = pixelOffset + dotHeight * (cellSize + gap);
|
h = pixelOffset + dotHeight * (cellSize + gap);
|
||||||
}
|
}
|
||||||
@@ -83,7 +85,7 @@ namespace McBitFont {
|
|||||||
lblSelection.Text = width.ToString() + ',' + height.ToString();
|
lblSelection.Text = width.ToString() + ',' + height.ToString();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SetModified(bool modif = true, bool prj = false) {
|
public void SetModified(bool modif = true, bool prj = false) {
|
||||||
string suffix = "";
|
string suffix = "";
|
||||||
if (prj) {
|
if (prj) {
|
||||||
prjModified = modif;
|
prjModified = modif;
|
||||||
@@ -136,7 +138,9 @@ namespace McBitFont {
|
|||||||
tsmiCodeShift.Visible = frames.Count > 1;
|
tsmiCodeShift.Visible = frames.Count > 1;
|
||||||
CodeShiftToolStripMenuItem.Visible = frames.Count > 1;
|
CodeShiftToolStripMenuItem.Visible = frames.Count > 1;
|
||||||
|
|
||||||
|
CheckForAdd();
|
||||||
|
|
||||||
|
history = new(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
[DllImport("user32.dll")]
|
[DllImport("user32.dll")]
|
||||||
@@ -146,9 +150,9 @@ namespace McBitFont {
|
|||||||
return (int)(((ushort)lowPart) | (uint)(highPart << 16));
|
return (int)(((ushort)lowPart) | (uint)(highPart << 16));
|
||||||
}
|
}
|
||||||
|
|
||||||
private FrameMiniature CopyFrame(FrameMiniature frame, bool clipboard = false) {
|
public FrameMiniature CopyFrame(FrameMiniature frame, bool clipboard = false) {
|
||||||
int width = chkRectSelect.Checked ? selection2.X - selection1.X + 1 : frame.width;
|
int width = chkRectSelect.Checked && clipboard ? selection2.X - selection1.X + 1 : frame.width;
|
||||||
int height = chkRectSelect.Checked ? selection2.Y - selection1.Y + 1 : frame.height;
|
int height = chkRectSelect.Checked && clipboard ? selection2.Y - selection1.Y + 1 : frame.height;
|
||||||
var ff = new FrameMiniature(frame.code, width, height);
|
var ff = new FrameMiniature(frame.code, width, height);
|
||||||
|
|
||||||
if (chkRectSelect.Checked && clipboard) {
|
if (chkRectSelect.Checked && clipboard) {
|
||||||
@@ -193,7 +197,7 @@ namespace McBitFont {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void nudX_ValueChanged(object sender, EventArgs e) {
|
public void nudX_ValueChanged(object sender, EventArgs e) {
|
||||||
Cursor.Current = Cursors.WaitCursor;
|
Cursor.Current = Cursors.WaitCursor;
|
||||||
if (monospaced) {
|
if (monospaced) {
|
||||||
Bitmap bmp;
|
Bitmap bmp;
|
||||||
@@ -212,10 +216,13 @@ namespace McBitFont {
|
|||||||
}
|
}
|
||||||
|
|
||||||
DotResize((int)nudX.Value, dotHeight);
|
DotResize((int)nudX.Value, dotHeight);
|
||||||
|
if (monospaced) history.Add(frames);
|
||||||
|
else history.Add(f);
|
||||||
|
|
||||||
Cursor.Current = Cursors.Default;
|
Cursor.Current = Cursors.Default;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void nudY_ValueChanged(object sender, EventArgs e) {
|
public void nudY_ValueChanged(object sender, EventArgs e) {
|
||||||
Cursor.Current = Cursors.WaitCursor;
|
Cursor.Current = Cursors.WaitCursor;
|
||||||
Bitmap bmp;
|
Bitmap bmp;
|
||||||
for (int i = 0; i < frames.Count; i++) {
|
for (int i = 0; i < frames.Count; i++) {
|
||||||
@@ -232,6 +239,7 @@ namespace McBitFont {
|
|||||||
}
|
}
|
||||||
|
|
||||||
DotResize(dotWidth, (int)nudY.Value);
|
DotResize(dotWidth, (int)nudY.Value);
|
||||||
|
history.Add(frames);
|
||||||
Cursor.Current = Cursors.Default;
|
Cursor.Current = Cursors.Default;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -279,7 +287,7 @@ namespace McBitFont {
|
|||||||
cbZoom_SelectedIndexChanged(cbZoom, null);
|
cbZoom_SelectedIndexChanged(cbZoom, null);
|
||||||
|
|
||||||
// Re-create history object
|
// Re-create history object
|
||||||
history = new CanvasHistory();
|
//history = new CanvasHistory();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void cbZoom_SelectedIndexChanged(object sender, EventArgs e) {
|
private void cbZoom_SelectedIndexChanged(object sender, EventArgs e) {
|
||||||
@@ -327,7 +335,7 @@ namespace McBitFont {
|
|||||||
|
|
||||||
(x, y, x2, y2) = RectSelCoords();
|
(x, y, x2, y2) = RectSelCoords();
|
||||||
|
|
||||||
history.AddPre(f);
|
//history.AddPre(f);
|
||||||
for (int i = x; i <= x2; i++) {
|
for (int i = x; i <= x2; i++) {
|
||||||
c = f.data[i, y];
|
c = f.data[i, y];
|
||||||
for (int j = y; j <= y2; j++) {
|
for (int j = y; j <= y2; j++) {
|
||||||
@@ -338,7 +346,8 @@ namespace McBitFont {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
history.AddPost(f);
|
//history.AddPost(f);
|
||||||
|
history.Add(f);
|
||||||
CheckHistoryButtons();
|
CheckHistoryButtons();
|
||||||
SetModified();
|
SetModified();
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
@@ -350,7 +359,7 @@ namespace McBitFont {
|
|||||||
|
|
||||||
(x, y, x2, y2) = RectSelCoords();
|
(x, y, x2, y2) = RectSelCoords();
|
||||||
|
|
||||||
history.AddPre(f);
|
//history.AddPre(f);
|
||||||
for (int i = x; i <= x2; i++) {
|
for (int i = x; i <= x2; i++) {
|
||||||
c = f.data[i, y2];
|
c = f.data[i, y2];
|
||||||
for (int j = y2; j >= y; j--) {
|
for (int j = y2; j >= y; j--) {
|
||||||
@@ -361,7 +370,8 @@ namespace McBitFont {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
history.AddPost(f);
|
//history.AddPost(f);
|
||||||
|
history.Add(f);
|
||||||
CheckHistoryButtons();
|
CheckHistoryButtons();
|
||||||
SetModified();
|
SetModified();
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
@@ -373,7 +383,7 @@ namespace McBitFont {
|
|||||||
|
|
||||||
(x, y, x2, y2) = RectSelCoords();
|
(x, y, x2, y2) = RectSelCoords();
|
||||||
|
|
||||||
history.AddPre(f);
|
//history.AddPre(f);
|
||||||
for (int j = y; j <= y2; j++) {
|
for (int j = y; j <= y2; j++) {
|
||||||
c = f.data[x, j];
|
c = f.data[x, j];
|
||||||
for (int i = x; i <= x2; i++) {
|
for (int i = x; i <= x2; i++) {
|
||||||
@@ -384,7 +394,8 @@ namespace McBitFont {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
history.AddPost(f);
|
//history.AddPost(f);
|
||||||
|
history.Add(f);
|
||||||
CheckHistoryButtons();
|
CheckHistoryButtons();
|
||||||
SetModified();
|
SetModified();
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
@@ -395,7 +406,7 @@ namespace McBitFont {
|
|||||||
bool c;
|
bool c;
|
||||||
(x, y, x2, y2) = RectSelCoords();
|
(x, y, x2, y2) = RectSelCoords();
|
||||||
|
|
||||||
history.AddPre(f);
|
//history.AddPre(f);
|
||||||
for (int j = y; j <= y2; j++) {
|
for (int j = y; j <= y2; j++) {
|
||||||
c = f.data[x2, j];
|
c = f.data[x2, j];
|
||||||
for (int i = x2; i >= x; i--) {
|
for (int i = x2; i >= x; i--) {
|
||||||
@@ -406,7 +417,8 @@ namespace McBitFont {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
history.AddPost(f);
|
//history.AddPost(f);
|
||||||
|
history.Add(f);
|
||||||
CheckHistoryButtons();
|
CheckHistoryButtons();
|
||||||
SetModified();
|
SetModified();
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
@@ -456,6 +468,7 @@ namespace McBitFont {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (e.Button != MouseButtons.None && !mouseDown) {
|
if (e.Button != MouseButtons.None && !mouseDown) {
|
||||||
|
// Started to move a mouse with button held
|
||||||
mouseDown = true;
|
mouseDown = true;
|
||||||
if (rectSel) {
|
if (rectSel) {
|
||||||
selection1.X = i;
|
selection1.X = i;
|
||||||
@@ -463,20 +476,23 @@ namespace McBitFont {
|
|||||||
selection2.X = i;
|
selection2.X = i;
|
||||||
selection2.Y = j;
|
selection2.Y = j;
|
||||||
dotPanel.Invalidate();
|
dotPanel.Invalidate();
|
||||||
} else history.AddPre(f, false);
|
} //else history.AddPre(f, false);
|
||||||
}
|
}
|
||||||
if (e.Button == MouseButtons.None && mouseDown) {
|
if (e.Button == MouseButtons.None && mouseDown) {
|
||||||
|
// Released a mouse button
|
||||||
mouseDown = false;
|
mouseDown = false;
|
||||||
if (rectSel) {
|
if (rectSel) {
|
||||||
NormPoints(ref selection1, ref selection2);
|
NormPoints(ref selection1, ref selection2);
|
||||||
dotPanel.Invalidate();
|
dotPanel.Invalidate();
|
||||||
} else {
|
} else {
|
||||||
if (!fChanged) {
|
//if (!fChanged) {
|
||||||
history.Remove(false);
|
// history.Remove(false);
|
||||||
} else {
|
//} else {
|
||||||
|
if (fChanged) {
|
||||||
fChanged = false;
|
fChanged = false;
|
||||||
history.ApplyAdded();
|
//history.ApplyAdded();
|
||||||
history.AddPost(f);
|
//history.AddPost(f);
|
||||||
|
history.Add(f);
|
||||||
}
|
}
|
||||||
CheckHistoryButtons();
|
CheckHistoryButtons();
|
||||||
}
|
}
|
||||||
@@ -538,7 +554,7 @@ namespace McBitFont {
|
|||||||
private void btnInvert_Click(object sender, EventArgs e) {
|
private void btnInvert_Click(object sender, EventArgs e) {
|
||||||
int x, y, x2, y2;
|
int x, y, x2, y2;
|
||||||
|
|
||||||
history.AddPre(f);
|
//history.AddPre(f);
|
||||||
|
|
||||||
(x, y, x2, y2) = RectSelCoords();
|
(x, y, x2, y2) = RectSelCoords();
|
||||||
|
|
||||||
@@ -548,7 +564,8 @@ namespace McBitFont {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
history.AddPost(f);
|
//history.AddPost(f);
|
||||||
|
history.Add(f);
|
||||||
CheckHistoryButtons();
|
CheckHistoryButtons();
|
||||||
SetModified();
|
SetModified();
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
@@ -560,7 +577,7 @@ namespace McBitFont {
|
|||||||
|
|
||||||
(x, y, x2, y2) = RectSelCoords();
|
(x, y, x2, y2) = RectSelCoords();
|
||||||
|
|
||||||
history.AddPre(f);
|
//history.AddPre(f);
|
||||||
for (j = y; j <= y2; j++) {
|
for (j = y; j <= y2; j++) {
|
||||||
a = x;
|
a = x;
|
||||||
b = x2;
|
b = x2;
|
||||||
@@ -572,7 +589,8 @@ namespace McBitFont {
|
|||||||
b--;
|
b--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
history.AddPost(f);
|
//history.AddPost(f);
|
||||||
|
history.Add(f);
|
||||||
CheckHistoryButtons();
|
CheckHistoryButtons();
|
||||||
SetModified();
|
SetModified();
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
@@ -584,7 +602,7 @@ namespace McBitFont {
|
|||||||
|
|
||||||
(x, y, x2, y2) = RectSelCoords();
|
(x, y, x2, y2) = RectSelCoords();
|
||||||
|
|
||||||
history.AddPre(f);
|
//history.AddPre(f);
|
||||||
for (i = x; i <= x2; i++) {
|
for (i = x; i <= x2; i++) {
|
||||||
a = y;
|
a = y;
|
||||||
b = y2;
|
b = y2;
|
||||||
@@ -596,13 +614,14 @@ namespace McBitFont {
|
|||||||
b--;
|
b--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
history.AddPost(f);
|
//history.AddPost(f);
|
||||||
|
history.Add(f);
|
||||||
CheckHistoryButtons();
|
CheckHistoryButtons();
|
||||||
SetModified();
|
SetModified();
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void button1_Click(object sender, EventArgs e) {
|
private void Export_Click(object sender, EventArgs e) {
|
||||||
if (modified) {
|
if (modified) {
|
||||||
if (MessageBox.Show("Current symbol is modified.\nDo you want to save the changes?", "Symbol was modified!", MessageBoxButtons.YesNo) == DialogResult.Yes) {
|
if (MessageBox.Show("Current symbol is modified.\nDo you want to save the changes?", "Symbol was modified!", MessageBoxButtons.YesNo) == DialogResult.Yes) {
|
||||||
SaveFrame();
|
SaveFrame();
|
||||||
@@ -634,7 +653,7 @@ namespace McBitFont {
|
|||||||
SetModified(true, true);
|
SetModified(true, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Bitmap GetMiniPictue(FrameMiniature m) {
|
public static Bitmap GetMiniPictue(FrameMiniature m) {
|
||||||
int picSize = (m.width > m.height) ? m.width : m.height;
|
int picSize = (m.width > m.height) ? m.width : m.height;
|
||||||
var bmp = new Bitmap(picSize, picSize);
|
var bmp = new Bitmap(picSize, picSize);
|
||||||
int imin = m.width < picSize ? (picSize - m.width) / 2 : 0;
|
int imin = m.width < picSize ? (picSize - m.width) / 2 : 0;
|
||||||
@@ -646,7 +665,7 @@ namespace McBitFont {
|
|||||||
bmp.SetPixel(i + imin, j + jmin, c);
|
bmp.SetPixel(i + imin, j + jmin, c);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Bitmap sbmp = new Bitmap(50, 50);
|
Bitmap sbmp = new(50, 50);
|
||||||
using (Graphics g = Graphics.FromImage(sbmp)) {
|
using (Graphics g = Graphics.FromImage(sbmp)) {
|
||||||
g.InterpolationMode = InterpolationMode.NearestNeighbor;
|
g.InterpolationMode = InterpolationMode.NearestNeighbor;
|
||||||
g.PixelOffsetMode = PixelOffsetMode.Half;
|
g.PixelOffsetMode = PixelOffsetMode.Half;
|
||||||
@@ -816,13 +835,13 @@ namespace McBitFont {
|
|||||||
SetWindowCap();
|
SetWindowCap();
|
||||||
SetModified(false); ;
|
SetModified(false); ;
|
||||||
CheckForAdd();
|
CheckForAdd();
|
||||||
fbuffer = false;
|
|
||||||
miniList.Items[0].Selected = true;
|
miniList.Items[0].Selected = true;
|
||||||
miniList.Refresh();
|
miniList.Refresh();
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
|
|
||||||
// Re-create history object
|
// Re-create history object
|
||||||
history = new CanvasHistory();
|
//history = new CanvasHistory();
|
||||||
|
history.Clear();
|
||||||
|
|
||||||
Cursor.Current = Cursors.Default;
|
Cursor.Current = Cursors.Default;
|
||||||
}
|
}
|
||||||
@@ -838,14 +857,12 @@ namespace McBitFont {
|
|||||||
tsmiRemoveSymbol.Enabled = false;
|
tsmiRemoveSymbol.Enabled = false;
|
||||||
tsmiRemoveBefore.Enabled = false;
|
tsmiRemoveBefore.Enabled = false;
|
||||||
tsmiRemoveAfter.Enabled = false;
|
tsmiRemoveAfter.Enabled = false;
|
||||||
//copyToolStripMenuItem.Enabled = false;
|
|
||||||
pasteToolStripMenuItem.Enabled = false;
|
|
||||||
return;
|
|
||||||
//miniList.Items[0].Selected = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
dotPanel.SuspendLayout();
|
||||||
// Clear history
|
// Clear history
|
||||||
history.Clear();
|
//history.Clear();
|
||||||
|
|
||||||
var sel = miniList.SelectedItems[0];
|
var sel = miniList.SelectedItems[0];
|
||||||
int code = Convert.ToInt32(sel.ImageKey);
|
int code = Convert.ToInt32(sel.ImageKey);
|
||||||
@@ -853,7 +870,10 @@ namespace McBitFont {
|
|||||||
nudX.Value = ff.width;
|
nudX.Value = ff.width;
|
||||||
nudY.Value = ff.height;
|
nudY.Value = ff.height;
|
||||||
f = ff;
|
f = ff;
|
||||||
dotPanel.Refresh();
|
|
||||||
|
|
||||||
|
history.Add(code);
|
||||||
|
|
||||||
ff = frames.Find(x => x.code == code);
|
ff = frames.Find(x => x.code == code);
|
||||||
if (frames.Count > 1 && (ff.Equals(frames.First()) || ff.Equals(frames.Last()))) {
|
if (frames.Count > 1 && (ff.Equals(frames.First()) || ff.Equals(frames.Last()))) {
|
||||||
removeSymbolToolStripMenuItem.Enabled = true;
|
removeSymbolToolStripMenuItem.Enabled = true;
|
||||||
@@ -862,26 +882,27 @@ namespace McBitFont {
|
|||||||
removeSymbolToolStripMenuItem.Enabled = false;
|
removeSymbolToolStripMenuItem.Enabled = false;
|
||||||
tsmiRemoveSymbol.Enabled = false;
|
tsmiRemoveSymbol.Enabled = false;
|
||||||
}
|
}
|
||||||
//copyToolStripMenuItem.Enabled = true;
|
|
||||||
if (ff.Equals(frames.First())) {
|
dotPanel.ResumeLayout();
|
||||||
|
dotPanel.Refresh();
|
||||||
|
|
||||||
|
if (frames.Count > 1 && ff.Equals(frames.First())) {
|
||||||
removeBeforeToolStripMenuItem.Enabled = false;
|
removeBeforeToolStripMenuItem.Enabled = false;
|
||||||
removeAfterToolStripMenuItem.Enabled = true;
|
removeAfterToolStripMenuItem.Enabled = true;
|
||||||
tsmiRemoveBefore.Enabled = false;
|
tsmiRemoveBefore.Enabled = false;
|
||||||
tsmiRemoveAfter.Enabled = true;
|
tsmiRemoveAfter.Enabled = true;
|
||||||
} else if (ff.Equals(frames.Last())) {
|
} else if (frames.Count > 1 && ff.Equals(frames.Last())) {
|
||||||
removeBeforeToolStripMenuItem.Enabled = true;
|
removeBeforeToolStripMenuItem.Enabled = true;
|
||||||
removeAfterToolStripMenuItem.Enabled = false;
|
removeAfterToolStripMenuItem.Enabled = false;
|
||||||
tsmiRemoveBefore.Enabled = true;
|
tsmiRemoveBefore.Enabled = true;
|
||||||
tsmiRemoveAfter.Enabled = false;
|
tsmiRemoveAfter.Enabled = false;
|
||||||
} else {
|
} else if (frames.Count > 1) {
|
||||||
removeBeforeToolStripMenuItem.Enabled = true;
|
removeBeforeToolStripMenuItem.Enabled = true;
|
||||||
removeAfterToolStripMenuItem.Enabled = true;
|
removeAfterToolStripMenuItem.Enabled = true;
|
||||||
tsmiRemoveBefore.Enabled = true;
|
tsmiRemoveBefore.Enabled = true;
|
||||||
tsmiRemoveAfter.Enabled = true;
|
tsmiRemoveAfter.Enabled = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fbuffer) pasteToolStripMenuItem.Enabled = true;
|
|
||||||
else pasteToolStripMenuItem.Enabled = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SaveToolStripMenuItem_Click(object sender, EventArgs e) {
|
private void SaveToolStripMenuItem_Click(object sender, EventArgs e) {
|
||||||
@@ -891,6 +912,16 @@ namespace McBitFont {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void FillFrameLists() {
|
||||||
|
foreach (FrameMiniature f in frames) {
|
||||||
|
var s = f.code.ToString().PadLeft(3, '0');
|
||||||
|
var sHex = 'x' + Convert.ToString(f.code, 16).PadLeft(2, '0').ToUpper();
|
||||||
|
var sss = DecodeSymbol(f.code);
|
||||||
|
ilMiniatures.Images.Add(s, (Image)GetMiniPictue(f));
|
||||||
|
miniList.Items.Add(s, (chkHexCodes.Checked ? sHex : s) + ' ' + sss, s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void LoadProject(string filename) {
|
private void LoadProject(string filename) {
|
||||||
SaveBlock sav;
|
SaveBlock sav;
|
||||||
|
|
||||||
@@ -908,13 +939,7 @@ namespace McBitFont {
|
|||||||
tsmiMakeVarWidth.Visible = monospaced;
|
tsmiMakeVarWidth.Visible = monospaced;
|
||||||
miniList.Items.Clear();
|
miniList.Items.Clear();
|
||||||
ilMiniatures.Images.Clear();
|
ilMiniatures.Images.Clear();
|
||||||
foreach (FrameMiniature ff in frames) {
|
FillFrameLists();
|
||||||
var s = ff.code.ToString().PadLeft(3, '0');
|
|
||||||
var sHex = 'x' + Convert.ToString(ff.code, 16).PadLeft(2, '0').ToUpper();
|
|
||||||
var sss = DecodeSymbol(ff.code);
|
|
||||||
ilMiniatures.Images.Add(s, (Image)GetMiniPictue(ff));
|
|
||||||
miniList.Items.Add(s, (chkHexCodes.Checked ? sHex : s) + ' ' + sss, s);
|
|
||||||
}
|
|
||||||
nudX.ValueChanged -= nudX_ValueChanged;
|
nudX.ValueChanged -= nudX_ValueChanged;
|
||||||
nudY.ValueChanged -= nudY_ValueChanged;
|
nudY.ValueChanged -= nudY_ValueChanged;
|
||||||
nudX.Value = frames.First().width;
|
nudX.Value = frames.First().width;
|
||||||
@@ -932,16 +957,17 @@ namespace McBitFont {
|
|||||||
|
|
||||||
prjFileName = filename;
|
prjFileName = filename;
|
||||||
prjName = Path.GetFileNameWithoutExtension(filename);
|
prjName = Path.GetFileNameWithoutExtension(filename);
|
||||||
|
dlgSavePNG.FileName = prjName + ".png";
|
||||||
|
dlgSave.FileName = prjName + ".mbfont";
|
||||||
SetWindowCap();
|
SetWindowCap();
|
||||||
|
|
||||||
miniList.Items[0].Selected = true;
|
miniList.Items[0].Selected = true;
|
||||||
|
|
||||||
CheckForAdd();
|
CheckForAdd();
|
||||||
fbuffer = false;
|
|
||||||
//copyToolStripMenuItem.Enabled = true;
|
|
||||||
|
|
||||||
// Re-create history object
|
// Re-create history object
|
||||||
history = new CanvasHistory();
|
//history = new CanvasHistory();
|
||||||
|
history.Clear();
|
||||||
|
|
||||||
tsmiMakeVarWidth.Visible = monospaced;
|
tsmiMakeVarWidth.Visible = monospaced;
|
||||||
makeVarWidthToolStripMenuItem.Visible = monospaced;
|
makeVarWidthToolStripMenuItem.Visible = monospaced;
|
||||||
@@ -961,7 +987,7 @@ namespace McBitFont {
|
|||||||
MessagePackSerializer.Serialize(ms, sav);
|
MessagePackSerializer.Serialize(ms, sav);
|
||||||
ms.Close();
|
ms.Close();
|
||||||
}
|
}
|
||||||
|
|
||||||
prjName = Path.GetFileNameWithoutExtension(filename);
|
prjName = Path.GetFileNameWithoutExtension(filename);
|
||||||
prjFileName = filename;
|
prjFileName = filename;
|
||||||
SetModified(false, true);
|
SetModified(false, true);
|
||||||
@@ -1031,45 +1057,53 @@ namespace McBitFont {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
prependSymbolToolStripMenuItem.Enabled = false;
|
prependSymbolToolStripMenuItem.Enabled = false;
|
||||||
appendSymbolToolStripMenuItem.Enabled = false;
|
appendSymbolToolStripMenuItem.Enabled = true;
|
||||||
tsmiPrepensSymbol.Enabled = false;
|
tsmiPrepensSymbol.Enabled = false;
|
||||||
tsmiAppendSymbol.Enabled = false;
|
tsmiAppendSymbol.Enabled = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void copyToolStripMenuItem_Click(object sender, EventArgs e) {
|
private void copyToolStripMenuItem_Click(object sender, EventArgs e) {
|
||||||
fbuffer = true;
|
var bb = MessagePackSerializer.Serialize(CopyFrame(f, true));
|
||||||
fbuf = CopyFrame(f, true);
|
DataObject clpbObj = new DataObject(clpbFormat.Name, bb);
|
||||||
pasteToolStripMenuItem.Enabled = true;
|
Clipboard.SetDataObject(clpbObj, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void pasteToolStripMenuItem_Click(object sender, EventArgs e) {
|
private void pasteToolStripMenuItem_Click(object sender, EventArgs e) {
|
||||||
history.AddPre(f);
|
// Try to read from clipboard
|
||||||
if (fbuf.width == f.width && fbuf.height == f.height) {
|
try {
|
||||||
Array.Copy(fbuf.data, f.data, fbuf.data.Length);
|
IDataObject clpbObj = Clipboard.GetDataObject();
|
||||||
} else {
|
byte[] bb = (byte[])clpbObj.GetData(clpbFormat.Name);
|
||||||
int di, dj, wmax, hmax, selw, selh;
|
fbuf = MessagePackSerializer.Deserialize<FrameMiniature>(bb);
|
||||||
if (chkRectSelect.Checked) {
|
}
|
||||||
di = selection1.X;
|
catch {
|
||||||
dj = selection1.Y;
|
return;
|
||||||
selw = selection2.X - selection1.X + 1;
|
}
|
||||||
selh = selection2.Y - selection1.Y + 1;
|
|
||||||
wmax = fbuf.width > selw ? selw : fbuf.width;
|
|
||||||
hmax = fbuf.height > selh ? selh : fbuf.height;
|
|
||||||
} else {
|
|
||||||
di = 0;
|
|
||||||
dj = 0;
|
|
||||||
wmax = (fbuf.width > f.width) ? f.width : fbuf.width;
|
|
||||||
hmax = (fbuf.height > f.height) ? f.height : fbuf.height;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (int i = 0; i < wmax; i++) {
|
//history.AddPre(f);
|
||||||
for (int j = 0; j < hmax; j++) {
|
int di, dj, wmax, hmax, selw, selh;
|
||||||
f.data[i + di, j + dj] = fbuf.data[i, j];
|
if (chkRectSelect.Checked) {
|
||||||
}
|
di = selection1.X;
|
||||||
|
dj = selection1.Y;
|
||||||
|
selw = selection2.X - selection1.X + 1;
|
||||||
|
selh = selection2.Y - selection1.Y + 1;
|
||||||
|
wmax = fbuf.width > selw ? selw : fbuf.width;
|
||||||
|
hmax = fbuf.height > selh ? selh : fbuf.height;
|
||||||
|
} else {
|
||||||
|
di = 0;
|
||||||
|
dj = 0;
|
||||||
|
wmax = (fbuf.width > f.width) ? f.width : fbuf.width;
|
||||||
|
hmax = (fbuf.height > f.height) ? f.height : fbuf.height;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < wmax; i++) {
|
||||||
|
for (int j = 0; j < hmax; j++) {
|
||||||
|
f.data[i + di, j + dj] = fbuf.data[i, j];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
history.AddPost(f);
|
|
||||||
|
//history.AddPost(f);
|
||||||
|
history.Add(f);
|
||||||
CheckHistoryButtons();
|
CheckHistoryButtons();
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
SetModified();
|
SetModified();
|
||||||
@@ -1118,7 +1152,7 @@ namespace McBitFont {
|
|||||||
private void FillFrame(bool val) {
|
private void FillFrame(bool val) {
|
||||||
int x, y, x2, y2;
|
int x, y, x2, y2;
|
||||||
|
|
||||||
history.AddPre(f);
|
//history.AddPre(f);
|
||||||
|
|
||||||
(x, y, x2, y2) = RectSelCoords();
|
(x, y, x2, y2) = RectSelCoords();
|
||||||
|
|
||||||
@@ -1128,7 +1162,8 @@ namespace McBitFont {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
history.AddPost(f);
|
//history.AddPost(f);
|
||||||
|
history.Add(f);
|
||||||
CheckHistoryButtons();
|
CheckHistoryButtons();
|
||||||
SetModified();
|
SetModified();
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
@@ -1209,13 +1244,15 @@ namespace McBitFont {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void undoToolStripMenuItem_Click(object sender, EventArgs e) {
|
private void undoToolStripMenuItem_Click(object sender, EventArgs e) {
|
||||||
history.Undo(f);
|
//history.Undo(f);
|
||||||
|
history.Undo();
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
CheckHistoryButtons();
|
CheckHistoryButtons();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void redoToolStripMenuItem_Click(object sender, EventArgs e) {
|
private void redoToolStripMenuItem_Click(object sender, EventArgs e) {
|
||||||
history.Redo(f);
|
//history.Redo(f);
|
||||||
|
history.Redo();
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
CheckHistoryButtons();
|
CheckHistoryButtons();
|
||||||
}
|
}
|
||||||
@@ -1266,13 +1303,14 @@ namespace McBitFont {
|
|||||||
private void importImageToolStripMenuItem_Click(object sender, EventArgs e) {
|
private void importImageToolStripMenuItem_Click(object sender, EventArgs e) {
|
||||||
ImageImporter iform = new ImageImporter(f.width, f.height);
|
ImageImporter iform = new ImageImporter(f.width, f.height);
|
||||||
if (iform.ShowDialog() == DialogResult.OK) {
|
if (iform.ShowDialog() == DialogResult.OK) {
|
||||||
history.AddPre(f);
|
//history.AddPre(f);
|
||||||
for (int i = 0; i < iform.bmpScaled.Width; i++) {
|
for (int i = 0; i < iform.bmpScaled.Width; i++) {
|
||||||
for (int j = 0; j < iform.bmpScaled.Height; j++) {
|
for (int j = 0; j < iform.bmpScaled.Height; j++) {
|
||||||
f.data[i, j] = iform.bmpScaled.GetPixel(i, j).ToArgb().Equals(Color.Black.ToArgb());
|
f.data[i, j] = iform.bmpScaled.GetPixel(i, j).ToArgb().Equals(Color.Black.ToArgb());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
history.AddPost(f);
|
//history.AddPost(f);
|
||||||
|
history.Add(f);
|
||||||
CheckHistoryButtons();
|
CheckHistoryButtons();
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
SetModified();
|
SetModified();
|
||||||
@@ -1424,5 +1462,105 @@ namespace McBitFont {
|
|||||||
selection2.Y = dotHeight - 1;
|
selection2.Y = dotHeight - 1;
|
||||||
dotPanel.Refresh();
|
dotPanel.Refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void TestFont_Click(object sender, EventArgs e) {
|
||||||
|
var tester = new FontTester(codepage, dotHeight, baseline, frames);
|
||||||
|
tester.ShowDialog();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ExportPNG(object sender, EventArgs e) {
|
||||||
|
CheckModifiedFrame();
|
||||||
|
CheckModifiedProject();
|
||||||
|
|
||||||
|
if (dlgSavePNG.ShowDialog() == DialogResult.OK) {
|
||||||
|
int pixelSize = 3;
|
||||||
|
int symbolMargin = 2 * pixelSize;
|
||||||
|
int headerHeight = 100;
|
||||||
|
int maxWidth = 0;
|
||||||
|
int i, j, v, h, x, y;
|
||||||
|
string s;
|
||||||
|
|
||||||
|
foreach (FrameMiniature f in frames) {
|
||||||
|
if (f.width > maxWidth) maxWidth = f.width;
|
||||||
|
}
|
||||||
|
|
||||||
|
int cellWidth = (pixelSize * maxWidth + 2 * symbolMargin);
|
||||||
|
int cellHeight = (pixelSize * dotHeight + 2 * symbolMargin);
|
||||||
|
if (cellWidth < 10) cellWidth = 10;
|
||||||
|
if (cellHeight < 10) cellHeight = 10;
|
||||||
|
|
||||||
|
int width = cellWidth * 16 + 17 + 50;
|
||||||
|
int height = cellHeight * 16 + 17 + 25 + headerHeight;
|
||||||
|
|
||||||
|
Bitmap bmp = new(width > 450 ? width : 450, height);
|
||||||
|
Graphics g = Graphics.FromImage(bmp);
|
||||||
|
g.TextRenderingHint = System.Drawing.Text.TextRenderingHint.AntiAliasGridFit;
|
||||||
|
Font font = new("Consolas", 14, FontStyle.Bold);
|
||||||
|
Brush tb = Brushes.Black;
|
||||||
|
|
||||||
|
|
||||||
|
// Draw basic information
|
||||||
|
g.DrawString("Font project name: " + prjName, font, tb, 10, 10);
|
||||||
|
|
||||||
|
g.DrawString("Font height: " + dotHeight, font, tb, 10, 38);
|
||||||
|
g.DrawString("Font max width: " + maxWidth, font, tb, 10, 62);
|
||||||
|
g.DrawString("Symbols count: " + frames.Count, font, tb, 10, 86);
|
||||||
|
|
||||||
|
g.DrawString("First code: " + frames.First().code.ToString(), font, tb, 250, 38);
|
||||||
|
g.DrawString("Last code: " + frames.Last().code.ToString(), font, tb, 250, 62);
|
||||||
|
g.DrawString("Codepage: " + codepage.ToString(), font, tb, 250, 86);
|
||||||
|
|
||||||
|
|
||||||
|
// Draw grid
|
||||||
|
Pen p = new(Color.FromArgb(64, 0, 0, 0), 1);
|
||||||
|
SolidBrush b = new SolidBrush(Color.FromArgb(160, Color.Black));
|
||||||
|
//Brush b = Brushes.Black;
|
||||||
|
|
||||||
|
int xCapOffset = cellWidth / 2 - 8;
|
||||||
|
int yCapOffset = cellHeight / 2 - 10;
|
||||||
|
for (i = 0; i < 17; i++) {
|
||||||
|
x = 50 + 17 + i * cellWidth - 1;
|
||||||
|
y = headerHeight + 17 + 25 + i * cellHeight - 1;
|
||||||
|
g.DrawLine(p, 1, y, width - 1, y);
|
||||||
|
g.DrawLine(p, x, headerHeight + 20, x, headerHeight + height - 20);
|
||||||
|
|
||||||
|
if (i != 16) {
|
||||||
|
s = Convert.ToString(i, 16).ToUpper();
|
||||||
|
g.DrawString(s, font, b, x + xCapOffset, headerHeight + 20);
|
||||||
|
s = "0x" + Convert.ToString(i * 16, 16).PadLeft(2, '0').ToUpper();
|
||||||
|
g.DrawString(s, font, b, 10, y + yCapOffset);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Draw symbols
|
||||||
|
int code;
|
||||||
|
List<FrameMiniature> ff;
|
||||||
|
Rectangle rect;
|
||||||
|
// Cycle through grid cells
|
||||||
|
for (v = 0; v < 16; v++) {
|
||||||
|
for (h = 0; h < 16; h++) {
|
||||||
|
// Check if the font has a symbol with the code
|
||||||
|
code = 16 * v + h;
|
||||||
|
ff = frames.FindAll(x => x.code == code);
|
||||||
|
if (ff.Count == 1) {
|
||||||
|
x = 50 + 17 + h * cellWidth + symbolMargin;
|
||||||
|
y = headerHeight + 17 + 25 + v * cellHeight + symbolMargin;
|
||||||
|
// Cycly through symbol's pixels and draw the black ones
|
||||||
|
for (i = 0; i < ff[0].width; i++) {
|
||||||
|
for (j = 0; j < ff[0].height; j++) {
|
||||||
|
if (ff[0].data[i, j]) {
|
||||||
|
rect = new Rectangle(x + i * pixelSize, y + j * pixelSize, pixelSize, pixelSize);
|
||||||
|
g.FillRectangle(tb, rect);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bmp.Save(dlgSavePNG.FileName, ImageFormat.Png);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -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>
|
||||||
|
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,9 +20,9 @@
|
|||||||
<UseWindowsForms>true</UseWindowsForms>
|
<UseWindowsForms>true</UseWindowsForms>
|
||||||
<ImportWindowsDesktopTargets>true</ImportWindowsDesktopTargets>
|
<ImportWindowsDesktopTargets>true</ImportWindowsDesktopTargets>
|
||||||
<ApplicationIcon>icon_64.ico</ApplicationIcon>
|
<ApplicationIcon>icon_64.ico</ApplicationIcon>
|
||||||
<AssemblyVersion>2.2.0.0</AssemblyVersion>
|
<AssemblyVersion>2.4.0.0</AssemblyVersion>
|
||||||
<FileVersion>2.2.0.0</FileVersion>
|
<FileVersion>2.4.0.0</FileVersion>
|
||||||
<Version>$(VersionPrefix)2.2.0</Version>
|
<Version>$(VersionPrefix)2.4.0</Version>
|
||||||
<Copyright>Anton Mukhin</Copyright>
|
<Copyright>Anton Mukhin</Copyright>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'">
|
||||||
|
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();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -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.
|
||||||
-->
|
-->
|
||||||
|
20
McBitFont/Properties/Resources.Designer.cs
generated
@@ -270,6 +270,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>
|
||||||
@@ -300,6 +310,16 @@ 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>
|
/// <summary>
|
||||||
/// Looks up a localized resource of type System.Drawing.Bitmap.
|
/// Looks up a localized resource of type System.Drawing.Bitmap.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@@ -136,6 +136,9 @@
|
|||||||
<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="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_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>
|
||||||
@@ -223,10 +226,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="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>
|
|
||||||
</data>
|
|
||||||
<data name="arrow_out" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
<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>
|
<value>..\Resources\arrow_out.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value>
|
||||||
</data>
|
</data>
|
||||||
|
<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>
|
||||||
|
</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>
|
||||||
</root>
|
</root>
|
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 |
11
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+
|
||||||
@@ -37,6 +40,10 @@ New project dialog
|
|||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
Font test dialog
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
Export dialog
|
Export dialog
|
||||||
|
|
||||||

|

|
||||||
@@ -48,3 +55,7 @@ Import Image dialog
|
|||||||
Code Shift dialog
|
Code Shift dialog
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
Font PNG export example
|
||||||
|
|
||||||
|

|
||||||
|
16
TODO.txt
@@ -1,15 +1,11 @@
|
|||||||
Application:
|
Application:
|
||||||
V Move Select and Baseline buttons right
|
- Consider migrating to WPF in order to make DPI aware UI
|
||||||
V Display RectSelection width and width
|
V Copy-Paste now uses System clipboard and it is possible to copy-paste from/to different instances of running program
|
||||||
V Indicate modified project by adding "*" to window caption
|
|
||||||
|
|
||||||
Functionality:
|
Functionality:
|
||||||
V Copy/Paste should be aware of rectangle selection
|
V Rewrite history class so it tracks all changes, not only a canvas changes
|
||||||
V Select All function
|
|
||||||
V Select and Select All shortcuts
|
|
||||||
|
|
||||||
Bugs:
|
Bugs:
|
||||||
V EncodingProvider hotfix
|
V In some cases after switching to a symbol dotPanel mouse move causes "Out of range" exception (history.Pre after width change?)
|
||||||
V Check if frame changed before exit application
|
V Switching between symbols while select tool is active and small area selected trows an error
|
||||||
V Hostory does not record pastes from clipboard
|
V Full frame Copy in Clipboard does not respect selection on Paste operation
|
||||||
V Undo/Redo menu availability recalculation does not happen sometimes
|
|
BIN
examples/Font_3x3_mono_Latin.mbfont
Normal file
BIN
examples/Font_3x5_Latin.mbfont
Normal file
BIN
examples/Font_4x6_vw.mbfont
Normal file
BIN
examples/Font_9x17_Alagard_cyr_vw.mbfont
Normal file
BIN
examples/Font_Minecraft_Rus_5x7_vw.mbfont
Normal file
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
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: 11 KiB |
Before Width: | Height: | Size: 49 KiB After Width: | Height: | Size: 53 KiB |