• android日历调用首先第一步我们要添加权限
  <uses-permission android:name="android.permission.READ_CALENDAR" />
<uses-permission android:name="android.permission.WRITE_CALENDAR" />
  • 接着我们书写js调用接口
var calendar = {
add: function (success, data) {
exec(success, null, "Calendar", "add", [data]);
},
open:function(success, data){
exec(success, null, "Calendar", "open", [data]);
} }; module.exports = calendar;
  • 这两个方法一个add是后台添加到日历数据库,一个打开日历,然后调用系统日历添加

由于android存在版本兼容我们要添加

if (Build.VERSION.SDK_INT >=8) {
calanderURL = "content://com.android.calendar/calendars";
calanderEventURL = "content://com.android.calendar/events";
calanderRemiderURL = "content://com.android.calendar/reminders"; } else {
calanderURL = "content://calendar/calendars";
calanderEventURL = "content://calendar/events";
calanderRemiderURL = "content://calendar/reminders";
}
  • android的日历存储有多个用户,但是系统默认一般会第一个
Cursor userCursor = cordova.getActivity().getContentResolver()
.query(Uri.parse(calanderURL), null, null, null, null);
if (userCursor.getCount() > 0) {
userCursor.moveToFirst();
calId = userCursor.getString(userCursor.getColumnIndex("_id"));
}
  • android后台添加日历参数,这个时候我们一般调用phonegap线程写法,不会影响ui
private void Add(final JSONObject sData, final CallbackContext context) {
cordova.getThreadPool().execute(new Runnable() {
public void run() {
try {
ContentValues event = new ContentValues();
Log.v(TAG, sData.getString("dtstart"));
event.put("calendar_id", calId);
event.put(Events.TITLE, sData.getString("title"));
event.put(Events.EVENT_LOCATION,
sData.getString("location"));
event.put(Events.DESCRIPTION,
sData.getString("description"));
event.put(Events.DTSTART, sData.getLong("dtstart"));
event.put(Events.DTEND, sData.getLong("dtend"));
event.put("eventTimezone", TimeZone.getDefault().getID());
Uri url = cordova.getActivity().getContentResolver()
.insert(Uri.parse(calanderEventURL), event);
long id = Long.parseLong(url.getLastPathSegment());
ContentValues values = new ContentValues();
values.put("event_id", id);
// 提前10分钟有提醒
values.put("minutes", 10);
values.put("method", 1);
cordova.getActivity().getContentResolver()
.insert(Uri.parse(calanderRemiderURL), values);
} catch (JSONException e) {
e.printStackTrace();
}
context.success(); // Thread-safe.
}
});
}
  • 如何调用android弹出系统添加页面了
private void Open() {
Uri uri = Uri.parse(calanderEventURL);
Intent intent = new Intent("android.intent.action.INSERT", uri);
lastId = GetLastId();
cordova.startActivityForResult((CordovaPlugin) this, intent, 1); }
  • 因为调用系统添加日历我们无法知道我们添加的状态,我们只能判断日历事件表最大id的是否变化
  • 接下来提供详细java代码
package com.triedtech.triedapp.plugins.calendar;

import java.util.TimeZone;

