VC界面Calendar Control使用教程:如何使用日历控件自定义数据提供程序

翻译|使用教程|编辑:鲍佳佳|2020-07-03 17:43:18.270|阅读 18 次

概述:本文介绍如何对日历控件使用自定义数据源。它是基于标准的Visual Basic CalendarSample应用程序中包含的MySQL数据库提供程序示例进行描述的。

# 您正在找协同办公软件吗?点击这里站长给您推荐 #

背景

日历控件具有对以下数据提供程序的内置支持:内存,XML文件(或二进制文件),数据库(访问),MAPI(Outlook)。
但是,许多人已经有自己的数据来源,可以在“日历”窗口中显示数据。这可能是不支持Codejock Calendar数据库模型的旧数据库,可能是特定的数据库服务器(Microsoft SQL Server,MySQL,FoxPro等),甚至可能是指定数据对象的自定义内存数组,而该数组已经具有自己的加载/保存代码。

另一个问题是如何允许多人在不同的工作站上同时处理同一组约会(请注意,使用所描述的解决方案可能只会部分解决此问题)。

第三个问题是当人们拥有大量约定数据并且怀疑所有数据同时保存在内存中时可能会出现问题。

通过实施自定义日历数据提供程序,可以解决所有这些问题。

简单的解决方案-自定义加载/保存事件代码

首先让我们考虑一个最简单的情况-您有一个旧数据库,只想在单个工作站上使用它,并且想用相应的工具栏按钮打开并保存所有更改(或其他方式,主要思想是数据库并不总是与日历上显示的数据库同步)。

在这种情况下,正确的解决方案是根本不使用自定义数据提供程序:

您所需要做的就是使用标准的内存数据提供程序,该程序默认情况下是通过Calendar控件创建的。当然,它可以序列化为XML文件,但是如果您不提供文件名,那么Memory DataProvider将会成为您的事件的简单存储。您必须用事件填充日历,然后允许用户使用它们,并在保存时通过迭代所有日历事件来更新数据库中的所有数据。这可能以以下方式显示:

加载:
'加载事件
Sub Populate()
        objCalendar.DataProvider.RemoveAllEvents '<打开事件记录集或集合> '<迭代此集合> 对于 objEventsCollection 中的每个 objEvent
         设置 objCalendarEvent = objCalendar.DataProvider.CreateEventEx(objEvent.ID)
        objCalendarEvent.StartTime = .. 。
        ... 
        objCalendar.DataProvider.AddEvent objCalendarEvent    下一页 
    objCalendar.Populate 结束小组
保存:
“迭代事件和保存到数据库
私人 小组保存()
     昏暗 objEvent 作为 CalendarEvent
     对于 每个 objEvent 在 objCalendar.DataProvider.GetAllEventsRaw
         ” <节省事件属性> 
        “objEvent.Id 
        ‘objEvent.Subject 
    接着
    ’<提交节省> 
结束 子
复杂的解决方案-定制数据提供者
    CalendarControl.SetDataProvider“ Provider =自定义;”
当您拥有自己要显示的数据源(例如DB或内存集合),约定记录众多或想要具有多用户工作环境时,需要自定义数据提供程序。

已经有几个标准示例可用(用于MS SQL Server和MySQL)。

简要介绍其工作原理:它要求您在数据源中创建/读取/更新日历事件。设置“自定义数据提供程序-日历”时,您可以发送一些通知,以捕获和处理数据操作:例如从数据库读取事件数据并填充日历事件对象成员或更新/创建/删除数据库记录。
您可以使用任何数据库或其他自定义数据存储(例如对象数组等)。
使用自定义数据提供程序,您应该实现的主要内容是RetrieveDayEvents处理程序的主体。如果返回空事件集合,则控件将始终不显示任何内容。
要实现的第二件事是DoXXX处理程序的主体。有关详细的代码示例,请参见VB CalendarSample,类providerMySQL.cls和providerSQLServer.cls。

创建一个新事件:
Private  Sub Calendar_DoCreateEvent(ByVal pEvent As _ 
            XtremeCalendarControl.CalendarEvent,NewEventID _ As Long,bResult As Boolean)
     '1)从pEvent获取属性'2)准备并执行相应的SQL语句,该语句将'新事件添加到数据库中'3)如果数据库有自动递增的事件ID字段,检索“它一个新的事件,并分配到NewEventID ” 4)集bResult为true,如果一切操作顺利完     结束小组
关于递归
当自定义数据提供程序要求您读取事件或事件集时,您必须仅读取具有“ notRecurring”或“ master”重复状态的事件。

加载重复模式时,还必须加载和设置与此模式相关的所有日历事件异常。

正在加载重复发生master事件

当您读取具有“master”重复状态的日历事件对象并将其返回给自定义数据提供程序时,有一个技巧。

日历事件对象有2个特殊的自定义属性:“ process_RecurrenceState”和“ process_RecurrencePatternID”。它们用于处理master事件。如果设置了它们,并且RecurrenceState为“ master”,则自定义数据提供程序将触发DoReadRPattern事件,并将该事件作为Master。并且还将为RetrieveDayEvents方法生成事件。这些属性是临时的,它们将被数据提供者删除。

如果未设置这些属性–但是自定义数据提供者期望主事件已经完成-调用CreateRecurrence方法并设置重复模式。

当事件和模式分别存储在不同的表中时,此机制对于DB数据提供程序很有用。

但是,如果事件存储在某个内存集合或数组中,则不应使用它,因为主事件在内部存储了重复模式。

点击下载Xtreme Calendar最新试用版

对此产品有任何疑问,欢迎咨询慧都在线客服>>



标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,尊重他人劳动成果

登录 慧都网发表评论


暂无评论...

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
在线
客服
咨询
电话
400-700-1020
在线
QQ
购物车 反馈 返回
顶部
在线客服系统
live chat