获取电话记录,phone.h

void GetPhoneNumberCallLog()
{
TCHAR LastIncomingCall[40];
TCHAR LastMissedCall[40];
TCHAR LastOutGoingCall[40];

TCHAR LastIncomingCallName[256];
TCHAR LastMissedCallName[256];
TCHAR LastOutGoingCallName[256];

HANDLE ph;
CALLLOGENTRY entry;
DWORD count;
entry.cbSize = sizeof(CALLLOGENTRY);
if(PhoneOpenCallLog(&ph)== S_OK)
{
   if(S_OK == PhoneSeekCallLog(ph, CALLLOGSEEK_BEGINNING, 0, &count))

//如果用CALLLOGSEEK_END那么count得到是的全部记录的个数

//如果用CALLLOGSEEK_BEGINNING那么count得是0
   {
    int lastIncallFlag = 0;
    int lastMissedCallFlag = 0;
    int lastOutgoingCallFlag = 0;

    while(PhoneGetCallLogEntry(ph, &entry) == S_OK)
    {
     if(( !lastIncallFlag)&&(entry.iom != IOM_OUTGOING) && (!entry.fOutgoing) )
     {
      //MessageBox(NULL, entry.pszNumber, TEXT("Last Incoming Call"), 0);
      lstrcpy(LastIncomingCall,   entry.pszNumber);
      if(!entry.pszName)
       lstrcpy(LastIncomingCallName,   TEXT("Unknow"));
      else
       lstrcpy(LastIncomingCallName,   entry.pszName);
      MessageBox(NULL,LastIncomingCall,LastIncomingCallName,0);
      lastIncallFlag = 1;
     }
     if(( !lastMissedCallFlag) && (entry.iom == IOM_MISSED))
     {
      lstrcpy(LastMissedCall,   entry.pszNumber);
      if(!entry.pszName)
       lstrcpy(LastMissedCallName,   TEXT("Unknow"));
      else
       lstrcpy(LastMissedCallName,   entry.pszName);
      MessageBox(NULL,LastMissedCall,LastMissedCallName,0);
      lastMissedCallFlag = 1;
     }
     if(( !lastOutgoingCallFlag) && (entry.iom == IOM_OUTGOING))
     {
      lstrcpy(LastOutGoingCall,   entry.pszNumber);
      if(!entry.pszName)
       lstrcpy(LastOutGoingCallName,   TEXT("Unknow"));
      else
       lstrcpy(LastOutGoingCallName,   entry.pszName);
      MessageBox(NULL,LastOutGoingCall,LastOutGoingCallName,0);
      lastOutgoingCallFlag = 1;
     }

     // Make phone
      /* PHONEMAKECALLINFO phonemakecall;
      phonemakecall.cbSize = sizeof(PHONEMAKECALLINFO);
      phonemakecall.dwFlags = PMCF_PROMPTBEFORECALLING;
      phonemakecall.pszDestAddress = entry.pszNumber;
      phonemakecall.pszAppName = NULL;
      phonemakecall.pszCalledParty = NULL;
      phonemakecall.pszComment = NULL;
      PhoneMakeCall(&phonemakecall);*/
    }

    //Show the call log filter
    //PhoneShowCallLog(CALLLOGFILTER_OUTGOING);
   }
}
PhoneCloseCallLog (ph);

}

打开phone.h发现在WM5.0上有两个两个函数在SDK里是没有的

第一个是

HRESULT PhoneAddSpeedDial(DWORD dwFlags, DWORD* piKey, const TCHAR* pszDisplayName, const TCHAR* pszTelNumber);

第二个是

HRESULT PhoneShowCallLog(CALLLOGFILTER iCallLogFilter);

typedef enum
{
     CALLLOGFILTER_ALL_CALLS,
     CALLLOGFILTER_MISSED,
     CALLLOGFILTER_INCOMING,
     CALLLOGFILTER_OUTGOING
} CALLLOGFILTER;

//++++++
//
//   PhoneAddSpeedDial
//
//        adds a speed dial entry
//
// dwFlags - currently unused, set to 0
//
// piKey - in/out: the key sequence which will invoke the speed dial.
//            currently an entry between 2 and 99 (inclusive) is valid.
//             the API will cause existing entries to be overwritten
//
// pszDisplayName - the non-empty display name for the speed dial
//
// pszTelNumber - the non-empty tel# to be dialed
//

