I have trhe following code which prints the datagridview.. now i want to print a label and a textbox under the datagridview.. how can i do so?
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Collections;
namespace ResturantBookingSystem
{
public partial class frmTableOrder : Form
{
StringFormat strFormat; //Used to format the grid rows.
ArrayList arrColumnLefts = new ArrayList();//Used to save left coordinates of columns
ArrayList arrColumnWidths = new ArrayList();//Used to save column widths
int iCellHeight = 0; //Used to get/set the datagridview cell height
int iTotalWidth = 0; //
int iRow = 0;//Used as counter
bool bFirstPage = false; //Used to check whether we are printing first page
bool bNewPage = false;// Used to check whether we are printing a new page
int iHeaderHeight = 0; //Used for the header height
string username;
int orderID;
public frmTableOrder(string username, int orderID)
{
this.username = username;
this.orderID = orderID;
InitializeComponent();
}
private void btnEdit_Click(object sender, EventArgs e)
{
ManagerUserAccount mgrUserAccount = new ManagerUserAccount();
UserAccount ua = mgrUserAccount.SearchUserAccount(username);
frmTableOrderMaintenance frmMaintenance = new frmTableOrderMaintenance(0, "Edit", 0,ua.StaffID, orderID);
frmMaintenance.Show();
frmTableOrder_Load(null, null);
}
private void frmTableOrder_Load(object sender, EventArgs e)
{
FillOrderDetails();
}
public void FillOrderDetails()
{
dgvOrderItems.Rows.Clear();
ManagerOrder mgrOrder = new ManagerOrder();
Order r = mgrOrder.GetOrderByID(orderID);
ManagerOrderItem mgrOrderItem = new ManagerOrderItem();
List<OrderItem> listOfOrderItems = mgrOrderItem.SearchOrderItemsByOrderID(orderID);
txtTotal.Text = r.TotalPrice.ToString();
cbPaid.Checked = r.Paid;
foreach (OrderItem oi in listOfOrderItems)
{
ManagerItems mgrItems = new ManagerItems();
Item i = mgrItems.GetItemByID(oi.ItemID);
ManagerItemType mgrItemType = new ManagerItemType();
string type = mgrItemType.SearchTypeByID(i.TypeID);
int n = dgvOrderItems.Rows.Add();
dgvOrderItems.Rows[n].Cells[0].Value = i.Name;
dgvOrderItems.Rows[n].Cells[1].Value = type;
dgvOrderItems.Rows[n].Cells[2].Value = i.Price.ToString();
dgvOrderItems.Rows[n].Cells[3].Value = oi.Quantity.ToString();
dgvOrderItems.Rows[n].Cells[4].Value = oi.SubTotal.ToString("0.00");
}
}
private void cbPaid_CheckedChanged(object sender, EventArgs e)
{
bool paid = cbPaid.Checked;
ManagerOrder mgrOrder = new ManagerOrder();
bool edited = mgrOrder.UpdatePaid(paid, orderID);
if (edited)
{
MessageBox.Show("Edited.");
}
else
{
MessageBox.Show("NOT Edited.");
}
}
private void printReciept()
{
//Open the print dialog
PrintDialog printDialog = new PrintDialog();
printDialog.Document = printDocument1;
printDialog.UseEXDialog = true;
//Get the document
if (DialogResult.OK == printDialog.ShowDialog())
{
printDocument1.DocumentName = "Test Page Print";
printDocument1.Print();
}
/*
Note: In case you want to show the Print Preview Dialog instead of
Print Dialog then comment the above code and uncomment the following code
*/
//Open the print preview dialog
//PrintPreviewDialog objPPdialog = new PrintPreviewDialog();
//objPPdialog.Document = printDocument1;
//objPPdialog.ShowDialog();
}
private void btnPrint_Click(object sender, EventArgs e)
{
printReciept();
}
private void printDocument1_BeginPrint(object sender, System.Drawing.Printing.PrintEventArgs e)
{
try
{
strFormat = new StringFormat();
strFormat.Alignment = StringAlignment.Near;
strFormat.LineAlignment = StringAlignment.Center;
strFormat.Trimming = StringTrimming.EllipsisCharacter;
arrColumnLefts.Clear();
arrColumnWidths.Clear();
iCellHeight = 0;
iRow = 0;
bFirstPage = true;
bNewPage = true;
// Calculating Total Widths
iTotalWidth = 0;
foreach (DataGridViewColumn dgvGridCol in dgvOrderItems.Columns)
{
iTotalWidth += dgvGridCol.Width;
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
}
private void printDocument1_PrintPage(object sender, System.Drawing.Printing.PrintPageEventArgs e)
{
try
{
//Set the left margin
int iLeftMargin = e.MarginBounds.Left;
//Set the top margin
int iTopMargin = e.MarginBounds.Top;
//Whether more pages have to print or not
bool bMorePagesToPrint = false;
int iTmpWidth = 0;
//For the first page to print set the cell width and header height
if (bFirstPage)
{
foreach (DataGridViewColumn GridCol in dgvOrderItems.Columns)
{
iTmpWidth = (int)(Math.Floor((double)((double)GridCol.Width /
(double)iTotalWidth * (double)iTotalWidth *
((double)e.MarginBounds.Width / (double)iTotalWidth))));
iHeaderHeight = (int)(e.Graphics.MeasureString(GridCol.HeaderText,
GridCol.InheritedStyle.Font, iTmpWidth).Height) + 11;
// Save width and height of headres
arrColumnLefts.Add(iLeftMargin);
arrColumnWidths.Add(iTmpWidth);
iLeftMargin += iTmpWidth;
}
}
//Loop till all the grid rows not get printed
while (iRow <= dgvOrderItems.Rows.Count - 1)
{
DataGridViewRow GridRow = dgvOrderItems.Rows[iRow];
//Set the cell height
iCellHeight = GridRow.Height + 5;
int iCount = 0;
//Check whether the current page settings allo more rows to print
if (iTopMargin + iCellHeight >= e.MarginBounds.Height + e.MarginBounds.Top)
{
bNewPage = true;
bFirstPage = false;
bMorePagesToPrint = true;
break;
}
else
{
if (bNewPage)
{
//Draw Header
e.Graphics.DrawString("Items Ordered", new Font(dgvOrderItems.Font, FontStyle.Bold),
Brushes.Black, e.MarginBounds.Left, e.MarginBounds.Top -
e.Graphics.MeasureString("Items Ordered", new Font(dgvOrderItems.Font,
FontStyle.Bold), e.MarginBounds.Width).Height - 13);
String strDate = DateTime.Now.ToLongDateString() + " " + DateTime.Now.ToShortTimeString();
//Draw Date
e.Graphics.DrawString(strDate, new Font(dgvOrderItems.Font, FontStyle.Bold),
Brushes.Black, e.MarginBounds.Left + (e.MarginBounds.Width -
e.Graphics.MeasureString(strDate, new Font(dgvOrderItems.Font,
FontStyle.Bold), e.MarginBounds.Width).Width), e.MarginBounds.Top -
e.Graphics.MeasureString("Items Ordered", new Font(new Font(dgvOrderItems.Font,
FontStyle.Bold), FontStyle.Bold), e.MarginBounds.Width).Height - 13);
//Draw Columns
iTopMargin = e.MarginBounds.Top;
foreach (DataGridViewColumn GridCol in dgvOrderItems.Columns)
{
e.Graphics.FillRectangle(new SolidBrush(Color.LightGray),
new Rectangle((int)arrColumnLefts[iCount], iTopMargin,
(int)arrColumnWidths[iCount], iHeaderHeight));
e.Graphics.DrawRectangle(Pens.Black,
new Rectangle((int)arrColumnLefts[iCount], iTopMargin,
(int)arrColumnWidths[iCount], iHeaderHeight));
e.Graphics.DrawString(GridCol.HeaderText, GridCol.InheritedStyle.Font,
new SolidBrush(GridCol.InheritedStyle.ForeColor),
new RectangleF((int)arrColumnLefts[iCount], iTopMargin,
(int)arrColumnWidths[iCount], iHeaderHeight), strFormat);
iCount++;
}
bNewPage = false;
iTopMargin += iHeaderHeight;
}
iCount = 0;
//Draw Columns Contents
foreach (DataGridViewCell Cel in GridRow.Cells)
{
if (Cel.Value != null)
{
e.Graphics.DrawString(Cel.Value.ToString(), Cel.InheritedStyle.Font,
new SolidBrush(Cel.InheritedStyle.ForeColor),
new RectangleF((int)arrColumnLefts[iCount], (float)iTopMargin,
(int)arrColumnWidths[iCount], (float)iCellHeight), strFormat);
}
//Drawing Cells Borders
e.Graphics.DrawRectangle(Pens.Black, new Rectangle((int)arrColumnLefts[iCount],
iTopMargin, (int)arrColumnWidths[iCount], iCellHeight));
iCount++;
}
}
iRow++;
iTopMargin += iCellHeight;
}
//If more lines exist, print another page.
if (bMorePagesToPrint)
e.HasMorePages = true;
else
e.HasMorePages = false;
}
catch (Exception exc)
{
MessageBox.Show(exc.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
}
}
}