如何去掉任务栏上的Notification【转】

分为两种情况:

一、自己用SHNotificationAdd 创建出来的Notification,当然是用SHNotificationRemove来去掉了。

 

二、系统的Notification(比方说未接电话、新短信之类的),可以用以下的方法:

通过修改注册表[HKEY_CURRENT_USER/System/State]下一些相关的键值。

e.g.

要去掉未接电话Notificatio,修改如下:

[HKEY_CURRENT_USER/System/State/Phone]

"Missed Call Count"=0

去掉新短消息Notification,修改如下:

[HKEY_CURRENT_USER/System/State/Messages/sms/Unread]

"Count"=0

上次说修改键值来达到删除Notification的目的,但可能会产生副作用,比方说Today Screen里面的计数可能会因为这个注册表的改动而显示了错误的值。

[HKEY_CURRENT_USER/System/State/Messages/sms/Unread]

"Count"=0

 

后来在网上搜了一下,codeproject上有个人是通过SHNotificationRemove实现的,我修改了一下,sample code如下:

  1. void RemoveNewMessageNotification() 
  2.     SHNOTIFICATIONDATA shnd; 
  3.     CLSID clsid; 
  4.     LRESULT result; 
  5.     DWORD dwID = 0; 
  6.     if (0 == CLSIDFromString(TEXT("{A877D65B-239C-47a7-9304-0D347F580408}"), &clsid)) 
  7.     { 
  8.             memset(&shnd, 0, sizeof(shnd)); 
  9.             shnd.cbStruct = sizeof(SHNOTIFICATIONDATA); 
  10.             do 
  11.             { 
  12.                 result = SHNotificationGetData(&clsid,dwID,&shnd); 
  13.                 if (ERROR_SUCCESS == result) 
  14.                 { 
  15.                     SHNotificationRemove(&clsid,dwID); 
  16.                     if (shnd.pszHTML)
  17.                     {
  18.                         free((void *) shnd.pszHTML); 
  19.                         shnd.pszHTML = NULL; 
  20.                     }
  21.                     if (shnd.pszTitle) 
  22.                     {
  23.                         free((void *) shnd.pszTitle); 
  24.                         shnd.pszTitle = NULL; 
  25.                     }
  26.                 } 
  27.                 else 
  28.                     dwID++; 
  29.             } while ((ERROR_SUCCESS != result) && (dwID < 20000)); 
  30.     }




  31. 系统菜单扩展

    系统菜单的扩展是通过COM来实现的,主要工作有两个:代码实现和创建注册表键值。

    1. 代码实现:

    实现接口为IObjectWithSite和IContextMenu。当然,还包括IClassFactory,它帮助生成指定CLSID的对象,它的代码其实都是千篇一律,把sample中的代码稍微修改一下就可以用了。

    具体的实现请参考<SDK安装路径>/Samples/Common/CPP/Win32/InboxMenuExtensibility下的一个例子,它扩展了tmail.exe(Messaging) message list下的menu。

    关键的实现主要还是在QueryContextMenu和InvokeCommand,QueryContextMenu一般用来添加菜单的操作,InvokeCommand是用于点击你刚添加的菜单项时的响应。值得一提的是QueryContextMenu的返回值,应设为你添加的菜单项个数,一般实现为return MAKE_HRESULT(SEVERITY_SUCCESS, 0, nMenuAdded); 这样系统就知道你到底添加了多少菜单,别人调用QueryContextMenu的时候idCmdFirst才是正确的。比方说其它应用程序恰好也在这个菜单里加了菜单项,就不会引起冲突(冲突就是说比方说点了你的菜单项,结果响应的却是其它软件加的菜单项的命令)。而且Smart Phone也比较特殊,每进到一个popup menu就会响应一下QueryContextMenu,所以一般都是计算当前弹出菜单的菜单项个数来避免每次进去一个popup menu都添加菜单项。

    2. 注册表键值的创建:

    [HKEY_CLASSES_ROOT/CLSID]下创建一个key,name为你所用的CLSID,再在这个key下面创建一个key,name为InProcServer32,默认值设为你的DLL。

    [HKEY_LOCAL_MACHINE/Software/Microsoft/Shell/Extensions/ContextMenus]下创建的key需要根据你扩展菜单的位置来决定的,具体的值请看SDK document中的Menu Overview。

     State and Notifications Broker

     State and Notifications Broker提供了一个在注册表中存储系统和应用程序信息的机制和一个存储信息改变的通知系统。它可以用于监控系统中的任何注册表键值。通知种类包括以下几种:

  32. System state information, such as features present (camera, keyboard), active application, cradled state, battery state.
  33. Message information, such as count of unread, last received, account info.
  34. Tasks and appointments information, such as upcoming, overdue, location.
  35. Windows Media Player information, such as currently playing album, artist.
  36. Phone information, such as signal information, operator information, call information, multiline information.
  37. Connections information, related to bluetooth, cellular, network, modem, etc.

            snapi.h中包含了需要监控的注册表Key、Path、Value Name和Mask,比方说你想知道现在的phone处在一个什么状态,可以看到snapi.h中有这么一段:

    ////////////////////////////////////////////////////////////////////////////////
    // PhoneRoaming
    // Gets a value indicating whether the phone is currently in roaming mode.
    #define SN_PHONEROAMING_ROOT HKEY_LOCAL_MACHINE
    #define SN_PHONEROAMING_PATH TEXT("System//State//Phone")
    #define SN_PHONEROAMING_VALUE TEXT("Status")
    #define SN_PHONEROAMING_BITMASK 0x200

            当键值[HKLM/System/State/Phone] "Status"值的0x200这一位上为1时,说明phone处在漫游状态。

            那么,如何监控注册表键值呢?可以用RegistryNotifyApp、RegistryNotifyWindow、RegistryNotifyCallback等API。以下是Sample Code:

    1. #include <snapi.h>
    2. #include <regext.h>
    3. #define UM_REGNOTIFY    WM_USER+1000
    4. // Global Variables:
    5. HREGNOTIFY          g_hRegNotify;
    6. LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
    7. {
    8.     switch (message) 
    9.     {
    10.         case WM_CREATE:
    11.             NOTIFICATIONCONDITION nc;
    12.             ZeroMemory(&nc, sizeof(NOTIFICATIONCONDITION));
    13.             nc.ctComparisonType = REG_CT_EQUAL;
    14.             nc.dwMask = 0x200;
    15.             nc.TargetValue.dw = 0x200;
    16.             RegistryNotifyWindow(SN_PHONEROAMING_ROOT, SN_PHONEROAMING_PATH, SN_PHONEROAMING_VALUE, hWnd, UM_REGNOTIFY, 0, &nc, &g_hRegNotify);
    17.             break;
    18.         case UM_REGNOTIFY:
    19.             MessageBox(hWnd, _T("Phone is roaming!"), _T("Notification Broker"), MB_OK);
    20.             break;
    21.         case WM_DESTROY:
    22.             RegistryCloseNotification(g_hRegNotify);
    23.             PostQuitMessage(0);
    24.             break;
    25.         default:
    26.             return DefWindowProc(hWnd, message, wParam, lParam);
    27.     }
    28.     return 0;
    29. }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值