Text Editing is one of the most common tasks performed, this tutorial will show you who to create your own Text Editor, using the TextBox, Open/Save & Font/Colour Dialogs and more!
This part will show you how to create the Text Editor, Part Two will add Find & Replace to the Text Editor.
Printer Friendly Download Tutorial (297KB) Download Source Code (12.9KB)
Step 1
Start Microsoft Visual Basic 2008 Express Edition, then select File then New Project... Choose Windows Forms Application from the New Project Window, enter a name for the Project and then click OK, see below:
data:image/s3,"s3://crabby-images/c9ccf/c9ccf6f9737fb9b95742e4b1b04015e8464e07ea" alt="New Project"
Step 2
A Blank Form named Form1 should then appear, see below:
data:image/s3,"s3://crabby-images/e75f4/e75f4525100a8583512d983e67d15cb64268a03a" alt="Form1"
Step 3
With Form1 selected goto the Properties box and change the Name from Form1 to frmMain
data:image/s3,"s3://crabby-images/cba1c/cba1c884a05f9ca55e50e6d3aabc95287f835b16" alt="Form1 Properties"
Step 4
Then from the Common Controls tab on the Toolbox select the Textbox component:
data:image/s3,"s3://crabby-images/0dc0c/0dc0c5c38588522ad3db6e34e18143e8e40f9a7b" alt="Textbox Component"
Step 5
Draw a Textbox on the Form, see below:
data:image/s3,"s3://crabby-images/cd320/cd3204e9e3640202339e2ee1676516264a5c4309" alt="frmMain with Textbox"
Step 6
Then goto the Properties box and change the Name to txtEditor, Dock to Fill, Multiline to True and Scrollbars to Vertical, see Below:
data:image/s3,"s3://crabby-images/9aa23/9aa2330326f06623818ee8ec5e8c5727eef7af8a" alt="TextBox Properties"
Step 7
Then from the Menus & Toolbars tab on the Toolbox select the MenuStrip Control, see Below:
data:image/s3,"s3://crabby-images/fc836/fc836fd8f98b7749edd177e4783ff66748ed9ba6" alt="MenuStrip Component"
Step 8
Either double-click on the MenuStrip Control entry in the Menu & Toolbars tab on the Toolbox or keep the MenuStrip Component Clicked and then move it over the Form then let go. Change the Name of the MenuStrip in the properties to mnuText The Form will then look as below:
data:image/s3,"s3://crabby-images/dad46/dad461f93272965baf0f15a4d51635dc2b5de92a" alt="frmMain with MenuStrip"
Step 9
Click or select where the MenuStrip says "Type Here", an editable Textbox will appear type in "File" without the quotes in this Box, then in the Box below that type in "New", below that "Open...", then "Save...", then "-" which is minus or the hyphen key which will appear as a Seperator and then finally "Exit". The MenuStrip should look as below:
data:image/s3,"s3://crabby-images/375da/375dada6c6b8b3512d72a6d173a942e702cb3fb9" alt="mnuText with SubMenus"
Step 10
Click or select where the MenuStrip says "Type Here" next to "File", and in this type in "Edit" without the quotes in this Box, then in the Box below that type "Cut", then below that "Copy", then "Paste" and "Delete", type in "-" which is minus or the hyphen key for a Seperator, then below that "Select All" and finally "Time/Date". The MenuStrip should look as below:
data:image/s3,"s3://crabby-images/6b037/6b037932d378609d02e0cccdac79315603bfaa02" alt="mnuText with Edit Sub Menu Items"
Step 11
Click on or select the MenuStrip again, on this next to the Edit menu will be another "Type Here" option this this box type "Format" without the quotes, then in the "Type Here" box under that type "Font...", then below that "Colour..." and finally "Background...", see below:
data:image/s3,"s3://crabby-images/8627c/8627cd973c4257f15dea7c1be52775f6f4ecc58a" alt="mnuText with Format Sub Menu Items"
Step 12
Click on "File" on the MenuStrip to show the MenuStrip then Double Click on the Menu Item Labeled "New" (NewToolStripMenuItem) and type the following in the NewToolStripMenuItem_Click() Sub:
Dim Response As MsgBoxResult Response = MsgBox("Are you sure you want to start a New Document?", _ MsgBoxStyle.Question + MsgBoxStyle.YesNo, _ "Text Editor") If Response = MsgBoxResult.Yes Then txtEditor.Text = "" Me.Text = "Text Editor - Untitled" End If
See Below:
data:image/s3,"s3://crabby-images/10f00/10f00934a0475864dfdbaa5a31d6f1bf16b5538e" alt="File Menu New Menu Item Click Event"
Step 13
Click on the [Design] Tab to view the form again, then Click on "File" on the MenuStrip to show the MenuStrip then Double Click on the Menu Item Labeled "Open..." (OpenToolStripMenuItem) and type the following in the OpenToolStripMenuItem_Click() Sub:
Dim Open As New OpenFileDialog() Dim myStreamReader As System.IO.StreamReader Open.Filter = "Plain Text Files (*.txt)|*.txt|All files (*.*)|*.*" Open.CheckFileExists = True Open.ShowDialog(Me) Try Open.OpenFile() myStreamReader = System.IO.File.OpenText(Open.FileName) txtEditor.Text = myStreamReader.ReadToEnd() Me.Text = "Text Editor - " & Open.FileName Catch ex As Exception ' Do nothing on Exception End Try
See Below:
data:image/s3,"s3://crabby-images/129e6/129e664f2e32091df5054e57b15e2bddbae551f8" alt="File Menu Open Menu Item Click Event"
Step 14
Click on the [Design] Tab to view the form again, then Click on "File" on the MenuStrip to show the MenuStrip then Double Click on the Menu Item Labeled "Save..." (SaveToolStripMenuItem) and type the following in the SaveToolStripMenuItem_Click() Sub
Dim Save As New SaveFileDialog() Dim myStreamWriter As System.IO.StreamWriter Save.Filter = "Plain Text Files (*.txt)|*.txt|All files (*.*)|*.*" Save.CheckPathExists = True Save.ShowDialog(Me) Try myStreamWriter = System.IO.File.CreateText(Save.FileName) myStreamWriter.Write(txtEditor.Text) myStreamWriter.Flush() Me.Text = "Text Editor - " & Save.FileName Catch ex As Exception ' Do nothing on Exception End Try
See Below:
data:image/s3,"s3://crabby-images/cb34d/cb34d83587acbe097c192c0aadf243372b4a401f" alt="File Menu Save Menu Item Click Event"
Step 15
Click on the [Design] Tab to view the form again, then Click on "File" on the MenuStrip to show the MenuStrip then Double Click on the Menu Item Labeled "Exit" (ExitToolStripMenuItem) and type the following in the ExitToolStripMenuItem_Click() Sub
Dim Response As MsgBoxResult Response = MsgBox("Are you sure you want to Exit Text Editor?", _ MsgBoxStyle.Question + MsgBoxStyle.YesNo, _ "Text Editor") If Response = MsgBoxResult.Yes Then End End If
See Below:
data:image/s3,"s3://crabby-images/a5b5b/a5b5bccee99bc8acc8a2e7775f1e34f9b74c86c1" alt="File Menu Exit Menu Item Click Event"
Step 16
Click on "Edit" on the MenuStrip to show the MenuStrip then Double Click on the Menu Item Labeled "Cut" (CutToolStripMenuItem) and type the following in the CutToolStripMenuItem_Click() Sub:
txtEditor.Cut()
See Below:
data:image/s3,"s3://crabby-images/64292/642921aeb820f2e6f6db25c0b91ff838fd46cd9d" alt="Edit Menu Cut Menu Item Click Event"
Step 17
Click on the [Design] Tab to view the form again or double click on the Form's name in the Solution Explorer, then Click on "Edit" on the MenuStrip to show the MenuStrip then Double Click on the Menu Item Labeled "Copy" (CopyToolStripMenuItem) and type the following in the CopyToolStripMenuItem_Click() Sub:
txtEditor.Copy()
See Below:
data:image/s3,"s3://crabby-images/b2ed6/b2ed69184fe364df2e54ad7e77a0987d9e6e5d32" alt="Edit Menu Copy Menu Item Click Event"
Step 18
Click on the [Design] Tab to view the form again or double click on the Form's name in the Solution Explorer, then Click on "Edit" on the MenuStrip to show the MenuStrip then Double Click on the Menu Item Labeled "Paste" (PasteToolStripMenuItem) and type the following in the PasteToolStripMenuItem_Click() Sub:
txtEditor.Paste()
See Below:
data:image/s3,"s3://crabby-images/e904b/e904baa7eb17412c335d0de7f45ea525d0e5b9ea" alt="Edit Menu Paste Menu Item Click Event"
Step 19
Click on the [Design] Tab to view the form again or double click on the Form's name in the Solution Explorer, then Click on "Edit" on the MenuStrip to show the MenuStrip then Double Click on the Menu Item Labeled "Delete" (DeleteToolStripMenuItem) and type the following in the DeleteToolStripMenuItem_Click() Sub:
txtEditor.SelectedText = ""
See Below:
data:image/s3,"s3://crabby-images/32e36/32e36ce76642b873cda6110b778d7ac546016429" alt="Edit Menu Delete Menu Item Click Event"
Step 20
Click on the [Design] Tab to view the form again or double click on the Form's name in the Solution Explorer, then Click on "Edit" on the MenuStrip to show the MenuStrip then Double Click on the Menu Item Labeled "Select All" (SelectAllToolStripMenuItem) and type the following in the SelectAllToolStripMenuItem_Click() Sub:
txtEditor.SelectAll()
See Below:
data:image/s3,"s3://crabby-images/3a100/3a1000841771681e378e42f37a63ca1d943d6f01" alt="Edit Menu Select All Menu Item Click Event"
Step 21
Click on the [Design] Tab to view the form again or double click on the Form's name in the Solution Explorer, then Click on "Edit" on the MenuStrip to show the MenuStrip then Double Click on the Menu Item Labeled "Time/Date" (TimeDateToolStripMenuItem) and type the following in the TimeDateToolStripMenuItem_Click() Sub:
txtEditor.SelectedText = Format(Now, "HH:mm dd/MM/yyyy")
See Below:
data:image/s3,"s3://crabby-images/4c4b7/4c4b7c26e43441da97ce6ec23b3a0eecd837455e" alt="Edit Menu Time/Date Menu Item Click Event"
Step 22
Click on [Design] tab or double click on the Form's name in Solution Explorer then click on "Format" on the MenuStrip to show the MenuStrip then Double Click on the Menu Item Labeled "Font..." (FontToolStripMenuItem) and type the following in the FontToolStripMenuItem_Click() Sub:
Dim Font As New FontDialog() Font.Font = txtEditor.Font Font.ShowDialog(Me) Try txtEditor.Font = Font.Font Catch ex As Exception ' Do nothing on Exception End Try
See Below:
data:image/s3,"s3://crabby-images/92b88/92b88812cfef739a4e1fdeb01ca41f180c775541" alt="Format Menu Font Menu Item Click Event"
Step 23
Click on the [Design] Tab to view the form again or double click on the Form's name in the Solution Explorer, then Click on "Format" on the MenuStrip to show the MenuStrip then Double Click on the Menu Item Labeled "Colour..." (ColourToolStripMenuItem) and type the following in the ColourToolStripMenuItem_Click() Sub:
Dim Colour As New ColorDialog() Colour.Color = txtEditor.ForeColor Colour.ShowDialog(Me) Try txtEditor.ForeColor = Colour.Color Catch ex As Exception ' Do nothing on Exception End Try
See Below:
data:image/s3,"s3://crabby-images/abee5/abee5bc4a4099c559949ceca1ee21720460d03a5" alt="Format Menu Colour Menu Item Click Event"
Step 24
Click on the [Design] Tab to view the form again or double click on the Form's name in the Solution Explorer, then Click on "Format" on the MenuStrip to show the MenuStrip then Double Click on the Menu Item Labeled "Background..." (BackgroundToolStripMenuItem) and type the following in the BackgroundToolStripMenuItem_Click() Sub:
Dim Colour As New ColorDialog() Colour.Color = txtEditor.BackColor Colour.ShowDialog(Me) Try txtEditor.BackColor = Colour.Color Catch ex As Exception ' Do nothing on Exception End Try
See Below:
data:image/s3,"s3://crabby-images/e8487/e8487e87f9c5776bd9fa8df79d1ffde468633aa3" alt="Format Menu Background Menu Item Click Event"
Step 25
Click on the [Design] Tab to view the form again, then Double Click on the Form (frmMain) and type the following in the frmMain_Load() Sub
txtEditor.Text = "" Me.Text = "Text Editor - Untitled"
See Below:
data:image/s3,"s3://crabby-images/e7c3e/e7c3ef04b79269282fa1d838664ba9e7e3771412" alt="frmMain Load Event"
Step 26
Steps 26-28 are optional and just add Keyboard Shortcuts to the MenuItems, you don't have to do these if you don't want to!
Click on the [Design] Tab to view the form again, click on "New" on the MenuStrip then in the Properties box look for the "ShortcutKeys" option and
click on the Drop Down arrow where "None" appears. Check the "Ctrl" Checkbox in "Modifiers" and then in the "Key" dropdown list select "N",
see below:
data:image/s3,"s3://crabby-images/04c88/04c8864ffe26920f2fcf390a35765753e8aac381" alt="File Menu New Menu Item Shortcut Key"
Step 27
Set the rest of the "File" MenuItem "ShortcutKeys" Properties except the "Exit" Menu Item, "Open" should be set to "Ctrl+O" and "Save" to "Ctrl+S", the File Menu should appear as below:
data:image/s3,"s3://crabby-images/84f40/84f40f236165f186204dd4c6ef51aeb9edf662f3" alt="File Menu with Shortcut Keys"
Step 28
Click on or select the "Edit" Menu and set the "ShortcutKeys" Properties, "Cut" should be set to "Ctrl+X", "Copy" to "Ctrl+C", "Paste" to "Ctrl+V", "Delete" should be just "Del" in the Keys drop-down list, "Select All" should be "Ctrl+A", "Time/Date" should be just "F5" from the Keys drop-down list. The Edit Menu should appear as below:
data:image/s3,"s3://crabby-images/50859/508592c941e954f05b77878485044e4793886b77" alt="Edit Menu with Shortcut Keys"
Step 29
Save the Project as you have now finished the application, then click on Start:
data:image/s3,"s3://crabby-images/d5099/d50997c18f65b4ae2f93079cb63bf01ea31adeb7" alt="Start"
When you do the following will appear:
data:image/s3,"s3://crabby-images/fe1bf/fe1bf963cbb7fdab147b83766b31bbe35e42dd57" alt="Text Editor Running"
Step 30
Click on the File Menu and select Open...,this will show the Open File Dialog, then select a Text File on your Computer this should appear in the Textbox, see below:
data:image/s3,"s3://crabby-images/69fd6/69fd6f0657761e4bcdb91df59b3471af7e259fd3" alt="Text Editor with Opened Document"
Step 31
Click File then Exit or click on the Close button
on the top right of the Text Editor to end the application.
This Text Editor has all the main Editing and Format features you would expect from a Plain Text Editor, plus has added some extra enhancements such as Shortcut Keys and Foreground / Background Colours.