Compare commits
	
		
			7 Commits
		
	
	
		
			30142fda26
			...
			7aa75224ee
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 7aa75224ee | |||
| 4fe2af03b0 | |||
|  | fc4822065a | ||
|  | 3778a753fb | ||
|  | 20bd7095dd | ||
| 8ed1e33f22 | |||
|  | 1eb463c94f | 
							
								
								
									
										46
									
								
								McBitFont/Form1.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										46
									
								
								McBitFont/Form1.Designer.cs
									
									
									
										generated
									
									
									
								
							| @@ -214,7 +214,7 @@ | |||||||
|             cbZoom.Size = new System.Drawing.Size(75, 23); |             cbZoom.Size = new System.Drawing.Size(75, 23); | ||||||
|             cbZoom.TabIndex = 6; |             cbZoom.TabIndex = 6; | ||||||
|             cbZoom.TabStop = false; |             cbZoom.TabStop = false; | ||||||
|             toolTip1.SetToolTip(cbZoom, "Canvas zoom level"); |             toolTip1.SetToolTip(cbZoom, "Canvas zoom level (Ctrl+Scroll)"); | ||||||
|             //  |             //  | ||||||
|             // label4 |             // label4 | ||||||
|             //  |             //  | ||||||
| @@ -249,38 +249,38 @@ | |||||||
|             // btnFill |             // btnFill | ||||||
|             //  |             //  | ||||||
|             btnFill.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnFill.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|  |             btnFill.Image = Properties.Resources.Canvas_Fill; | ||||||
|             btnFill.Location = new System.Drawing.Point(92, 9); |             btnFill.Location = new System.Drawing.Point(92, 9); | ||||||
|             btnFill.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnFill.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnFill.Name = "btnFill"; |             btnFill.Name = "btnFill"; | ||||||
|             btnFill.Size = new System.Drawing.Size(35, 35); |             btnFill.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnFill.TabIndex = 8; |             btnFill.TabIndex = 8; | ||||||
|             btnFill.Text = "⬤"; |             toolTip1.SetToolTip(btnFill, "Paint canvas black (Ctrl+B)"); | ||||||
|             toolTip1.SetToolTip(btnFill, "Paint canvas black"); |  | ||||||
|             btnFill.UseVisualStyleBackColor = true; |             btnFill.UseVisualStyleBackColor = true; | ||||||
|             btnFill.Click += btnFill_Click; |             btnFill.Click += btnFill_Click; | ||||||
|             //  |             //  | ||||||
|             // btnClear |             // btnClear | ||||||
|             //  |             //  | ||||||
|             btnClear.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnClear.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|  |             btnClear.Image = Properties.Resources.Canvas_Clear; | ||||||
|             btnClear.Location = new System.Drawing.Point(8, 9); |             btnClear.Location = new System.Drawing.Point(8, 9); | ||||||
|             btnClear.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnClear.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnClear.Name = "btnClear"; |             btnClear.Name = "btnClear"; | ||||||
|             btnClear.Size = new System.Drawing.Size(35, 35); |             btnClear.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnClear.TabIndex = 7; |             btnClear.TabIndex = 7; | ||||||
|             btnClear.Text = "○"; |             toolTip1.SetToolTip(btnClear, "Paint canvas white (Ctrl+W)"); | ||||||
|             toolTip1.SetToolTip(btnClear, "Paint canvas white"); |  | ||||||
|             btnClear.UseVisualStyleBackColor = true; |             btnClear.UseVisualStyleBackColor = true; | ||||||
|             btnClear.Click += btnClear_Click; |             btnClear.Click += btnClear_Click; | ||||||
|             //  |             //  | ||||||
|             // btnMirrorY |             // btnMirrorY | ||||||
|             //  |             //  | ||||||
|             btnMirrorY.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnMirrorY.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|  |             btnMirrorY.Image = Properties.Resources.Famfamfam_Silk_Shape_flip_vertical_16; | ||||||
|             btnMirrorY.Location = new System.Drawing.Point(92, 92); |             btnMirrorY.Location = new System.Drawing.Point(92, 92); | ||||||
|             btnMirrorY.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnMirrorY.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnMirrorY.Name = "btnMirrorY"; |             btnMirrorY.Name = "btnMirrorY"; | ||||||
|             btnMirrorY.Size = new System.Drawing.Size(35, 35); |             btnMirrorY.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnMirrorY.TabIndex = 6; |             btnMirrorY.TabIndex = 6; | ||||||
|             btnMirrorY.Text = "⩥"; |  | ||||||
|             toolTip1.SetToolTip(btnMirrorY, "Mirror by Y axis (vertical)"); |             toolTip1.SetToolTip(btnMirrorY, "Mirror by Y axis (vertical)"); | ||||||
|             btnMirrorY.UseVisualStyleBackColor = true; |             btnMirrorY.UseVisualStyleBackColor = true; | ||||||
|             btnMirrorY.Click += btnMirrorY_Click; |             btnMirrorY.Click += btnMirrorY_Click; | ||||||
| @@ -288,12 +288,12 @@ | |||||||
|             // btnMirrorX |             // btnMirrorX | ||||||
|             //  |             //  | ||||||
|             btnMirrorX.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnMirrorX.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|  |             btnMirrorX.Image = Properties.Resources.Famfamfam_Silk_Shape_flip_horizontal_16; | ||||||
|             btnMirrorX.Location = new System.Drawing.Point(50, 92); |             btnMirrorX.Location = new System.Drawing.Point(50, 92); | ||||||
|             btnMirrorX.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnMirrorX.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnMirrorX.Name = "btnMirrorX"; |             btnMirrorX.Name = "btnMirrorX"; | ||||||
|             btnMirrorX.Size = new System.Drawing.Size(35, 35); |             btnMirrorX.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnMirrorX.TabIndex = 5; |             btnMirrorX.TabIndex = 5; | ||||||
|             btnMirrorX.Text = "◮"; |  | ||||||
|             toolTip1.SetToolTip(btnMirrorX, "Mirror by X axis (horizontal)"); |             toolTip1.SetToolTip(btnMirrorX, "Mirror by X axis (horizontal)"); | ||||||
|             btnMirrorX.UseVisualStyleBackColor = true; |             btnMirrorX.UseVisualStyleBackColor = true; | ||||||
|             btnMirrorX.Click += btnMirrorX_Click; |             btnMirrorX.Click += btnMirrorX_Click; | ||||||
| @@ -301,65 +301,65 @@ | |||||||
|             // btnInvert |             // btnInvert | ||||||
|             //  |             //  | ||||||
|             btnInvert.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnInvert.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|  |             btnInvert.Image = Properties.Resources.z_contrast; | ||||||
|             btnInvert.Location = new System.Drawing.Point(8, 92); |             btnInvert.Location = new System.Drawing.Point(8, 92); | ||||||
|             btnInvert.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnInvert.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnInvert.Name = "btnInvert"; |             btnInvert.Name = "btnInvert"; | ||||||
|             btnInvert.Size = new System.Drawing.Size(35, 35); |             btnInvert.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnInvert.TabIndex = 4; |             btnInvert.TabIndex = 4; | ||||||
|             btnInvert.Text = "◪"; |             toolTip1.SetToolTip(btnInvert, "Invert pixel colors (Ctrl+I)"); | ||||||
|             toolTip1.SetToolTip(btnInvert, "Invert pixel colors"); |  | ||||||
|             btnInvert.UseVisualStyleBackColor = true; |             btnInvert.UseVisualStyleBackColor = true; | ||||||
|             btnInvert.Click += btnInvert_Click; |             btnInvert.Click += btnInvert_Click; | ||||||
|             //  |             //  | ||||||
|             // btnShiftDown |             // btnShiftDown | ||||||
|             //  |             //  | ||||||
|             btnShiftDown.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnShiftDown.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|  |             btnShiftDown.Image = Properties.Resources.z_down; | ||||||
|             btnShiftDown.Location = new System.Drawing.Point(50, 51); |             btnShiftDown.Location = new System.Drawing.Point(50, 51); | ||||||
|             btnShiftDown.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnShiftDown.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnShiftDown.Name = "btnShiftDown"; |             btnShiftDown.Name = "btnShiftDown"; | ||||||
|             btnShiftDown.Size = new System.Drawing.Size(35, 35); |             btnShiftDown.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnShiftDown.TabIndex = 3; |             btnShiftDown.TabIndex = 3; | ||||||
|             btnShiftDown.Text = "▼"; |             toolTip1.SetToolTip(btnShiftDown, "Shift pixels down (Ctrl+Down)"); | ||||||
|             toolTip1.SetToolTip(btnShiftDown, "Shift pixels down"); |  | ||||||
|             btnShiftDown.UseVisualStyleBackColor = true; |             btnShiftDown.UseVisualStyleBackColor = true; | ||||||
|             btnShiftDown.Click += btnShiftDown_Click; |             btnShiftDown.Click += btnShiftDown_Click; | ||||||
|             //  |             //  | ||||||
|             // btnShiftUp |             // btnShiftUp | ||||||
|             //  |             //  | ||||||
|             btnShiftUp.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnShiftUp.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|  |             btnShiftUp.Image = Properties.Resources.z_uo; | ||||||
|             btnShiftUp.Location = new System.Drawing.Point(50, 9); |             btnShiftUp.Location = new System.Drawing.Point(50, 9); | ||||||
|             btnShiftUp.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnShiftUp.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnShiftUp.Name = "btnShiftUp"; |             btnShiftUp.Name = "btnShiftUp"; | ||||||
|             btnShiftUp.Size = new System.Drawing.Size(35, 35); |             btnShiftUp.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnShiftUp.TabIndex = 2; |             btnShiftUp.TabIndex = 2; | ||||||
|             btnShiftUp.Text = "▲"; |             toolTip1.SetToolTip(btnShiftUp, "Shift pixels up (Ctrl+Up)"); | ||||||
|             toolTip1.SetToolTip(btnShiftUp, "Shift pixels up"); |  | ||||||
|             btnShiftUp.UseVisualStyleBackColor = true; |             btnShiftUp.UseVisualStyleBackColor = true; | ||||||
|             btnShiftUp.Click += btnShiftUp_Click; |             btnShiftUp.Click += btnShiftUp_Click; | ||||||
|             //  |             //  | ||||||
|             // btnShiftRight |             // btnShiftRight | ||||||
|             //  |             //  | ||||||
|             btnShiftRight.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnShiftRight.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|  |             btnShiftRight.Image = Properties.Resources.z_right; | ||||||
|             btnShiftRight.Location = new System.Drawing.Point(92, 51); |             btnShiftRight.Location = new System.Drawing.Point(92, 51); | ||||||
|             btnShiftRight.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnShiftRight.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnShiftRight.Name = "btnShiftRight"; |             btnShiftRight.Name = "btnShiftRight"; | ||||||
|             btnShiftRight.Size = new System.Drawing.Size(35, 35); |             btnShiftRight.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnShiftRight.TabIndex = 1; |             btnShiftRight.TabIndex = 1; | ||||||
|             btnShiftRight.Text = "▶"; |             toolTip1.SetToolTip(btnShiftRight, "Shift pixels right (Ctrl+Right)"); | ||||||
|             toolTip1.SetToolTip(btnShiftRight, "Shift pixels right"); |  | ||||||
|             btnShiftRight.UseVisualStyleBackColor = true; |             btnShiftRight.UseVisualStyleBackColor = true; | ||||||
|             btnShiftRight.Click += btnShiftRight_Click; |             btnShiftRight.Click += btnShiftRight_Click; | ||||||
|             //  |             //  | ||||||
|             // btnShiftLeft |             // btnShiftLeft | ||||||
|             //  |             //  | ||||||
|             btnShiftLeft.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); |             btnShiftLeft.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, 204); | ||||||
|  |             btnShiftLeft.Image = Properties.Resources.z_left; | ||||||
|             btnShiftLeft.Location = new System.Drawing.Point(8, 51); |             btnShiftLeft.Location = new System.Drawing.Point(8, 51); | ||||||
|             btnShiftLeft.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); |             btnShiftLeft.Margin = new System.Windows.Forms.Padding(4, 3, 4, 3); | ||||||
|             btnShiftLeft.Name = "btnShiftLeft"; |             btnShiftLeft.Name = "btnShiftLeft"; | ||||||
|             btnShiftLeft.Size = new System.Drawing.Size(35, 35); |             btnShiftLeft.Size = new System.Drawing.Size(35, 35); | ||||||
|             btnShiftLeft.TabIndex = 0; |             btnShiftLeft.TabIndex = 0; | ||||||
|             btnShiftLeft.Text = "◀"; |             toolTip1.SetToolTip(btnShiftLeft, "Shift pixels left (Ctrl+Left)"); | ||||||
|             toolTip1.SetToolTip(btnShiftLeft, "Shift pixels left"); |  | ||||||
|             btnShiftLeft.UseVisualStyleBackColor = true; |             btnShiftLeft.UseVisualStyleBackColor = true; | ||||||
|             btnShiftLeft.Click += btnShiftLeft_Click; |             btnShiftLeft.Click += btnShiftLeft_Click; | ||||||
|             //  |             //  | ||||||
| @@ -374,7 +374,7 @@ | |||||||
|             btnExport.Text = " Export"; |             btnExport.Text = " Export"; | ||||||
|             btnExport.TextAlign = System.Drawing.ContentAlignment.MiddleRight; |             btnExport.TextAlign = System.Drawing.ContentAlignment.MiddleRight; | ||||||
|             btnExport.TextImageRelation = System.Windows.Forms.TextImageRelation.ImageBeforeText; |             btnExport.TextImageRelation = System.Windows.Forms.TextImageRelation.ImageBeforeText; | ||||||
|             toolTip1.SetToolTip(btnExport, "Configure and export data"); |             toolTip1.SetToolTip(btnExport, "Configure and export data (Ctrl+E)"); | ||||||
|             btnExport.UseVisualStyleBackColor = true; |             btnExport.UseVisualStyleBackColor = true; | ||||||
|             btnExport.Click += Export_Click; |             btnExport.Click += Export_Click; | ||||||
|             //  |             //  | ||||||
| @@ -491,7 +491,7 @@ | |||||||
|             btnApply.Text = " Apply"; |             btnApply.Text = " Apply"; | ||||||
|             btnApply.TextAlign = System.Drawing.ContentAlignment.MiddleRight; |             btnApply.TextAlign = System.Drawing.ContentAlignment.MiddleRight; | ||||||
|             btnApply.TextImageRelation = System.Windows.Forms.TextImageRelation.ImageBeforeText; |             btnApply.TextImageRelation = System.Windows.Forms.TextImageRelation.ImageBeforeText; | ||||||
|             toolTip1.SetToolTip(btnApply, "Apply changes made to the symbol"); |             toolTip1.SetToolTip(btnApply, "Apply changes made to the symbol (Ctrl+Space)"); | ||||||
|             btnApply.UseVisualStyleBackColor = true; |             btnApply.UseVisualStyleBackColor = true; | ||||||
|             btnApply.Click += button2_Click; |             btnApply.Click += button2_Click; | ||||||
|             //  |             //  | ||||||
| @@ -1065,7 +1065,7 @@ | |||||||
|             chkRectSelect.Text = " Select"; |             chkRectSelect.Text = " Select"; | ||||||
|             chkRectSelect.TextAlign = System.Drawing.ContentAlignment.MiddleCenter; |             chkRectSelect.TextAlign = System.Drawing.ContentAlignment.MiddleCenter; | ||||||
|             chkRectSelect.TextImageRelation = System.Windows.Forms.TextImageRelation.ImageBeforeText; |             chkRectSelect.TextImageRelation = System.Windows.Forms.TextImageRelation.ImageBeforeText; | ||||||
|             toolTip1.SetToolTip(chkRectSelect, "Turn on/off rectangle selection"); |             toolTip1.SetToolTip(chkRectSelect, "Turn on/off rectangle selection (Ctrl+R)"); | ||||||
|             chkRectSelect.UseVisualStyleBackColor = true; |             chkRectSelect.UseVisualStyleBackColor = true; | ||||||
|             chkRectSelect.CheckedChanged += chkRectSelect_CheckedChanged; |             chkRectSelect.CheckedChanged += chkRectSelect_CheckedChanged; | ||||||
|             //  |             //  | ||||||
| @@ -1078,7 +1078,7 @@ | |||||||
|             nudBrush.Name = "nudBrush"; |             nudBrush.Name = "nudBrush"; | ||||||
|             nudBrush.Size = new System.Drawing.Size(47, 23); |             nudBrush.Size = new System.Drawing.Size(47, 23); | ||||||
|             nudBrush.TabIndex = 24; |             nudBrush.TabIndex = 24; | ||||||
|             toolTip1.SetToolTip(nudBrush, "Symbol height"); |             toolTip1.SetToolTip(nudBrush, "Symbol height (Alt+Scroll)"); | ||||||
|             nudBrush.Value = new decimal(new int[] { 1, 0, 0, 0 }); |             nudBrush.Value = new decimal(new int[] { 1, 0, 0, 0 }); | ||||||
|             nudBrush.ValueChanged += nudBrush_ValueChanged; |             nudBrush.ValueChanged += nudBrush_ValueChanged; | ||||||
|             //  |             //  | ||||||
| @@ -1110,9 +1110,9 @@ | |||||||
|             lblSelection.Location = new System.Drawing.Point(5, 84); |             lblSelection.Location = new System.Drawing.Point(5, 84); | ||||||
|             lblSelection.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); |             lblSelection.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0); | ||||||
|             lblSelection.Name = "lblSelection"; |             lblSelection.Name = "lblSelection"; | ||||||
|             lblSelection.Size = new System.Drawing.Size(30, 15); |             lblSelection.Size = new System.Drawing.Size(32, 15); | ||||||
|             lblSelection.TabIndex = 24; |             lblSelection.TabIndex = 24; | ||||||
|             lblSelection.Text = "W,H"; |             lblSelection.Text = "WxH"; | ||||||
|             lblSelection.TextAlign = System.Drawing.ContentAlignment.TopRight; |             lblSelection.TextAlign = System.Drawing.ContentAlignment.TopRight; | ||||||
|             lblSelection.Visible = false; |             lblSelection.Visible = false; | ||||||
|             //  |             //  | ||||||
|   | |||||||
| @@ -59,7 +59,7 @@ namespace McBitFont { | |||||||
|         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.6"; |         public const string version = "2.7"; | ||||||
|         public string prjName = "Untitled"; |         public string prjName = "Untitled"; | ||||||
|         public string prjFileName = ""; |         public string prjFileName = ""; | ||||||
|         public int codepage = 1251; |         public int codepage = 1251; | ||||||
| @@ -83,7 +83,7 @@ namespace McBitFont { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         private void UpdateSelectionLabel(int width, int height) { |         private void UpdateSelectionLabel(int width, int height) { | ||||||
|             lblSelection.Text = width.ToString() + ',' + height.ToString(); |             lblSelection.Text = width.ToString() + 'x' + height.ToString(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         public void SetModified(bool modif = true, bool prj = false) { |         public void SetModified(bool modif = true, bool prj = false) { | ||||||
| @@ -346,7 +346,7 @@ namespace McBitFont { | |||||||
|                 vScroll.Enabled = true; |                 vScroll.Enabled = true; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             dotPanel.Cursor = McCursor.GetCursor((int)nudBrush.Value, cellSize, gap); |             if (!chkRectSelect.Checked) dotPanel.Cursor = McCursor.GetCursor((int)nudBrush.Value, cellSize, gap); | ||||||
|             dotPanel.Refresh(); |             dotPanel.Refresh(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -1394,6 +1394,10 @@ namespace McBitFont { | |||||||
|         private void chkRectSelect_CheckedChanged(object sender, EventArgs e) { |         private void chkRectSelect_CheckedChanged(object sender, EventArgs e) { | ||||||
|             lblSelection.Visible = lblSelectionLabel.Visible = chkRectSelect.Checked; |             lblSelection.Visible = lblSelectionLabel.Visible = chkRectSelect.Checked; | ||||||
|             selectAllToolStripMenuItem.Enabled = chkRectSelect.Checked; |             selectAllToolStripMenuItem.Enabled = chkRectSelect.Checked; | ||||||
|  |  | ||||||
|  |             if (chkRectSelect.Checked) dotPanel.Cursor = McCursor.GetCursorSelect(); | ||||||
|  |             else dotPanel.Cursor = McCursor.GetCursor((int)nudBrush.Value, cellSize, gap); | ||||||
|  |  | ||||||
|             dotPanel.Refresh(); |             dotPanel.Refresh(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -1688,7 +1692,7 @@ namespace McBitFont { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         private void nudBrush_ValueChanged(object sender, EventArgs e) { |         private void nudBrush_ValueChanged(object sender, EventArgs e) { | ||||||
|             dotPanel.Cursor = McCursor.GetCursor((int)nudBrush.Value, cellSize, gap); |             if (!chkRectSelect.Checked) dotPanel.Cursor = McCursor.GetCursor((int)nudBrush.Value, cellSize, gap); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -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.6.0.0</AssemblyVersion> |     <AssemblyVersion>2.7.0.0</AssemblyVersion> | ||||||
|     <FileVersion>2.6.0.0</FileVersion> |     <FileVersion>2.7.0.0</FileVersion> | ||||||
|     <Version>$(VersionPrefix)2.6.0</Version> |     <Version>$(VersionPrefix)2.7.0</Version> | ||||||
|     <Copyright>Anton Mukhin</Copyright> |     <Copyright>Anton Mukhin</Copyright> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'"> |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'"> | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ using System.Drawing; | |||||||
| using System.Drawing.Drawing2D; | using System.Drawing.Drawing2D; | ||||||
| using System.Drawing.Imaging; | using System.Drawing.Imaging; | ||||||
| using System.Linq; | using System.Linq; | ||||||
|  | using System.Runtime.CompilerServices; | ||||||
| using System.Runtime.InteropServices; | using System.Runtime.InteropServices; | ||||||
| using System.Text; | using System.Text; | ||||||
| using System.Threading.Tasks; | using System.Threading.Tasks; | ||||||
| @@ -101,5 +102,30 @@ namespace McBitFont { | |||||||
|             return CreateCursorNoResize(bmp, cellSize / 2, cellSize / 2); |             return CreateCursorNoResize(bmp, cellSize / 2, cellSize / 2); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         public static Cursor GetCursorSelect() { | ||||||
|  |             Point[] arrow   = { new(1, 1), new(12, 12), new(11, 13), new(6, 13), new(2, 17), new(1, 16) }; | ||||||
|  |             Point[] corner1 = { new(13, 6), new(20, 6), new(20, 13), new(17, 13), new(17, 9), new(13, 9) }; | ||||||
|  |             Point[] corner2 = { new(17, 16), new(20, 16), new(20, 23), new(13, 23), new(13, 20), new(17, 20) }; | ||||||
|  |             Point[] corner3 = { new(3, 16), new(6, 16), new(6, 20), new(10, 20), new(10, 23), new(3, 23) }; | ||||||
|  |             Point[] corner4 = { new(6, 6), new(10, 6), new(10, 9), new(6, 9) }; | ||||||
|  |  | ||||||
|  |             Bitmap bmp = new(21, 24); | ||||||
|  |             Pen pb  = new(Color.Black, 1); | ||||||
|  |             SolidBrush bw = new (Color.White); | ||||||
|  |             using (Graphics g = Graphics.FromImage(bmp)) { | ||||||
|  |                 g.FillPolygon(bw, corner1); | ||||||
|  |                 g.DrawPolygon(pb, corner1); | ||||||
|  |                 g.FillPolygon(bw, corner2); | ||||||
|  |                 g.DrawPolygon(pb, corner2); | ||||||
|  |                 g.FillPolygon(bw, corner3); | ||||||
|  |                 g.DrawPolygon(pb, corner3); | ||||||
|  |                 g.FillPolygon(bw, corner4); | ||||||
|  |                 g.DrawPolygon(pb, corner4); | ||||||
|  |                 g.FillPolygon(bw, arrow); | ||||||
|  |                 g.DrawPolygon(pb, arrow); | ||||||
|  |             } | ||||||
|  |             return CreateCursorNoResize(bmp, 1, 1); | ||||||
|  |         } | ||||||
|  |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -29,6 +29,8 @@ Some basic hints on the interface: | |||||||
|  |  | ||||||
| Download in the [Releases](https://gitea.mcflyer.ru/McFLY/McBitFont/releases) section! | Download in the [Releases](https://gitea.mcflyer.ru/McFLY/McBitFont/releases) section! | ||||||
|  |  | ||||||
|  | Library example instructions to implement to STM32 code: [mctext](STM32_HAL_Lib/README.md) | ||||||
|  |  | ||||||
| #### Important: | #### Important: | ||||||
| **Since v2.0 new save file format is implemented. You can use [McBitFont v1.7](https://gitea.mcflyer.ru/McFLY/McBitFont/releases/tag/v1.7) to convert old saved files to the new format.** | **Since v2.0 new save file format is implemented. You can use [McBitFont v1.7](https://gitea.mcflyer.ru/McFLY/McBitFont/releases/tag/v1.7) to convert old saved files to the new format.** | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								STM32_HAL_Lib/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								STM32_HAL_Lib/README.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | # McText Library | ||||||
|  |  | ||||||
|  | - The library uses "Left to Right, Top to bottom" scan and "LSB Top" for pixels alignment | ||||||
|  |  | ||||||
|  | #### Instructions | ||||||
|  |  | ||||||
|  | To use the library you have to have a display driver with a function that paints a single pixel with X and Y coordinates and 0/1 color.<br> | ||||||
|  | Find "SET A FUNCTION NAME HERE!" text in *mctext.c* file and change the function name that suits your driver.<br> | ||||||
|  | **Note:** it is possible that you will have to change parameters in the function to match your driver. | ||||||
|  |  | ||||||
|  | **Note:** check the "include" in *mctext.h* file to match your HAL. (stm32f1xx_hal.h is fo STM32F1 MCU series) | ||||||
|  |  | ||||||
|  | Now use **mct_String** function to draw a string of text. | ||||||
							
								
								
									
										113
									
								
								STM32_HAL_Lib/mctext.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										113
									
								
								STM32_HAL_Lib/mctext.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,113 @@ | |||||||
|  | /* | ||||||
|  |  * mctext.c | ||||||
|  |  * | ||||||
|  |  *  Created on: May 16, 2025 | ||||||
|  |  *      Author: User | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #include "mctext.h" | ||||||
|  | #include "ST7565.h" | ||||||
|  |  | ||||||
|  | //=========================== SET A FUNCTION NAME HERE! ===========================// | ||||||
|  | // A function from display driver to set a pixel (x, y, color) | ||||||
|  | void (*mct_SetPixel)(uint8_t, uint8_t, uint8_t) = ST7565_SetPixel; | ||||||
|  | //=================================================================================// | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // Draw a single character. Returns width of drawn character | ||||||
|  | uint8_t mct_CharT(uint8_t x, uint8_t y, unsigned char c, uint8_t color, const uint8_t *font, uint8_t transp) { | ||||||
|  |   uint8_t pk = font[0]; // Is it a packed font? | ||||||
|  |   uint8_t w  = font[1]; // Font char width | ||||||
|  |   uint8_t h  = font[2]; // Font char height | ||||||
|  |   uint8_t fc = font[4]; // First char code in the font | ||||||
|  |   uint8_t lc = font[5]; // Last char code in the font | ||||||
|  |   uint8_t i, j, p, s, b, seg; // i-cur.column, j-cur.row of 8, p-rows of 8, s-height in cur.row of 8, b-cur.bit in cur.row, seg-byte.segment | ||||||
|  |   uint8_t bps;          // Bytes per symbol for packed fonts | ||||||
|  |   uint16_t o;           // Current offset | ||||||
|  |  | ||||||
|  |   if (c < fc || c > lc) return 0; | ||||||
|  |   if (x > LCDWIDTH) return 0; | ||||||
|  |   if (y+h > LCDHEIGHT) return 0; | ||||||
|  |  | ||||||
|  |   // Calc the offset for desired symbol | ||||||
|  |   if (pk) { // The font is packed | ||||||
|  |     if (w) { // The font is monospaced | ||||||
|  |       bps = w*h/8;                      // Bytes per symbol | ||||||
|  |       if ((w*h)%8 > 0) bps++;           // Correction for the last byte | ||||||
|  |       o = FONT_HEADER+(c-fc)*bps;       // Offset for desired symbol | ||||||
|  |     } else { // The font is not monospaced | ||||||
|  |       o = FONT_HEADER;                  // Starting offset | ||||||
|  |       for (i=0; i<c-fc; i++) {          // Going through every symbol | ||||||
|  |         bps = font[o]*h/8;              // Bytes per current symbol | ||||||
|  |         if ((font[o]*h)%8 > 0) bps++;   // Correction for the last byte | ||||||
|  |         o += bps + 1;                   // Adding symbol's width to the offset (+ width byte) | ||||||
|  |       } | ||||||
|  |       w = font[o];                      // Desired symbol's width | ||||||
|  |       o++;                              // Offset for desired symbol's data | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // Draw the packed symbol! | ||||||
|  |     bps = w*h/8;                        // Bytes per current symbol | ||||||
|  |     if ((w*h)%8 > 0) bps++;             // Correction for the last byte | ||||||
|  |     b = 0;                              // bit indexer in "current" byte | ||||||
|  |     for (i=0; i<w; i++) {               // Going through columns | ||||||
|  |       if (x+i > LCDWIDTH) return i-1;   // Check if we're out of display size | ||||||
|  |       for (j=0; j<h; j++) {             // Going through rows in column [i] | ||||||
|  |         if (b == 0) seg = font[o]; | ||||||
|  |         if ((seg>>b) & 1) mct_SetPixel(x+i, y+j, color); // Paint the pixel | ||||||
|  |         if (b < 7) b++; else {b = 0; o++;} // Track bits and bytes | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |   } else { // The font is not packed | ||||||
|  |     p = (h%8 > 0) ? h/8 + 1 : h/8;      // Bytes in one column | ||||||
|  |     if (w) { // The font is monospaced | ||||||
|  |       o = FONT_HEADER+(c-fc)*w*p;       // Offset for desired symbol | ||||||
|  |     } else { // The font is not monospaced | ||||||
|  |       o = FONT_HEADER;                  // Starting offset | ||||||
|  |       for (i=0; i<c-fc; i++) {          // Going through every symbol | ||||||
|  |         o += font[o]*p + 1;             // Adding symbol's width to the offset | ||||||
|  |       } | ||||||
|  |       w = font[o];                      // Desired symbol's width | ||||||
|  |       o++;                              // Offset for desired symbol's data | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // Draw the symbol | ||||||
|  |     for (i=0; i<w; i++) {               // Going through columns | ||||||
|  |       if (x+i > LCDWIDTH) return i-1;   // Check if we're out of display size | ||||||
|  |       for (j=0; j<p; j++) {             // Going through bytes in single column | ||||||
|  |         s = (h - j*8 >= 8) ? 8 : (h - j*8) % 8; // Clac the amount of pixels in current byte | ||||||
|  |  | ||||||
|  |         seg = font[o]; | ||||||
|  |         for (b=0; b<s; b++) {           // Going through the byte and paint the pixel if the bit is 1 | ||||||
|  |           if ((seg>>b) & 1) mct_SetPixel(x+i, y+j*8+b, color); | ||||||
|  |           else if (!transp) mct_SetPixel(x+i, y+j*8+b, !color); | ||||||
|  |         } | ||||||
|  |         o++; | ||||||
|  |       } | ||||||
|  |       //mct_SetPixel(x+i, y, color);   // For testing purposes | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return w; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Draw a single character. Transparent background. Returns width of drawn character | ||||||
|  | uint8_t mct_Char(uint8_t x, uint8_t y, unsigned char c, uint8_t color, const uint8_t *font) { | ||||||
|  |   return mct_CharT(x, y, c, color, font, 1); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Draw a string of characters | ||||||
|  | void mct_String(uint8_t x, uint8_t y, const char *c, uint8_t color, const uint8_t *font) { | ||||||
|  |   uint8_t w  = font[1]; // Font char width | ||||||
|  |   uint8_t h  = font[2]; // Font char height | ||||||
|  |   uint8_t s  = font[3]; // Font space between characters | ||||||
|  |  | ||||||
|  |   if (y+h > LCDHEIGHT) return; | ||||||
|  |   while (c[0] != 0) { | ||||||
|  |     if (x+w > LCDWIDTH) return; | ||||||
|  |     w = mct_Char(x, y, (unsigned char)*c, color, font); | ||||||
|  |     c++; | ||||||
|  |     x += w + s; | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										21
									
								
								STM32_HAL_Lib/mctext.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								STM32_HAL_Lib/mctext.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | /* | ||||||
|  |  * mctext.h | ||||||
|  |  * | ||||||
|  |  *  Created on: May 16, 2025 | ||||||
|  |  *      Author: User | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #ifndef INC_MCTEXT_H_ | ||||||
|  | #define INC_MCTEXT_H_ | ||||||
|  |  | ||||||
|  | #include "stm32f1xx_hal.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // Draw a single character. Returns width of drawn character | ||||||
|  | uint8_t mct_Char(uint8_t x, uint8_t y, unsigned char c, uint8_t color, const uint8_t *font); | ||||||
|  |  | ||||||
|  | // Draw a string of characters | ||||||
|  | void mct_String(uint8_t x, uint8_t y, const char *c, uint8_t color, const uint8_t *font); | ||||||
|  |  | ||||||
|  | #endif /* INC_MCTEXT_H_ */ | ||||||
							
								
								
									
										5
									
								
								TODO.txt
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								TODO.txt
									
									
									
									
									
								
							| @@ -1,7 +1,10 @@ | |||||||
| Application: | Application: | ||||||
| - Consider migrating to WPF in order to make DPI aware UI | - Consider migrating to WPF in order to make DPI aware UI | ||||||
| - Cursor for rectangular selection tool | V Cursor for rectangular selection tool | ||||||
|  | V Icons for tool buttons | ||||||
|  | V Tooltips now has keyboard shortcuts info | ||||||
|  |  | ||||||
| Functionality: | Functionality: | ||||||
|  |  | ||||||
| Bugs: | Bugs: | ||||||
|  | V Fix selection info: change comma to x | ||||||
|   | |||||||
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								examples/SelectionCursor.mbfont
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								examples/SelectionCursor.mbfont
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
		Reference in New Issue
	
	Block a user