PhoneGap + HTML5 + jqueryMobile Android-DATE control, phonegap-date

Source: Internet
Author: User

PhoneGap + HTML5 + jqueryMobile Android-DATE control, phonegap-date

Original article: Android-DATE control developed by PhoneGap + HTML5 + jqueryMobile

Source code: http://www.zuidaima.com/share/1550463778802688.htm

The DATE control cannot normally call Android's DATE Keyboard Under Android. You need to use PhoneGap to call Android's native control, but it still does not achieve the best effect and finds a temporary solution, I would like to share with you that if you have a better solution, you can share with you that this method has a defect that the time control cannot be called when the control has a value.

/** *  */package com.phonegap.plugins;import java.util.Calendar;import java.util.Date;import org.json.JSONArray;import org.json.JSONException;import org.json.JSONObject;import android.app.DatePickerDialog;import android.app.DatePickerDialog.OnDateSetListener;import android.app.TimePickerDialog;import android.app.TimePickerDialog.OnTimeSetListener;import android.content.Context;import android.util.Log;import android.widget.DatePicker;import android.widget.TimePicker;import org.apache.cordova.api.CallbackContext;import org.apache.cordova.api.CordovaPlugin;/** * @author ng4e www.zuidaima.com * @author Daniel van 't Oever *  *         Rewrote plugin so it it similar to the iOS datepicker plugin and it *         accepts prefilled dates and time */public class DatePickerPlugin extends CordovaPlugin {private static final String ACTION_DATE = "date";private static final String ACTION_TIME = "time";private final String pluginName = "DatePickerPlugin";    @Overridepublic boolean execute(String action, JSONArray args, CallbackContext callbackContext) {Log.d(pluginName, "DatePicker called with options: " + args);return this.show(args, callbackContext);}public synchronized boolean show(final JSONArray data, final CallbackContext callbackContext) {final Calendar c = Calendar.getInstance();final Runnable runnable;final Context currentCtx = cordova.getActivity();final DatePickerPlugin datePickerPlugin = this;String action = "date";/* * Parse information from data parameter and where possible, override * above date fields */int month = -1, day = -1, year = -1, hour = -1, min = -1;try {JSONObject obj = data.getJSONObject(0);action = obj.getString("mode");String optionDate = obj.getString("date");String[] datePart = optionDate.split("/");month = Integer.parseInt(datePart[0]);day = Integer.parseInt(datePart[1]);year = Integer.parseInt(datePart[2]);hour = Integer.parseInt(datePart[3]);min = Integer.parseInt(datePart[4]);/* currently not handled in Android */// boolean optionAllowOldDates = obj.getBoolean("allowOldDates");} catch (JSONException e) {e.printStackTrace();}// By default initalize these fields to 'now'final int mYear = year == -1 ? c.get(Calendar.YEAR) : year;final int mMonth = month == -1 ? c.get(Calendar.MONTH) : month - 1;final int mDay = day == -1 ? c.get(Calendar.DAY_OF_MONTH) : day;final int mHour = hour == -1 ? c.get(Calendar.HOUR_OF_DAY) : hour;final int mMinutes = min == -1 ? c.get(Calendar.MINUTE) : min;if (ACTION_TIME.equalsIgnoreCase(action)) {runnable = new Runnable() {public void run() {final TimeSetListener timeSetListener = new TimeSetListener(datePickerPlugin, callbackContext);final TimePickerDialog timeDialog = new TimePickerDialog(currentCtx, timeSetListener, mHour,mMinutes, true);timeDialog.show();}};} else if (ACTION_DATE.equalsIgnoreCase(action)) {runnable = new Runnable() {public void run() {final DateSetListener dateSetListener = new DateSetListener(datePickerPlugin, callbackContext);final DatePickerDialog dateDialog = new DatePickerDialog(currentCtx, dateSetListener, mYear,mMonth, mDay);dateDialog.show();}};} else {Log.d(pluginName, "Unknown action. Only 'date' or 'time' are valid actions");return false;}cordova.getActivity().runOnUiThread(runnable);return true;}private final class DateSetListener implements OnDateSetListener {private final DatePickerPlugin datePickerPlugin;private final CallbackContext callbackContext;private DateSetListener(DatePickerPlugin datePickerPlugin, CallbackContext callbackContext) {this.datePickerPlugin = datePickerPlugin;this.callbackContext = callbackContext;}/** * Return a string containing the date in the format YYYY/MM/DD */public void onDateSet(final DatePicker view, final int year, final int monthOfYear, final int dayOfMonth) {String returnDate = year + "/" + (monthOfYear + 1) + "/" + dayOfMonth;callbackContext.success(returnDate);}}private final class TimeSetListener implements OnTimeSetListener {private final DatePickerPlugin datePickerPlugin;private final CallbackContext callbackContext;private TimeSetListener(DatePickerPlugin datePickerPlugin, CallbackContext callbackContext) {this.datePickerPlugin = datePickerPlugin;this.callbackContext = callbackContext;}/** * Return the current date with the time modified as it was set in the * time picker. */public void onTimeSet(final TimePicker view, final int hourOfDay, final int minute) {Date date = new Date();date.setHours(hourOfDay);date.setMinutes(minute);callbackContext.success(date.toLocaleString());}}}


Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.