import org.apache.cordova.CallbackContext;
import org.apache.cordova.CordovaPlugin;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject; import android.content.ContentValues;
import android.content.Intent;
import android.database.Cursor;
import android.net.Uri;
import android.os.Build; import android.provider.CalendarContract.Events;
import android.util.Log; public class Calendar extends CordovaPlugin {
public static final Integer RESULT_CODE_CREATE = 0;
private static String calanderURL = "";
private static String calanderEventURL = "";
private static String calanderRemiderURL = "";
private String TAG = "calendar";
public int isInit = 0;
public int lastId = 0;
private String calId;
private CallbackContext callbackContext; public boolean execute(String action, JSONArray args,
CallbackContext callbackContext) throws JSONException {
this.callbackContext = callbackContext;
initConfig();
if (action.equals("add")) { JSONObject sData = args.getJSONObject(0);
this.Add(sData, callbackContext);
return true;
} else if (action.equals("open")) {
Open();
return true;
}
return false;
} private void initConfig() {
if (isInit == 0) {
if (Build.VERSION.SDK_INT >=8) {
calanderURL = "content://com.android.calendar/calendars";
calanderEventURL = "content://com.android.calendar/events";
calanderRemiderURL = "content://com.android.calendar/reminders"; } else {
calanderURL = "content://calendar/calendars";
calanderEventURL = "content://calendar/events";
calanderRemiderURL = "content://calendar/reminders";
}
Cursor userCursor = cordova.getActivity().getContentResolver()
.query(Uri.parse(calanderURL), null, null, null, null);
if (userCursor.getCount() > 0) {
userCursor.moveToFirst();
calId = userCursor.getString(userCursor.getColumnIndex("_id"));
}
isInit = 1;
}
} private void Add(final JSONObject sData, final CallbackContext context) {
cordova.getThreadPool().execute(new Runnable() {
public void run() {
try {
ContentValues event = new ContentValues();
Log.v(TAG, sData.getString("dtstart"));
event.put("calendar_id", calId);
event.put(Events.TITLE, sData.getString("title"));
event.put(Events.EVENT_LOCATION,
sData.getString("location"));
event.put(Events.DESCRIPTION,
sData.getString("description"));
event.put(Events.DTSTART, sData.getLong("dtstart"));
event.put(Events.DTEND, sData.getLong("dtend"));
event.put("eventTimezone", TimeZone.getDefault().getID());
Uri url = cordova.getActivity().getContentResolver()
.insert(Uri.parse(calanderEventURL), event);
long id = Long.parseLong(url.getLastPathSegment());
ContentValues values = new ContentValues();
values.put("event_id", id);
// 提前10分钟有提醒
values.put("minutes", 10);
values.put("method", 1);
cordova.getActivity().getContentResolver()
.insert(Uri.parse(calanderRemiderURL), values);
} catch (JSONException e) {
e.printStackTrace();
}
context.success(); // Thread-safe.
}
});
} private int GetLastId() {
Cursor userCursor = cordova
.getActivity()
.getContentResolver()
.query(Uri.parse(calanderEventURL), null,
Events.CALENDAR_ID + " =" + calId, null,
Events._ID + " desc limit 1");
if (userCursor.getCount() > 0) {
userCursor.moveToFirst();
String event_id = userCursor.getString(userCursor
.getColumnIndex(Events._ID));
userCursor.close();
return Integer.parseInt(event_id);
}
return 0;
} private void Open() {
Uri uri = Uri.parse(calanderEventURL);
Intent intent = new Intent("android.intent.action.INSERT", uri);
lastId = GetLastId();
cordova.startActivityForResult((CordovaPlugin) this, intent, 1); } private JSONObject LastRecord() throws JSONException{
Cursor userCursor = cordova
.getActivity()
.getContentResolver()
.query(Uri.parse(calanderEventURL), null,
Events.CALENDAR_ID + " =" + calId, null,
Events._ID + " desc limit 1");
userCursor.moveToFirst();
String event_id = userCursor.getString(userCursor
.getColumnIndex(Events._ID));
JSONObject record = new JSONObject();
Log.v(TAG, userCursor.getString(userCursor.getColumnIndex(Events.TITLE)));
record.put("dtstart", userCursor.getString(userCursor.getColumnIndex(Events.DTSTART)));
record.put("dtend", userCursor.getString(userCursor.getColumnIndex(Events.DTEND)));
record.put("id", userCursor.getString(userCursor.getColumnIndex(Events._ID)));
record.put("location", userCursor.getString(userCursor.getColumnIndex(Events.EVENT_LOCATION)));
record.put("title", userCursor.getString(userCursor.getColumnIndex(Events.TITLE)));
record.put("description", userCursor.getString(userCursor.getColumnIndex(Events.DESCRIPTION)));
userCursor.close(); return record;
} /**
* Called when the calendar view exits.
*
* @param requestCode
* The request code originally supplied to
* startActivityForResult(), allowing you to identify who this
* result came from.
* @param resultCode
* The integer result code returned by the child activity through
* its setResult().
* @param intent
* An Intent, which can return result data to the caller (various
* data can be attached to Intent "extras").
*/
public void onActivityResult(int requestCode, int resultCode, Intent intent) {
Log.v(TAG,String.valueOf(lastId));
Log.v(TAG,String.valueOf(GetLastId()));
if (lastId != GetLastId()) {
try {
Log.v(TAG,"执行");
this.callbackContext.success(LastRecord());
} catch (JSONException e) {
e.printStackTrace();
}
}
} }

