Solved

ShowDialog form with MonthCalendar over the button that shows calendar

Posted on 2008-11-03
6
594 Views
Last Modified: 2011-10-19
I have various forms that contain date maskedtextboxes and a button to the right of each textbox inside either a tabcontrol, panel or both.  The button will showdialog this form that contains a MonthCalendar with only a Close option in top right.

I am attempting to pass the location of the button so that the top/left corner of Calendar form can be displayed just over the top/left corner of button.  Below is the code to kick off the calendar.

Dim frm As New Misc_CalendarDateSelect(104, "txtDueDate", txtDueDate.Text, Me.Panel1.Location + Me.cmdDueDateCalendar.Location)

The positioning, however is always high and too far to left.  Where am I going wrong???
0
Comment
Question by:TSFLLC
  • 3
  • 3
6 Comments
 
LVL 96

Expert Comment

by:Bob Learned
ID: 22875633
The form's position is based on screen coordinates, and the control's position is based on client coordinates.  You need to convert the client coordinates to screen coordinates, in order to position the form correctly.  The Form and Control class inherit the PointToClient and PointToScreen methods for that purpose.
0
 

Author Comment

by:TSFLLC
ID: 22876801
Below is the code I'm using where Label1 is a label and cmdCheckDateCalendar is the button I want to set the form in front of:

Dim frm As New Misc_CalendarDateSelect("txtCheckDate", FormatCurrentDate(), Me.PointToScreen(Me.Label1.Location + Me.cmdCheckDateCalendar.Location))
frm.ShowDialog()

Public Sub New(ByVal xTextBox As String, ByVal xDate As Date, ByVal xPoint As Point)
        MyBase.New()

        'This call is required by the Windows Form Designer.
        InitializeComponent()
        'Add any initialization after the InitializeComponent() call
        glDateField = xTextBox
        MonthCalendar1.SelectionStart = xDate
        MonthCalendar1.SelectionEnd = xDate
        Me.Location = Me.PointToClient(xPoint)
    End Sub


The only issue I have now is that the CalendarForm does not hide the calendar button with the top left corner of the form but it hides it with the top left corner of the Calendar itself.  I can live with that but I don't understand why it's doing that.
0
 
LVL 96

Expert Comment

by:Bob Learned
ID: 22876861
Can you attach a .png screen shot of what you mean by "hide"?
0
Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

 

Author Comment

by:TSFLLC
ID: 22877380
In the image I attached I have moved the Integra Calendar form away from the Calendar button so that you could see the button.  When you click the button initially, the Integra Calendar form displays over the button and the top left edge of the calendar matches up with the top left corner of the button.

What I don't understand is why the top/left corner of the Integra Calendar form (not the top/left corner of the Calendar control) doesn't match the top/left positioning of the calendar button???

Thanks.
Phil
MonthCalendar1.jpg
0
 
LVL 96

Accepted Solution

by:
Bob Learned earned 500 total points
ID: 22879910
Try something like this example.

You may not have set the form's StartPosition to Manual.

Dim form As New TestForm() 
 
form.StartPosition = FormStartPosition.Manual 
form.Location = New Point(Me.Left + Me.ShowFormButton.Right, Me.Top + Me.ShowFormButton.Bottom) 
 
form.Show() 

Open in new window

0
 

Author Comment

by:TSFLLC
ID: 22880242
The issue of not setting start position to manual was my #1 problem.  The code below works like a charm.

This was the conclusion to the code that worked accordingly:

From data entry form.....
Private Sub cmdInvoiceDateCalendar_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdInvoiceDateCalendar.Click
    If txtInvoiceDate.Text = "  /  /" Then
        Dim frm As New Misc_CalendarDateSelect(104, "txtInvoiceDate", FormatCurrentDate(), Me.PointToScreen(Me.gbInvoiceAssessment1.Location + Me.cmdInvoiceDateCalendar.Location))
        frm.ShowDialog()
    Else
        Dim frm As New Misc_CalendarDateSelect(104, "txtInvoiceDate", txtInvoiceDate.Text, Me.PointToScreen(Me.gbInvoiceAssessment1.Location + Me.cmdInvoiceDateCalendar.Location))
        frm.ShowDialog()
    End If
End Sub

From MonthCalendar form....
Public Sub New(ByVal xTextBox As String, ByVal xDate As Date, ByVal xPoint As Point)
        MyBase.New()

        'This call is required by the Windows Form Designer.
        InitializeComponent()
        'Add any initialization after the InitializeComponent() call
        glDateField = xTextBox
        MonthCalendar1.SelectionStart = xDate
        MonthCalendar1.SelectionEnd = xDate
        Me.StartPosition = FormStartPosition.Manual
        Me.Location = xPoint
    End Sub


Thanks!
Phil
0

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Exit the loop 4 49
VB.Net - TypeInitializer Error 25 32
VB.NET 2008 - Windows Protected Your PC 7 41
VB.Net. Reading xml value 6 29
It’s quite interesting for me as I worked with Excel using vb.net for some time. Here are some topics which I know want to share with others whom this might help. First of all if you are working with Excel then you need to Download the Following …
Calculating holidays and working days is a function that is often needed yet it is not one found within the Framework. This article presents one approach to building a working-day calculator for use in .NET.
In a recent question (https://www.experts-exchange.com/questions/29004105/Run-AutoHotkey-script-directly-from-Notepad.html) here at Experts Exchange, a member asked how to run an AutoHotkey script (.AHK) directly from Notepad++ (aka NPP). This video…

856 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question