Skip to main content

PowerShell creating Windows Forms


From this Technet blog (link below), it shows how to add a Form and a Label control using PowerShell.


The PowerShell script below is a modification from above link.

Here, I will add a Button to the form, and also add an event click listener to the button.

And also add the simple but very useful "Msgbox".

Unlike VB.Net where you can just drag and drop your control on the form and VB.Net will do the necessary things on the background. For PowerShell you have to code the controls and location.

For the script below, location control for x and y coordinates is set.

If the location is not set, the control will be overlapping with each other and other controls cannot be seen.

To dig more about MSDN System Windows Forms, check out link below:



Here's the script below, with comments above the codes:

# =======================

Add-Type -AssemblyName System.Windows.Forms

# Add a Form to PowerShell
$Form = New-Object system.Windows.Forms.Form


#Set the FormBorderStyle cannot be drag manually
$Form.FormBorderStyle="Fixed3D"


#Set the text for the Form
$Form.Text = "Sample Form"


#Add a label control to the form
$Label = New-Object System.Windows.Forms.Label


#Add a text to the label control
$Label.Text = "This form is very simple."


#Set the Label control to Auto size to display whole string
$Label.AutoSize = $True


#Set the x and y coordinates location for the label control
#Top left corner x and y = 0
$Label.Location = "10,10"


#Add a new button to the form
$Button = New-Object System.Windows.Forms.Button

#Set the text or caption to the button
$Button.Text = "Simple Button"

#Set to Autosize so the text or caption will not be crop
$Button.AutoSize = $True


#Set Button Location below the label
$Button.Location = "10,40"


#Add a click event listener to the button
#Load the Net Framework to display and use Msgbox function


$Button.Add_Click({

[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.VisualBasic")
[Microsoft.VisualBasic.Interaction]::MsgBox("Hello there!!! Testing Only!?",'YesNoCancel,Exclamation', "Respond please")

})



#Add the controls to the form and show the form
$Form.Controls.Add($Label)
$Form.Controls.Add($Button)
$Form.ShowDialog()

 # =======================

PowerShell script without the comments:

 # =======================
Add-Type -AssemblyName System.Windows.Forms
$Form = New-Object system.Windows.Forms.Form
$Form.FormBorderStyle="Fixed3D"
$Form.Text = "Sample Form"
$Label = New-Object System.Windows.Forms.Label
$Label.Text = "This form is very simple."
$Label.AutoSize = $True
$Label.Location = "10,10"

$Button = New-Object System.Windows.Forms.Button
$Button.Text = "Simple Button"
$Button.AutoSize = $True
$Button.Location = "10,40"

$Button.Add_Click({
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.VisualBasic")
[Microsoft.VisualBasic.Interaction]::MsgBox("Hello there!!! Testing Only!?",'YesNoCancel,Exclamation', "Respond please")
})


$Form.Controls.Add($Label)
$Form.Controls.Add($Button)
$Form.ShowDialog()
 # ======================= 

Output for above script:





Hope it helps…Cheers!!!

A basic way to display form, label and button using PowerShell. Hope it helps you to get started..

================

Educational App for Android Kids:

https://play.google.com/store/apps/details?id=com.letsmultiply

Comments

Popular posts from this blog

Notepad++ convert multiple lines to a single line and vice versa

Notepad++ is an awesome text editing tool, it can accept regex to process the text data. If the data is in a “.csv” format or comma separated values which is basically just a text file that can either be opened using a text editor, excel or even word. Notepad++ can process the contents of the file using regex. Example if the data has multiple rows or lines, and what is needed is to convert the whole lines of data into a single line. Notepad++ can easily do it using regex. However, if the data is on a single line and it needs to be converted into multiple lines or rows then regex can also be used for this case. Here’s an example on how to convert multiple rows or lines into a single line. Example data: Multiple rows, just a sample data. Press Ctrl+H, and  on "Find what" type: [\r\n]+ and on "Replace with" type with: , (white space) --white space is needed if need to have a space in between the data. See image below, "Regular Expression" must be se

WMIC get computer name

WMIC get computer model, manufacturer, computer name and  username. WMIC is a command-line tool and that can generate information about computer model, its manufacturer, its username and other informations depending on the parameters provided. Why would you need a command line tool if there’s a GUI to check? If you have 20 or 100 computers, or even more. It’s quite a big task just checking the GUI to check the computer model and username. If you have remote computers, you need to delegate someone in the remote office or location to check. Or you can just write a batch file or script to automate the task. Here’s the code below on how get computer model, manufacturer and the username. Open an elevated command prompt and type:     wmic computersystem get "Model","Manufacturer", "Name", "UserName" Just copy and paste the code above, the word “computersystem” does not need to be change to a computer name. A

How to check office version from command line

The are quite a few ways to check office version it can be done via registry, PowerShell or VBScript and of course, good old command line can also do it. Checking Windows office version whether it is Office 2010, Office, 2013, Office 2016 or other version is quite important to check compatibility of documents; or just a part of software inventory. For PowerShell this simple snippet can check the office version: $ol = New-Object -ComObject Excel.Application $ol . Version The command line option will tell you where’s the path located; the result will also tell whether office is 32-bit, 64-bit and of course the version of the office as well. Here’s the command that will check the office version and which program directory the file is located which will tell whether it’s 32-bit or 64-bit. Command to search for Excel.exe: DIR C:\ /s excel.exe | find   /i "Directory of"  Above command assumes that program files is on  C: drive. Sample Outpu