phonegap之android原生日历调用的更多相关文章

  1. uni-app&H5&Android混合开发三 || uni-app调用Android原生方法的三种方式

    前言: 关于H5的调用Android原生方法的方式有很多,在该片文章中我主要简单介绍三种与Android原生方法交互的方式. 一.H5+方法调用android原生方法 H5+ Android开发规范官 ...

  2. PhoneGap或者Cordova框架下实现Html5中JS调用Android原生代码

    PhoneGap或者Cordova框架下实现Html5中JS调用Android原生代码 看看新闻网>看引擎>开源产品 0人收藏此文章, 发表于8小时前(2013-09-06 00:39) ...

  3. Android移动APP开发笔记——Cordova(PhoneGap)通过CordovaPlugin插件调用 Activity 实例

    引言 Cordova(PhoneGap)采用的是HTML5+JavaScript混合模式来开发移动手机APP,因此当页面需要获取手机内部某些信息时(例如:联系人信息,坐标定位,短信等),程序就需要调用 ...

  4. Flutter学习(9)——Flutter插件实现(Flutter调用Android原生

    原文地址: Flutter学习(9)--Flutter插件实现(Flutter调用Android原生) | Stars-One的杂货小窝 最近需要给一个Flutter项目加个apk完整性检测,需要去拿 ...

  5. React Native Android原生模块开发实战|教程|心得|怎样创建React Native Android原生模块

    尊重版权,未经授权不得转载 本文出自:贾鹏辉的技术博客(http://blog.csdn.net/fengyuzhengfan/article/details/54691503) 告诉大家一个好消息. ...

  6. Android原生游戏开发:使用JustWeEngine开发微信打飞机

    使用JustWeEngine开发微信打飞机: 作者博客: 博客园 引擎地址:JustWeEngine 示例代码:EngineDemo JustWeEngine? JustWeEngine是托管在Git ...

  7. 基于命令行编译打包phonegap for android应用 分类: Android Phonegap 2015-05-10 10:33 73人阅读 评论(0) 收藏

    也许你习惯了使用Eclipse编译和打包Android应用.不过,对于使用html5+js开发的phonegap应用,本文建议你抛弃Eclipse,改为使用命令行模式,绝对的快速和方便. 一直以来,E ...

  8. 使用 Eclipse PhoneGap 构建 Android 应用程序入门

    Eclipse 是一种支持多种技术的开源集成开发环境 (IDE),但本文重点介绍 Java 支持,这也是 Android 应用程序的“母语”.Android 是 Google 发布的开源移动操作系统. ...

  9. [Android Pro] android 4.4 Android原生权限管理:AppOps

    reference : http://m.blog.csdn.net/blog/langzxz/45308199 reference : http://blog.csdn.net/hyhyl1990/ ...

随机推荐

  1. 为自己的爬虫更换代理和HTML头部

    import requestsimport reimport randomimport time class download(): def __init__(self): self.iplist = ...

  2. 1 云计算系列之云计算概述和KVM虚拟化简介

    为什么会出现云之传统数据中学面临的问题 物理服务器的利用率非常低,浪费资源,且资源分配不合理,比如一台服务器CPU使用率不到40%,或者某个应用需要的硬件配置低但是服务器硬件配置高等等. 云计算概念 ...

  3. top命令

    TOP是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前台,直到用户终止该程序为止.比较准确的说,top命令提供了实时的对系统处理器的状态监视.它将显示系统中C ...

  4. 测试dns

    测试dns nslookup test.cn 10.109.68.114 ipconfig /flushdns dig test.cn @10.109.68.114 sudo /etc/init.d/ ...

  5. python程序一直在后台运行的解决办法

    刚写了个python程序,要一直在后台运行,即使断开ssh进程也在,下面是解决办法: 假如Python程序为test.py 编写shell脚本start.sh #!/bin/bash python t ...

  6. mysql中binlog_format模式与配置详解

    mysql复制主要有三种方式:基于SQL语句的复制(statement-based replication, SBR),基于行的复制(row-based replication, RBR),混合模式复 ...

  7. Access应用笔记<四>-一个完整的自动化报表搭建过程

    距离之前的三篇日志已经很久啦,今天终于完成了一个比较完整的自动化报表搭建过程 基于公司数据保密原则,样板就不放到网上来了,简单说一下背景: 这次access实现的功能包括: 1)为部门整体搭建了一个员 ...

  8. Mongodb profile(慢查询日志)

    在MySQL中,慢查询日志是经常作为我们优化数据库的依据,那在MongoDB中是否有类似的功能呢?答案是肯定的,那就是MongoDB Database Profiler.所以MongoDB 不仅有,而 ...

  9. Linux C 字符串函数 strlen()、strcat()、strncat()、strcmp()、strncmp()、strcpy()、strncpy() 详解

      strlen(返回字符串长度) 表头文件 #include <string.h> 定义函数 size_t strlen(const char *s); 函数说明 strlen()用来计 ...

  10. css特殊字符总结

    < :    &lt > :    &gt