diff -r 7516d6d86cf5 -r ed14f46c0e55 src/hbwidgets/widgets/hbdatetimepicker.cpp --- a/src/hbwidgets/widgets/hbdatetimepicker.cpp Mon Oct 04 17:49:30 2010 +0300 +++ b/src/hbwidgets/widgets/hbdatetimepicker.cpp Mon Oct 18 18:23:13 2010 +0300 @@ -26,66 +26,164 @@ #include "hbdatetimepicker.h" #include "hbdatetimepicker_p.h" #include "hbstyleoption_p.h" +#include "hbframeitem.h" +#include "hbstyleprimitivedata.h" +#include /*! @beta \class HbDateTimePicker - \brief HbDateTimePicker class provides a widget for picking the date, time, date and time.
+ \brief The HbDateTimePicker class provides a widget that has multiple vertical tumblers + for selecting a date, time, or date and time by flick, drag and tap gestures. + + The number of tumblers depends on the display format. The default constructor creates + a widget for selecting a date by internally setting the display format to the default + locale's short date format. Other constructors enable you to create a widget + for selecting a time or date and time by passing a QTime or QDateTime variable as an + argument. Internally these constructors set the display format to the default locale's + short time or date and time format, respectively. + + Use setDisplayFormat() to set the display format. Be aware that changing the display format + can change the widget from one for selecting the date to one for selecting the time, for + example. + + Looping is enabled in the tumblers. The general appearance of the widget depends on the + theme that is in use. + + + + + +
\image html hbdatetimepicker_date.png "Display format: d.MMMM"\image html hbdatetimepicker_time.png "Display format: h.m.AP"
- By default date picker will be created, with date functionality only. - For exclusive time or datetime picker creation, use QTime or QDateTime variable as parameter for the constructor. - \li Date and Time - \li Date - \li Time + You can set the range of values available in the tumblers by defining minimum and maximum + values or using convenience range functions. If you change the range, if necessary + the widget changes the displayed values so that they are within the new range. Users + cannot select a value outside the range. One effect of this is that if you set, + for example, an afternoon time range, users cannot scroll to the AM value when the + display format includes an AM/PM tumbler. The date range is currently independent of the + time range. + + You can use setInterval() to define the increments for the minute tumbler. This is + useful when you want users to be able to set the time in 15 minute increments, for example. + + The number of rows displayed depends on how much space is available. To change the number + of rows shown when the widget is is in a layout, for example, use + QGraphicsLayoutItem::setPreferredHeight() to increase the space available. The widget then + increases the number of rows to occupy the available space. - Below is a sample code snippet for datetime picker creation: - \snippet{ultimatecodesnippet/ultimatecodesnippet.cpp,51} + %HbDateTimePicker emits a dateChanged(), timeChanged() or dateTimeChanged() signal when + the user selects a new value. The selected date, time, or date and time value is passed + in a QDate, QTime, or QDateTime argument. + + \section _usecases_hbdatetimepicker Using HbDateTimePicker + + The following example demonstrates creating a widget for selecting a date: + + \code + // Use the default constructor to create a widget for selecting a date. + HbDateTimePicker *datePicker = new HbDateTimePicker(); + + // Set the minumum and maximum dates to display. + datePicker->setMinimumDate(QDate::currentDate()); + datePicker->setMaximumDate(QDate::currentDate().addDays(365)); - By default, display format is from HbExtendedLocale. User can set the format using setDisplayFormat API. \sa setDisplayFormat.
- Based on the display format the tumblers or sections will be rearranged.
- For each tumbler(TumbleView) in datetime picker, loopingEnabled property is always true.
+ // Specify the display format. + datePicker->setDisplayFormat("dd.MMMM.yyyy"); + \endcode + + The following example demonstrates connecting the dateChanged() signal to a slot + on an object, \a d, of a class (not shown). This has a \c setMeetingDate() function + that takes a QDate argument. + + \code + QObject::connect(datePicker, SIGNAL(dateChanged(const QDate&)), + d, SLOT(setMeetingDate(const QDate&))); + \endcode + + The following example demonstrates creating a widget for selecting a time: + + \code + // Create a widget for selecting a time. + HbDateTimePicker *timePicker = new HbDateTimePicker(QTime()); + + // Set the minimum and maximum times using the convenience range method. + timePicker->setTimeRange(QTime::currentTime(), + QTime::currentTime().addSecs(10*60*60)); + + // Set the time interval to be 15 minutes. + timePicker->setInterval(QDateTimeEdit::MinuteSection, 15); + + // Specify the display format. + timePicker->setDisplayFormat("hh:mm.ap"); + \endcode + + The following example demonstrates creating a widget for selecting a date and time: - HbDateTimePicker provides various date and time range functionalities.
- Currently the date range is independent of the time range. - \sa setDateRange \sa setTimeRange \sa setDateTimeRange - \sa setMinimumTime \sa setMaximumTime \sa setMinimumDate \sa setMaximumDate - \sa setMinimumDateTime \sa setMaximumDateTime + \code + // Create a widget for selecting a date and time. + HbDateTimePicker *dateTimePicker = + new HbDateTimePicker(QDateTime::currentDateTime()); - \image html hbdatetimepicker_date.png "Datetime picker with date functionalities, in d/MMMM format" - \image html hbdatetimepicker_time.png "Datetime picker with time functionalities, in h.m.AP format" - - Note:Graphics in the above images varies depending on theme. + // Specify the display format. + dateTimePicker->setDisplayFormat("dd.MM.yyyy.hh.mm.ap"); + \endcode + + The properties that hold the minimum and maximum values take a QDate, QTime + or QDateTime object as an argument. DocML does not directly support properties that + use QDate, QTime or QDateTime as a parameter. This means that when you add an \b %HbDateTimePicker + widget in Application Designer, you must pass the date, time and date and time to these + properties as a string in a valid ISO 8601 extended format. For example, YYYY-MM-DD for dates, + hh:mm:ss for times, and YYYY-MM-DDTHH:MM:SS for combined dates and times. + + Here is an example of the \c maximumTime property defined in DocML: + + \code + + + + + + \endcode + + \section _methodgroups_HbDateTimePicker Function groups + + \li \b Range: setDateRange(), setTimeRange(), setDateTimeRange() + \li \b Minimum \b value: setMinimumDate(), setMinimumTime(), setMinimumDateTime() + \li \b Maximum \b value: setMaximumDate(), setMaximumTime(), setMaximumDateTime() + \li \b Time \b interval: setInterval() + + \sa HbTumbleView, HbExtendedLocale */ /*! - \fn void dateChanged(const QDate &date) + \fn void HbDateTimePicker::dateChanged(const QDate &date); - This signal is emitted when item selection changes in any of the date pickers(day, month, year) in the datetimepicker widget. - - \param date selected by the user. + This signal is emitted when there is a change in the day, month or year selected. + The new date is passed in \a date. */ /*! - \fn void timeChanged(const QTime &time) + \fn void HbDateTimePicker::timeChanged(const QTime &time); - This signal is emitted when item selection changes in any of the time pickers(hour, minute, second, am/pm) in the datetimepicker widget. - \param time selected by the user. + This signal is emitted when there is a change in the hour, minute, second, or AM/PM + selected. The new time is passed in \a time. */ /*! - \fn void dateTimeChanged(const QDateTime &datetime) + \fn void HbDateTimePicker::dateTimeChanged(const QDateTime &datetime); - This signal is emitted when item selection changes in any of the date and time pickers in the datetimepicker widget. - \param datetime selected by the user. + This signal is emitted when there is a change in the value selected in any of the + tumblers in a date and time picker. The new date and time are passed in \a dateTime. */ /*! - Constructs date picker widget by default. + Constructs an %HbDateTimePicker object with the locale's default short date display format + and with parent \a parent. - \param parent parent item for datetime picker widget. */ HbDateTimePicker::HbDateTimePicker( QGraphicsItem *parent ): HbWidget(*new HbDateTimePickerPrivate, parent) @@ -99,8 +197,9 @@ } /*! - Constructs datetime picker widget with both date and time functionalities and with default locale's datetime format. - \param datetime Value to be set on datetime picker widget, which has both date and time related tumblers. + Constructs an %HbDateTimePicker object with the locale's default short date and time + display format and with parent \a parent. + */ HbDateTimePicker::HbDateTimePicker(const QDateTime &datetime, QGraphicsItem *parent ): HbWidget(*new HbDateTimePickerPrivate, parent) @@ -112,9 +211,9 @@ } /*! - Constructs datetime picker widget with only date functionalities and with default locale's date format. - - \param date QDate value. + Constructs an %HbDateTimePicker object with the locale's default short date + display format and with parent \a parent. + */ HbDateTimePicker::HbDateTimePicker(const QDate &date, QGraphicsItem *parent ): HbWidget(*new HbDateTimePickerPrivate, parent) @@ -126,9 +225,9 @@ } /*! - Constructs datetime picker widget with only time functionalities and with with default locale's time format. + Constructs an %HbDateTimePicker object with the locale's default time + display format and with parent \a parent. - \param time QTime value. */ HbDateTimePicker::HbDateTimePicker(const QTime &time, QGraphicsItem *pParent ): HbWidget(*new HbDateTimePickerPrivate, pParent) @@ -140,12 +239,13 @@ } /*! - \internal Protected constructor for derivations. - the default mode is DateTimeMode, if other mode is required, set the mDateTimeMode variable. - this does not set any default datetime, needs to be explicitly done in the derived constructor. + + The default mode is date and time. If another mode is required, set the mDateTimeMode + variable explicitly in the constructor of the class derived from HbDateTimePicker. This + does not set the default date and time value. - \sa setDateTime, setTime, setDate + \sa setDateTime(), setTime(), setDate() */ HbDateTimePicker::HbDateTimePicker(HbDateTimePickerPrivate &dd, QGraphicsItem *parent): HbWidget(dd, parent) @@ -155,18 +255,22 @@ d->init(QVariant::DateTime); } -/*! - \reimp -*/ + bool HbDateTimePicker::event(QEvent *e) -{ +{ + Q_D(HbDateTimePicker); + bool result = HbWidget::event(e); - if (e->type()==QEvent::LayoutRequest) { + if(e->type() == d->mFormatEventType){ + d->processFormatEvent(); + } + else if (e->type()==QEvent::LayoutRequest) { updatePrimitives(); } return result; } + /*! Destructor. */ @@ -175,9 +279,7 @@ } /*! - Returns current display format as QString value. - - \return display format of datetime picker widget. + Returns the current display format as a QString value. \sa setDisplayFormat() */ @@ -188,37 +290,48 @@ } /*! - Sets the display \a format . eg: DDMMYY, MMDDYY + Sets the display format using a suitable combination of the following expressions + in QString format. - These expressions may be used for the format: + These expressions may be used for the date: - - - - - - - - - - - + + + + + + + + + + + +
Expression Output
d The day as a number without a leading zero (1 to 31)
dd The day as a number with a leading zero (01 to 31)
ddd - The abbreviated localized day name (e.g. 'Mon' to 'Sun'). - Uses QDate::shortDayName().
dddd - The long localized day name (e.g. 'Monday' to 'Sunday'). - Uses QDate::longDayName().
M The month as a number without a leading zero (1 to 12)
MM The month as a number with a leading zero (01 to 12)
MMM - The abbreviated localized month name (e.g. 'Jan' to 'Dec'). - Uses QDate::shortMonthName().
MMMM - The long localized month name (e.g. 'January' to 'December'). - Uses QDate::longMonthName().
yy The year as two digit number (00 to 99)
yyyy The year as four digit number. If the year is negative, - a minus sign is prepended in addition.
Expression Output
d The day as a number without a leading zero (1 to 31).
dd The day as a number with a leading zero (01 to 31).
ddd The abbreviated localized day name (such as Mon to Sun). + Uses QDate::shortDayName().
dddd The long localized day name (such as Monday to Sunday). + Uses QDate::longDayName().
M The month as a number without a leading zero (1 to 12).
MM The month as a number with a leading zero (01 to 12).
MMM The abbreviated localized month name (such as Jan to Dec). + Uses QDate::shortMonthName().
MMMM The long localized month name (such as January to December). + Uses QDate::longMonthName().
yy The year as a two digit number (00 to 99).
yyyy The year as a four digit number. If the year is negative, + a minus sign is prepended.
+ + These expressions may be used for the time: + + + + + + + + + + + + +
Expression Output
h The hour without a leading zero (0 to 23 or 1 to 12).
hh The hour with a leading zero (00 to 23 or 01 to 12).
H The hour without a leading zero (0 to 23, even with AM/PM display).
HH The hour with a leading zero (00 to 23, even with AM/PM display).
m The minute without a leading zero (0 to 59).
mm The minute with a leading zero (00 to 59).
s The second without a leading zero (0 to 59).
ss The second with a leading zero (00 to 59).
AP or A Displays AM and PM.
ap or a Displays am and pm.
- NOTE:setDisplayFormat works only when the separators are mentioned in the format like 'dd.mm.yy' or 'dd mm yy', this - will be fixed in the future versions. - - \param format is the display format, for datetime picker widget, in QString format. + \note Currently you must include separators in the format; for example, 'dd.mm.yy'. + \note Use max upto 4 fields like hh:mm:ss:ap in the format. More than 4 fields will not be usable on typical mobile display. \sa displayFormat() */ @@ -226,34 +339,27 @@ { Q_D(HbDateTimePicker); - if(d->isFormatValid(format)){ + if(d->isFormatValid(format)){ d->mFormat = format; - d->parseDisplayFormat(format); - d->rearrangeTumbleViews(); - d->emitDateTimeChange(); - }//End If format is valid + d->postFormatEvent(); + } } /*! - Returns the current date in QDate format. - - \return current selected date in datetime picker. - - Note: The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime - as a string, in a valid ISO date format. + Returns the currently selected date in QDate format. - ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times. + \note DocML does not directly support properties that use QDate as a parameter. For these + properties, pass the date as a string in a valid ISO 8601 extended format, + such as YYYY-MM-DD. \code - ... - ... \endcode - \sa setDate + \sa setDate() */ QDate HbDateTimePicker::date() const { @@ -263,11 +369,11 @@ } /*! - Sets the current \a date in the form of QDate. + Sets the current date to \a date. - \param date date to be set on the datetime picker in QDate format + \param date The date in QDate format. - \sa date + \sa date() */ void HbDateTimePicker::setDate(const QDate& date) { @@ -276,25 +382,19 @@ } /*! - Returns minimum date in QDate format. - - \return Minimum date set on datetime picker in QDate format. - - Note: The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime - as a string, in a valid ISO date format. + Returns the minimum date in QDate format. - ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times. + \note DocML does not directly support properties that use QDate as a parameter. For these + properties, pass the date as a string in a valid ISO 8601 extended format, such as YYYY-MM-DD. \code - ... - ... \endcode - - \sa setMinimumDate + + \sa setMinimumDate() */ QDate HbDateTimePicker::minimumDate()const { @@ -303,11 +403,11 @@ } /*! - Sets minimum \a date in QDate format. + Sets the minimum date to \a date. - \param Minimum date to be set on datetime picker in QDate format. + \param date The minimum date in QDate format. - \sa minimumDate + \sa minimumDate(), setDateRange() */ void HbDateTimePicker::setMinimumDate(const QDate& date) { @@ -316,25 +416,19 @@ } /*! - Returns maximum date in QDate format. - - \return Maximum Date set on datetime picker in QDate format. - - Note: The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime - as a string, in a valid ISO date format. + Returns the maximum date in QDate format. - ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times. + \note DocML does not directly support properties that use QDate as a parameter. For these + properties, pass the date as a string in a valid ISO 8601 extended format, such as YYYY-MM-DD. \code - ... - ... \endcode - \sa setMaximumDate + \sa setMaximumDate() */ QDate HbDateTimePicker::maximumDate()const { @@ -343,11 +437,11 @@ } /*! - Sets maximum \a date in QDate format. + Sets the maximum date to \a date. - \param date Maximum date to be set on datetime picker in QDate format. + \param date The maximum date in QDate format. - \sa maximumDate + \sa maximumDate(), setDateRange() */ void HbDateTimePicker::setMaximumDate(const QDate& date) { @@ -356,12 +450,12 @@ } /*! - Sets minimum \a minDate and maximum \a maxDate dates in QDate format. This will allow user to set date range on datetime picker. + Sets the minimum and maximum dates. - \param minDate Minimum date in QDate format. - \param maxDate Maximum date in QDate format. + \param minDate The minimum date in QDate format. + \param maxDate The maximum date in QDate format. - \sa setMinimumDate \sa setMaximumDate + \sa setMinimumDate(), setMaximumDate() */ void HbDateTimePicker::setDateRange(const QDate &minDate, const QDate &maxDate) { @@ -371,25 +465,21 @@ } /*! - Returns the current date and time value, selected in datetime picker, in QDateTime format. - - \return date and time value in QDateTime format. - - Note: The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime - as a string, in a valid ISO date format. + Returns the currently selected date and time in QDateTime format. - ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times. + \note DocML does not directly support properties that use QDate, QTime or QDateTime as a + parameter. For these properties, pass the date, time or date and time as a string in a + valid ISO 8601 extended format. For example, YYYY-MM-DD for dates and YYYY-MM-DDTHH:MM:SS + for combined dates and times. \code - ... - ... \endcode - \sa setDateTime + \sa setDateTime() */ QDateTime HbDateTimePicker::dateTime()const { @@ -398,11 +488,11 @@ } /*! - Sets the current \a datetime value to be set on datetime picker in QDateTime format. + Sets the current date and time. - \param datetime in QDateTime format. + \param datetime The date and time in QDateTime format. - \sa dateTime + \sa dateTime() */ void HbDateTimePicker::setDateTime(const QDateTime &datetime) { @@ -411,25 +501,21 @@ } /*! - Returns minimum date time value set on datetime picker in QDateTime format. - - \return Minimum date and minimum time in QDateTime format. - - Note: The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime - as a string, in a valid ISO date format. + Returns the minimum date and time in QDateTime format. - ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times. + \note DocML does not directly support properties that use QDate, QTime or QDateTime as a + parameter. For these properties, pass the date, time or date and time as a string in a + valid ISO 8601 extended format. For example, YYYY-MM-DD for dates and YYYY-MM-DDTHH:MM:SS + for combined dates and times. \code - ... - ... \endcode - \sa setMinimumDateTime + \sa setMinimumDateTime() */ QDateTime HbDateTimePicker::minimumDateTime()const { @@ -438,14 +524,14 @@ } /*! - Sets minimum \a datetime for datetime picker in QDateTime format. + Sets the minimum date and time. - Note: There's no link between Date functionality and time functionality in this API. Using this API, for now, - would be similar to using a combination of setMinimumDate and setMinimumTime APIs. + \note The date and time are not linked in this API. This means that + calling this function is similar to calling setMinimumDate() and setMinimumTime(). - \param datetime minimum date and minimum time in QDateTime format. + \param datetime The minimum date and time in QDateTime format. - \sa minimumDateTime \sa setMinimumDate \sa setMinimumTime + \sa minimumDateTime(), setDateTimeRange() */ void HbDateTimePicker::setMinimumDateTime(const QDateTime& datetime) { @@ -454,25 +540,21 @@ } /*! - Returns maximum date time, set on datetime picker, in QDateTime format. - - \return Maximum date and maximum time in QDateTime format. - - Note: The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime - as a string, in a valid ISO date format. + Returns the maximum date and time in QDateTime format. - ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times. + \note DocML does not directly support properties that use QDate, QTime or + QDateTime as parameters. For these properties, pass the date, time, or date and time + as a string in a valid ISO 8601 extended format. For example, YYYY-MM-DD for dates + or YYYY-MM-DDTHH:MM:SS for combined dates and times. \code - ... - ... \endcode - \sa setMaximumDateTime + \sa setMaximumDateTime() */ QDateTime HbDateTimePicker::maximumDateTime()const { @@ -481,14 +563,14 @@ } /*! - Sets maximum \a datetime, to be set on datetime picker, in QDateTime format. + Sets the maximum date and time. - Note: There's no link between Date functionality and time functionality in this API, using this API for now - would be similar to using a combination of setMaximumDate and setMaximumTime APIs. + \note The date and time are not linked in this API. This means that + calling this function is similar to calling setMaximumDate() and setMaximumTime(). - \param date Maximum date and maximum time in QDateTime format. + \param date The maximum date and time in QDateTime format. - \sa maximumDateTime \sa setMaximumDate \sa setMaximumTime + \sa maximumDateTime(), setDateTimeRange() */ void HbDateTimePicker::setMaximumDateTime(const QDateTime& date) { @@ -497,18 +579,16 @@ } /*! - Sets minimum \a minDatetime and maximum \a maxDatetime date and time values, to be set on datetime picker, in QDateTime format. - This will allow the user to set date and time range on datetime picker. + Sets the minimum and maximum date and time. + + \note The date and time are not linked in this API. This means that calling + this function is equivalent to calling setMinimumDate(), setMaximumDate(), + setMinimumTime(), and setMaximumTime(). - Note: There's no link between Date and time in this API, using this API for now - would be similar to using a combination of setMinimumDate, setMaximumTime and - setMinimumTime, setMaximumTime APIs. + \param minDateTime The minimum date and time in QDateTime format. + \param maxDateTime The maximum date and time in QDateTime format. - \param minDateTime minimum date and time in QDateTime format. - \param maxDateTime maximum date and time in QDateTime format. - - \sa setMinimumDateTime \sa setMaximumDateTime \sa setMinimumDate \sa setMaximumDate - \sa setMinimumTime \sa setMaximumTime + \sa setMinimumDateTime(), setMaximumDateTime() */ void HbDateTimePicker::setDateTimeRange(const QDateTime &minDateTime, const QDateTime &maxDateTime) { @@ -517,25 +597,20 @@ } /*! - Returns the current time, selected in datetime picker widget, in QTime format. - - \return time in QTime format. - - Note: The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime - as a string, in a valid ISO date format. + Returns the currently selected time in QTime format. - ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times. + \note DocML does not directly support properties that use QTime as a parameter. + For these properties, pass the time as a string in a valid ISO 8601 extended format; + for example, HH:MM:SS. \code - ... - ... \endcode - \sa setTime + \sa setTime() */ QTime HbDateTimePicker::time() const { @@ -544,11 +619,11 @@ } /*! - Sets the current \a time, to be set on datetime picker widget, in QTime format. + Sets the current time to \a time. - \param time in QTime format. + \param time The time in QTime format. - \sa time + \sa time() */ void HbDateTimePicker::setTime(const QTime &time) { @@ -557,25 +632,20 @@ } /*! - Returns minimum time, set on datetime picker, in QTime format. - - \return Minimum time in QTime format. - - Note: The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime - as a string, in a valid ISO date format. + Returns the minimum time in QTime format. - ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times. + \note DocML does not directly support properties that use QTime as a parameter. + For these properties, pass the time as a string in a valid ISO 8601 extended format; + for example, HH:MM:SS. \code - ... - + - ... \endcode - \sa setMinimumTime + \sa setMinimumTime() */ QTime HbDateTimePicker::minimumTime()const { @@ -584,11 +654,11 @@ } /*! - Sets minimum \a time, to be set on datetime picker, in QTime format. + Sets the minimum time to \a time. - \param time minimum time in QTime format. + \param time The minimum time in QTime format. - \sa minimumTime + \sa minimumTime(), setTimeRange() */ void HbDateTimePicker::setMinimumTime(const QTime& time) { @@ -597,25 +667,20 @@ } /*! - Returns maximum time, set on datetime picker, in QTime format. - - \return maximum time in QTime format. + Returns the maximum time in QTime format. - Note: The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime - as a string, in a valid ISO date format. - - ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times. + \note DocML does not directly support properties that use QTime as a parameter. + For these properties, pass the time as a string in a valid ISO 8601 extended format; + for example, HH:MM:SS. \code - ... - + - ... \endcode - \sa setMaximumTime + \sa setMaximumTime() */ QTime HbDateTimePicker::maximumTime()const { @@ -624,11 +689,11 @@ } /*! - Sets maximum \a time, to be set on datetime picker, in QTime format. + Sets the maximum time to \a time. - \param time maximum time in QTime format + \param time The maximum time in QTime format. - \sa maximumTime + \sa maximumTime(), setTimeRange() */ void HbDateTimePicker::setMaximumTime(const QTime& time) { @@ -637,12 +702,12 @@ } /*! - Sets minimum \a minTime and maximum \a maxTime in QTime format. This will allow the user to set a time range on datetime picker. + Sets the minimum and maximum time. - \param minTime minimum time in QTime format. - \param maxTime maximum time in QTime format. + \param minTime The minimum time in QTime format. + \param maxTime The maximum time in QTime format. - \sa setMinimumTime \sa setMaximumTime + \sa setMinimumTime(), setMaximumTime() */ void HbDateTimePicker::setTimeRange(const QTime &minTime, const QTime &maxTime) { @@ -652,13 +717,14 @@ } /*! - Sets the \a interval or periodic gap for the corresponding \a section. + Sets the interval or periodic gap for a tumbler. Currently this is + supported for minute tumblers only. - Note: Only MinuteSection is supported at this time.
- Note: Minute interval must be a divisor of 60. Divisors of 60 are 1, 2, 3, 4, 5, 6, 10, 12, 15, 20, 30 - - \param section can be a MinuteSection. - \param interval to be set on each picker. + \param section This identifies the tumbler. This must be QDateTimeEdit::MinuteSection. + \param interval The interval to set on the tumbler. This must be a divisor of 60; that + is, 1, 2, 3, 4, 5, 6, 10, 12, 15, 20, or 30. + + \sa interval() */ void HbDateTimePicker::setInterval(QDateTimeEdit::Section section,int interval) { @@ -703,11 +769,12 @@ } /*! - returns the \a interval for the corresponding \a section. + Returns the interval set for a tumbler. Currently this is supported for + minute tumblers only. - Note: Only MinuteSection is supported at this time. + \param section Identifies the tumbler. This must be QDateTimeEdit::MinuteSection. - \return interval or duration set on a particular \a section. + \sa setInterval() */ int HbDateTimePicker::interval(QDateTimeEdit::Section section) const { @@ -717,56 +784,156 @@ } /*! - \deprecated HbDateTimePicker::primitive(HbStyle::Primitive) - is deprecated. - - \reimp -*/ -QGraphicsItem *HbDateTimePicker::primitive(HbStyle::Primitive primitive) const -{ - Q_D(const HbDateTimePicker); - switch(primitive) { - case HbStyle::P_DateTimePicker_background: - return d->mBackground; - - case HbStyle::P_DateTimePicker_frame: - return d->mFrame; - - case HbStyle::P_TumbleView_highlight: - return d->mHighlight; - - default: - return HbWidget::primitive(primitive); - } -} - -/*! - \reimp + Reimplemented from QGraphicsWidget::setGeometry(). */ void HbDateTimePicker::setGeometry(const QRectF &rect) { HbWidget::setGeometry(rect); updatePrimitives(); + Q_D(HbDateTimePicker); + + for(int i=0;imParser.mSectionNodes.count();i++) { + switch(d->mParser.mSectionNodes[i].type) { + case HbDateTimeParser::AmPmSection: + if(!d->mAmPmPicker){ + break; + } + break; + + case HbDateTimeParser::DaySection: + case HbDateTimeParser::DayOfWeekSection: + if(!d->mDayPicker){ + break; + } + d->mLabelDay->setPreferredWidth(d->mDayPicker->preferredSize().width()); + break; + + case HbDateTimeParser::MonthSection: + if(!d->mMonthPicker){ + break; + } + d->mLabelMonth->setPreferredWidth(d->mMonthPicker->preferredSize().width()); + break; + + case HbDateTimeParser::YearSection: + case HbDateTimeParser::YearSection2Digits: + if(!d->mYearPicker){ + break; + } + + d->mLabelYear->setPreferredWidth(d->mYearPicker->preferredSize().width()); + break; + + case HbDateTimeParser::SecondSection: + if(!d->mSecondPicker){ + break; + } + + d->mLabelSecond->setPreferredWidth(d->mSecondPicker->preferredSize().width()); + break; + + case HbDateTimeParser::MinuteSection: + if(!d->mMinutePicker){ + break; + } + d->mLabelMinute->setPreferredWidth(d->mMinutePicker->preferredSize().width()); + break; + + case HbDateTimeParser::Hour12Section: + case HbDateTimeParser::Hour24Section: + if(!d->mHourPicker){ + break; + } + d->mLabelHour->setPreferredWidth(d->mHourPicker->preferredSize().width()); + break; + + default: + break; + } + } + } -/*! - \reimp -*/ +void HbDateTimePicker::initPrimitiveData(HbStylePrimitiveData *primitiveData, const QGraphicsObject *primitive) +{ + HbWidget::initPrimitiveData(primitiveData, primitive); + QString itemName = HbStyle::itemName(primitive); + if(itemName == QLatin1String("background")) { + HbStyleFramePrimitiveData *frameItem = hbstyleprimitivedata_cast(primitiveData); + frameItem->frameGraphicsName= QLatin1String("qtg_fr_tumbler_bg"); + frameItem->frameType = HbFrameDrawer::NinePieces; + (const_cast (primitive))->setZValue(-5); + } + + if(itemName == QLatin1String("frame")) { + HbStyleFramePrimitiveData *frameItem = hbstyleprimitivedata_cast(primitiveData); + frameItem->frameGraphicsName= QLatin1String("qtg_fr_tumbler_overlay"); + frameItem->frameType = HbFrameDrawer::NinePieces; + (const_cast (primitive))->setZValue(1); + + } + if(itemName == QLatin1String("highlight")) { + HbStyleFramePrimitiveData *frameItem = hbstyleprimitivedata_cast(primitiveData); + frameItem->frameGraphicsName= QLatin1String("qtg_fr_tumbler_highlight_pri"); + frameItem->frameType = HbFrameDrawer::ThreePiecesHorizontal; + (const_cast (primitive))->setZValue(-1); + + } + +} + void HbDateTimePicker::updatePrimitives() { Q_D(HbDateTimePicker); - HbStyleOption option; - initStyleOption(&option); + HbWidget::updatePrimitives(); + if(d->mBackground) { - style()->updatePrimitive(d->mBackground,HbStyle::P_DateTimePicker_background,&option); + HbStyleFramePrimitiveData data; + initPrimitiveData(&data,d->mBackground); + style()->updatePrimitive(d->mBackground,&data,this); + if(!d->mLastAdded.isNull()){ + QRectF geom = ((HbFrameItem*)d->mBackground)->geometry(); + ((HbFrameItem*)d->mBackground)->setGeometry(geom.x(), d->mLastAdded->pos().y(), geom.width(), d->mLastAdded->size().height()); + } } + if(d->mFrame) { - style()->updatePrimitive(d->mFrame,HbStyle::P_DateTimePicker_frame,&option); + HbStyleFramePrimitiveData data; + initPrimitiveData(&data,d->mFrame); + style()->updatePrimitive(d->mFrame,&data,this); + if(!d->mLastAdded.isNull()){ + QRectF geom = ((HbFrameItem*)d->mFrame)->geometry(); + ((HbFrameItem*)d->mFrame)->setGeometry(geom.x(), d->mLastAdded->pos().y(), geom.width(), d->mLastAdded->size().height()); + } } if(d->mHighlight) { - style()->updatePrimitive(d->mHighlight,HbStyle::P_TumbleView_highlight,&option); + HbStyleFramePrimitiveData data; + initPrimitiveData (&data,d->mHighlight); + style()->updatePrimitive(d->mHighlight,&data,this); + if(!d->mLastAdded.isNull()){ + qreal top = d->mLastAdded->pos().y() + d->mLastAdded->size().height()/2 - ((HbFrameItem*)d->mHighlight)->geometry().height()/2; + d->mHighlight->setPos(d->mHighlight->pos().x(), top); + } + } } +QGraphicsItem *HbDateTimePicker::primitive(const QString &itemName) const +{ + Q_D(const HbDateTimePicker); + + if(!itemName.compare(QString("background"))){ + return d->mBackground; + } + if(!itemName.compare(QString("frame"))){ + return d->mFrame; + } + if(!itemName.compare(QString("highlight"))){ + return d->mHighlight; + } + + return HbWidget::primitive(itemName); +} + #include "moc_hbdatetimepicker.cpp"