Click here to Skip to main content
13,351,225 members (67,225 online)
Click here to Skip to main content
Add your own
alternative version


17 bookmarked
Posted 11 Apr 2007

Composite Date & Time Control

, 11 Apr 2007
Rate this:
Please Sign up or sign in to vote.
A control showing both date and time

Screenshot - CompositeDateTime_pic.jpg


This control displays the combined date and time, with calendar dropdown and updown arrows. It is basically two DatePicker controls merged using a SplitContainer. The splitter bar can be adjusted to give more room to either side.

This is my first attempt at such a control, so if there is another way, I'm open to suggestions.


The DatePicker control can display only date or time values. I currently use a combined date/time control in our MFC apps (BCGDateTime). When I moved to VS 2005, I couldn't find one written for .NET, so I tackled this.

Adding the control

Use Add Reference to add a reference to the DateAndTimeControls assembly in your project.

Add the control to the toolbox by right-clicking in a category and using Choose Items.

Screenshot - choose_item.jpg

Drag the control onto the form. The properties panel shows the new properties and events:

  • DateTimeValue - the default property of the control.
  • DateValue - just the date value of the control
  • TimeValue - just the time value of the control>
  • MinDate - the minimum date/time value for the control
  • MaxDate - the maximum date/time value for the control
  • DateFormat - the enumerated datepicker format value (ie long)
  • DateCustom - the custom format mask (ie dd-MMM-yyyy)
  • TimeFormat - the enumerated DatePicker format value (ie time)
  • TimeCustom - the custom format mask (ie hh:mi tt)
  • ValueChanged - the default event for the control. fired whenever the value is changed.

Using the control

To get a value from the control:

dim dt as Date
dt = DateTimeControl1.DateTimeValue
tTextbox1.Text = dt.ToString("dd-mmm-yyyy hh:mi tt")

To put a value in the control:

DateTimeControl1.DateTimeValue = Date.Now


Date.TryParse(TextBox1.Text, DateTimeControl1.DateTimeValue)

The constructor will give an error if the date is outside the MinDate-MaxDate range.

To clear the control:

DateTimeControl1.DateTimeValue = new Date(0L)

The date can also be cleared by typing <Backspace> in the control.

Points of Interest

Thanks to this project, I learned how to expose new class events to the outside world.


This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


About the Author

Richard Jones
Web Developer
Canada Canada
I have been developing applications at City of Moncton since 1992. My focus has been on C/C++ along with Oracle and SQL/Plus.

I've been tainted with Oracle Developer, and Palm development. ick.

I am actively developing in .NET 2015.

You may also be interested in...


Comments and Discussions

GeneralCant use in Web Application Pin
satejprabhu18-Oct-07 20:34
membersatejprabhu18-Oct-07 20:34 
GeneralRe: Cant use in Web Application [links are flipped] Pin
Richard Jones19-Oct-07 3:11
memberRichard Jones19-Oct-07 3:11 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

Permalink | Advertise | Privacy | Terms of Use | Mobile
Web03 | 2.8.180111.1 | Last Updated 11 Apr 2007
Article Copyright 2007 by Richard Jones
Everything else Copyright © CodeProject, 1999-2018
Layout: fixed | fluid