HRESULT PhoneAddSpeedDial(DWORD dwFlags, DWORD* piKey, const TCHAR* pszDisplayName, const TCHAR* pszTelNumber);

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
[解决方案] 1. 用顺序表方式实现在线通讯录的设计: 思路:定义一个结构体数组来存储通讯录中的信息,然后通过遍历数组来实现对通讯录的基本操作。 代码实现: #include <stdio.h> #include <string.h> #define MAX_SIZE 100 // 定义最大通讯录容量 // 定义通讯录结构体 typedef struct { char name[20]; // 姓名 char phone[20]; // 电话号码 } Contact; Contact contacts[MAX_SIZE]; // 定义通讯录数组 int count = 0; // 记录当前通讯录中的联系人数 // 插入联系人信息 void insert() { if (count >= MAX_SIZE) { printf("通讯录已满,无法添加新联系人!\n"); return; } Contact c; printf("请输入联系人姓名:"); scanf("%s", c.name); printf("请输入联系人电话号码:"); scanf("%s", c.phone); contacts[count++] = c; printf("联系人添加成功!\n"); } // 删除联系人信息 void delete() { if (count == 0) { printf("通讯录为空,无法删除联系人!\n"); return; } char name[20]; printf("请输入要删除的联系人姓名:"); scanf("%s", name); int i; for (i = 0; i < count; i++) { if (strcmp(name, contacts[i].name) == 0) { int j; for (j = i; j < count - 1; j++) { contacts[j] = contacts[j + 1]; } count--; printf("联系人删除成功!\n"); return; } } printf("该联系人不存在,无法删除!\n"); } // 显示所有联系人信息 void display() { if (count == 0) { printf("通讯录为空,无法显示联系人信息!\n"); return; } printf("所有联系人信息如下:\n"); int i; for (i = 0; i < count; i++) { printf("%s:%s\n", contacts[i].name, contacts[i].phone); } } // 查找联系人信息 void search() { if (count == 0) { printf("通讯录为空,无法查找联系人!\n"); return; } char name[20]; printf("请输入要查找的联系人姓名:"); scanf("%s", name); int i; for (i = 0; i < count; i++) { if (strcmp(name, contacts[i].name) == 0) { printf("%s:%s\n", contacts[i].name, contacts[i].phone); return; } } printf("该联系人不存在,无法查找!\n"); } // 修改联系人信息 void modify() { if (count == 0) { printf("通讯录为空,无法修改联系人信息!\n"); return; } char name[20]; printf("请输入要修改的联系人姓名:"); scanf("%s", name); int i; for (i = 0; i < count; i++) { if (strcmp(name, contacts[i].name) == 0) { printf("请输入联系人新电话号码:"); scanf("%s", contacts[i].phone); printf("联系人信息修改成功!\n"); return; } } printf("该联系人不存在,无法修改!\n"); } int main() { int choice; while (1) { printf("\n********** 通讯录管理系统 **********\n"); printf("1. 插入联系人信息\n"); printf("2. 删除联系人信息\n"); printf("3. 显示所有联系人信息\n"); printf("4. 查找联系人信息\n"); printf("5. 修改联系人信息\n"); printf("0. 退出系统\n"); printf("请输入您的选择:"); scanf("%d", &choice); switch (choice) { case 0: printf("感谢使用本系统,再见!\n"); return 0; case 1: insert(); break; case 2: delete(); break; case 3: display(); break; case 4: search(); break; case 5: modify(); break; default: printf("输入有误,请重新输入!\n"); break; } } return 0; } 2. 用单链表方式实现在线通讯录的设计: 思路:定义一个通讯录节点结构体,每个节点包含姓名、电话号码和指向下一个节点的指针。使用头结点来指向第一个节点,通过遍历链表来实现对通讯录的基本操作。 代码实现: #include <stdio.h> #include <stdlib.h> #include <string.h> // 定义通讯录节点结构体 typedef struct contact { char name[20]; // 姓名 char phone[20]; // 电话号码 struct contact *next; // 指向下一个节点的指针 } ContactNode; ContactNode *head = NULL; // 头结点 // 插入联系人信息 void insert() { ContactNode *p = (ContactNode *) malloc(sizeof(ContactNode)); printf("请输入联系人姓名:"); scanf("%s", p->name); printf("请输入联系人电话号码:"); scanf("%s", p->phone); p->next = NULL; if (head == NULL) { head = p; } else { ContactNode *q = head; while (q->next != NULL) { q = q->next; } q->next = p; } printf("联系人添加成功!\n"); } // 删除联系人信息 void delete() { if (head == NULL) { printf("通讯录为空,无法删除联系人!\n"); return; } char name[20]; printf("请输入要删除的联系人姓名:"); scanf("%s", name); if (strcmp(name, head->name) == 0) { ContactNode *p = head; head = head->next; free(p); printf("联系人删除成功!\n"); return; } ContactNode *p = head->next; ContactNode *q = head; while (p != NULL) { if (strcmp(name, p->name) == 0) { q->next = p->next; free(p); printf("联系人删除成功!\n"); return; } q = p; p = p->next; } printf("该联系人不存在,无法删除!\n"); } // 显示所有联系人信息 void display() { if (head == NULL) { printf("通讯录为空,无法显示联系人信息!\n"); return; } printf("所有联系人信息如下:\n"); ContactNode *p = head; while (p != NULL) { printf("%s:%s\n", p->name, p->phone); p = p->next; } } // 查找联系人信息 void search() { if (head == NULL) { printf("通讯录为空,无法查找联系人!\n"); return; } char name[20]; printf("请输入要查找的联系人姓名:"); scanf("%s", name); ContactNode *p = head; while (p != NULL) { if (strcmp(name, p->name) == 0) { printf("%s:%s\n", p->name, p->phone); return; } p = p->next; } printf("该联系人不存在,无法查找!\n"); } // 修改联系人信息 void modify() { if (head == NULL) { printf("通讯录为空,无法修改联系人信息!\n"); return; } char name[20]; printf("请输入要修改的联系人姓名:"); scanf("%s", name); ContactNode *p = head; while (p != NULL) { if (strcmp(name, p->name) == 0) { printf("请输入联系人新电话号码:"); scanf("%s", p->phone); printf("联系人信息修改成功!\n"); return; } p = p->next; } printf("该联系人不存在,无法修改!\n"); } int main() { int choice; while (1) { printf("\n********** 通讯录管理系统 **********\n"); printf("1. 插入联系人信息\n"); printf("2. 删除联系人信息\n"); printf("3. 显示所有联系人信息\n"); printf("4. 查找联系人信息\n"); printf("5. 修改联系人信息\n"); printf("0. 退出系统\n"); printf("请输入您的选择:"); scanf("%d", &choice); switch (choice) { case 0: printf("感谢使用本系统,再见!\n"); return 0; case 1: insert(); break; case 2: delete(); break; case 3: display(); break; case 4: search(); break; case 5: modify(); break; default: printf("输入有误,请重新输入!\n"); break; } } return 0; }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值