This exercise is meant to apply the concepts of a Button
control. It is used to process simple orders for a cleaning store. |
Practical Learning: Introducing Buttons
|
|
- Start a new Windows Application named GCS1
- Set the form's icon to Drive:\Program Files\Microsoft Visual Studio .NET 2003\Common7\Graphics\icons\Misc\BULLSEYE.ICO
- Design the form as follows:
data:image/s3,"s3://crabby-images/0fa52/0fa5233fb2b5ad81903cae5eb2dfec5717a22f01" alt="Georgetown Cleaning Services" |
Control |
Name |
Text |
Additional Properties |
GroupBox |
data:image/s3,"s3://crabby-images/feca2/feca252f2c26700efa270c5ba7f8750d8c151ee3" alt="GroupBox" |
|
Order Setup |
|
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
Customer Name: |
|
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtCustName |
|
|
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
Order Date: |
|
MaskedEdBox |
data:image/s3,"s3://crabby-images/d7f12/d7f12c08f92ee677ea468ac8f36f08be41cbdb64" alt="Masked Edit Control" |
txtOrderDate |
|
Format: dddd dd mmmm yyyy
Mask: ##-##-## |
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
Order Time: |
|
MaskedEdBox |
data:image/s3,"s3://crabby-images/d7f12/d7f12c08f92ee677ea468ac8f36f08be41cbdb64" alt="Masked Edit Control" |
txtOrderTime |
|
Format: hh:mm AM/PM
Mask: ##:## |
GroupBox |
data:image/s3,"s3://crabby-images/feca2/feca252f2c26700efa270c5ba7f8750d8c151ee3" alt="GroupBox" |
|
Order Processing |
|
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
Item Type |
|
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
Qty |
|
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
Unit Price |
|
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
Sub Total |
|
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
Shirts |
|
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtQtyShirts |
0 |
TextAlign: Right |
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtPriceShirts |
0.95 |
TextAlign: Right |
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtTotalShirts |
0.00 |
TextAlign: Right
ReadOnly: True |
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
Pants |
|
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtQtyPants |
0 |
TextAlign: Right |
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtPricePants |
2.95 |
TextAlign: Right |
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtTotalPants |
0.00 |
TextAlign: Right
ReadOnly: True |
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
Dresses |
|
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtQtyDresses |
0 |
TextAlign: Right |
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtPriceDresses |
2.95 |
TextAlign: Right |
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtTotaldresses |
4.55 |
TextAlign: Right
ReadOnly: True |
Button |
data:image/s3,"s3://crabby-images/af109/af10999320d08a4f3d46cc53e99072f63a9fca0b" alt="Button" |
btnCalculate |
Calculate |
|
GroupBox |
data:image/s3,"s3://crabby-images/feca2/feca252f2c26700efa270c5ba7f8750d8c151ee3" alt="GroupBox" |
|
Order Summary |
|
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
Total Order |
|
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtTotalOrder |
0.00 |
TextAlign: Right
ReadOnly: True |
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
TaxRate |
|
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtTaxRate |
5.75 |
TextAlign: Right |
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
% |
|
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
Tax Amount |
|
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtTaxAmount |
0.00 |
TextAlign: Right
ReadOnly: True |
Label |
data:image/s3,"s3://crabby-images/d8c9e/d8c9e7cd3527a1a2a8ab10283c643d2de5fc788c" alt="Label" |
|
Net Price |
|
TextBox |
data:image/s3,"s3://crabby-images/034ba/034baca30b4b239c06a9f5868e6db8aecaaf086c" alt="TextBox" |
txtNetPrice |
0.00 |
TextAlign: Right
ReadOnly: True |
Button |
data:image/s3,"s3://crabby-images/af109/af10999320d08a4f3d46cc53e99072f63a9fca0b" alt="Button" |
btnClose |
Close |
|
|
- Save All
- On the main menu, click File -> New -> File...
- In the New File dialog box, double-click Icon File
- Right-click a white area in the drawing section, position the mouse on
Current Icon Image Types, and click 16x16, 16 Colors
- Save it as Calculate in the main folder of the current project
- Change its design as follows:
data:image/s3,"s3://crabby-images/1f673/1f673cb9214f694ca3d1835c5b4c988b4f84cd2c" alt=""
- Right-click a white area in the drawing section, position the mouse on
Current Icon Image Types, and click 32x32, 16 Colors
- Right-click a white area in the drawing section and click Delete Image
Type
- Save the icon
- On the main menu, click Project -> Add New Item...
- In the Add New Item dialog box, click Icon File
- Change the name to SubTotal and click Open
- Right-click a white area in the drawing section, position the mouse on
Current Icon Image Types, and click 16x16, 16 Colors
- Change its design as follows:
data:image/s3,"s3://crabby-images/39c45/39c4506a732792ee75185e41eb38cb560a0fe288" alt=""
- Right-click a white area in the drawing section, position the mouse on
Current Icon Image Types, and click 32x32, 16 Colors
- Right-click a white area in the drawing section and click Delete Image
Type
- Save the icon
- Add three buttons inside the lower-left group box and delete the content
of their Text property
- Complete the design of the form as follows:
data:image/s3,"s3://crabby-images/ea0fc/ea0fc0003f27a0ec58e925cbc95ce508e6fb1137" alt="Georgetown Cleaning Services" |
Button Name |
Image |
ImageAlign |
TextAlign |
btnShirts |
SubTotal |
|
|
btnPants |
SubTotal |
|
|
btnDresses |
SubTotal |
|
|
btnCalculate |
Calculate |
TopCenter |
BottomCenter |
|
- On the main menu, click View Tab Order and click the controls in the
following order (observe the sequence in the Order Processing group box)
data:image/s3,"s3://crabby-images/d6e9b/d6e9b61174d2c4d6dec266abfb66536e74aaf11e" alt="Georgetown Cleaning Services - Tab Order"
- Save all
- Double-click the button for the shirts and implement its Click event as
follows:
private void btnShirts_Click(object sender, System.EventArgs e)
{
int quantity = 1;
double unitPrice = 0.00, subTotal;
// Retrieve the number of this item
// Just in case the user types an invalid value, we are using a try...catch
try
{
quantity = int.Parse(this->txtQtyShirts->Text);
}
catch(FormatException)
{
MessageBox::Show("The value you entered for the number of shirts is not valid" +
"\nPlease try again");
}
// Retrieve the unit price of this item
// Just in case the user types an invalid value, we are using a try...catch
try
{
unitPrice = double.Parse(this->txtPriceShirts->Text);
}
catch(FormatException)
{
MessageBox::Show("The value you entered for the price of shirts is not valid" +
"\nPlease try again");
}
// Calculate the sub-total for this item
subTotal = quantity * unitPrice;
// Display the sub-total in the corresponding text box
this->txtTotalShirts->Text = subTotal.ToString("F");
}
|
- Double-click the button for the pants and implement its Click event as
follows:
private void btnPants_Click(object sender, System.EventArgs e)
{
int quantity = 1;
double unitPrice = 0.00, subTotal;
try
{
quantity = int.Parse(this->txtQtyPants->Text);
}
catch(FormatException)
{
MessageBox::Show("The value you entered for the number of pants is not valid" +
"\nPlease try again");
}
try
{
unitPrice = double.Parse(this->txtPricePants->Text);
}
catch(FormatException)
{
MessageBox::Show("The value you entered for the price of pants is not valid" +
"\nPlease try again");
}
subTotal = quantity * unitPrice;
this->txtTotalPants->Text = subTotal.ToString("F");
}
|
- Double-click the button for the dresses and implement its Click event as
follows:
private void btnDresses_Click(object sender, System.EventArgs e)
{
int quantity = 1;
double unitPrice = 0.00, subTotal;
try
{
quantity = int.Parse(this->txtQtyDresses->Text);
}
catch(FormatException)
{
MessageBox::Show("The value you entered for the number of dresses is not valid" +
"\nPlease try again");
}
try
{
unitPrice = double.Parse(this->txtPriceDresses->Text);
}
catch(FormatException)
{
MessageBox::Show("The value you entered for the price of dresses is not valid" +
"\nPlease try again");
}
subTotal = quantity * unitPrice;
this->txtTotalDresses->Text = subTotal.ToString("F");
}
|
- Double-click the Calculate button and implement its Click event as
follows:
private void btnCalculate_Click(object sender, System.EventArgs e)
{
double priceShirts, pricePants, priceDresses, totalOrder;
double taxRate = 0.00, taxAmount;
double netPrice;
// Retrieve the value of the sub-total for each category of items
priceShirts = double.Parse(this->txtTotalShirts->Text);
pricePants = double.Parse(this->txtTotalPants->Text);
priceDresses = double.Parse(this->txtTotalDresses->Text);
// Calculate the total
totalOrder = priceShirts + pricePants + priceDresses;
// Retrieve the value of the tax rate
try
{
taxRate = double.Parse(this->txtTaxRate->Text);
}
catch(FormatException)
{
MessageBox::Show("The tax rate you entered is invalid" +
"\nPlease try again");
}
// Calculate the amount owed for the taxes
taxAmount = totalOrder * taxRate / 100;
// Add the tax amount to the total order
netPrice = totalOrder + taxAmount;
// Display the values of the order summary
this->txtTotalOrder->Text = totalOrder.ToString("C");
this->txtTaxAmount->Text = taxAmount.ToString("C");
this->txtNetPrice->Text = netPrice.ToString("C");
}
|
- Double-click the Close button and implement its Click event as follows:
private void btnClose_Click(object sender, System.EventArgs e)
{
Close();
}
|
- Execute the application to test the form. In the Order Date text box, type
081103 and in the Order Time, type 0728 then complete the rest of the order
data:image/s3,"s3://crabby-images/22231/22231149e07c87d3902e54226915bfcf8d3874ea" alt="Georgetown Cleaning Services - Order Processing"
- Close the form and return to your programming environment
|
|