C#开发微信门户及应用(15)-微信菜单增长扫一扫、发图片、发地理位置功能

原文: C#开发微信门户及应用(15)-微信菜单增长扫一扫、发图片、发地理位置功能

前面介绍了不少篇关于使用C#开发微信门户及应用的文章,基本上把当时微信能作的接口都封装差很少了,微信框架也积累了很多模块和用户,最近发现微信公众平台增长了很多内容,特别是在自定义菜单里面增长了扫一扫、发图片、发地理位置功能,这几个功能模块很重要,想一想之前想在微信公众号里面增长一个扫描二维码的功能,都作不了,如今能够了,还能够拍照上传等功能,本文主要介绍基于我前面的框架系列文章,进一步介绍如何集成和使用这些新增功能。html

一、微信几个功能的官方介绍

1). 扫码推送事件

用户点击按钮后,微信客户端将调起扫一扫工具,完成扫码操做后显示扫描结果(若是是URL,将进入URL),且会将扫码的结果传给开发者,开发者能够下发消息。web

2). 扫码推送事件,且弹出“消息接收中”提示框

用户点击按钮后,微信客户端将调起扫一扫工具,完成扫码操做后,将扫码的结果传给开发者,同时收起扫一扫工具,而后弹出“消息接收中”提示框,随后可能会收到开发者下发的消息。数据库

3). 弹出系统拍照发图

用户点击按钮后,微信客户端将调起系统相机,完成拍照操做后,将拍摄的相片发送给开发者,并推送事件给开发者,同时收起系统相机,随后可能会收到开发者下发的消息。服务器

4). 弹出拍照或者相册发图

用户点击按钮后,微信客户端将弹出选择器供用户选择“拍照”或者“从手机相册选择”。用户选择后即走其余两种流程。微信

5). 弹出微信相册发图器

用户点击按钮后,微信客户端将调起微信相册,完成选择操做后,将选择的相片发送给开发者的服务器,并推送事件给开发者,同时收起相册,随后可能会收到开发者下发的消息。微信开发

6). 弹出地理位置选择器

用户点击按钮后,微信客户端将调起地理位置选择工具,完成选择操做后,将选择的地理位置发送给开发者的服务器,同时收起位置选择工具,随后可能会收到开发者下发的消息。
但请注意,以上新增能力,均仅支持微信iPhone5.4.1以上版本,和Android5.4以上版本的微信用户,旧版本微信用户点击后将没有回应,开发者也不能正常接收到事件推送。微信公众平台

 

二、微信新菜单功能的测试公众号

微信不只增长了这些功能模块的支持,还考虑到咱们开发人员的方便,增长了一个叫作“menutest"的公众号,方便咱们测试。咱们在公众号搜索“menutest",而后关注它便可进行测试几个新增功能了。框架

“menutest"的公众号名称是”自定义菜单拓展测试“,我关注它并进行了测试,二维码、图片、地理位置都很OK,自己可以响应这些事件,而且图片、地理位置自身还能出现一个对应的事件,以下所示。工具

图片发送能够分为拍照、拍照和相册、微信相册三类,感受后面两个有点相似,但有这些功能都很不错的。post

       

三、改进菜单对象和提交菜单

前面说了,微信提供这些功能,能够在菜单里面进行集成,也就是菜单的类型由原来CLICK/VIEW两种,变为如今8种类型,增长2个扫码操做、3种图片操做、1种地理位置操做。

所以把菜单的枚举类型扩展一下,以下所示。

    /// <summary>
    /// 菜单按钮类型
    /// </summary>
    public enum ButtonType
    {
        /// <summary>
        /// 点击
        /// </summary>
        click,

        /// <summary>
        /// Url
        /// </summary>
        view,

        /// <summary>
        /// 扫码推事件的事件推送
        /// </summary>
        scancode_push,

        /// <summary>
        /// 扫码推事件且弹出“消息接收中”提示框的事件推送
        /// </summary>
        scancode_waitmsg,

        /// <summary>
        /// 弹出系统拍照发图的事件推送
        /// </summary>
        pic_sysphoto,

        /// <summary>
        /// 弹出拍照或者相册发图的事件推送
        /// </summary>
        pic_photo_or_album,

        /// <summary>
        /// 弹出微信相册发图器的事件推送
        /// </summary>
        pic_weixin,

        /// <summary>
        /// 弹出地理位置选择器的事件推送
        /// </summary>
        location_select
    }

而后在Winform里面调用建立菜单操做代码以下所示:

        private void btnCreateMenu_Click(object sender, EventArgs e)
        {
            MenuJson productInfo = new MenuJson("新功能测试", new MenuJson[] { 
                new MenuJson("扫码推事件", ButtonType.scancode_push, "scancode_push") 
                ,new MenuJson("系统拍照发图", ButtonType.pic_sysphoto, "pic_sysphoto") 
                , new MenuJson("拍照相册发图", ButtonType.pic_photo_or_album, "pic_photo_or_album") 
                , new MenuJson("微信相册发图", ButtonType.pic_weixin, "pic_weixin") 
                , new MenuJson("地理位置选择", ButtonType.location_select, "location_select") 
            });                                    

            MenuJson frameworkInfo = new MenuJson("框架产品", new MenuJson[] { 
                new MenuJson("Win开发框架", ButtonType.click, "win"),
                new MenuJson("WCF开发框架", ButtonType.click, "wcf"),
                new MenuJson("混合式框架", ButtonType.click, "mix"), 
                new MenuJson("Web开发框架", ButtonType.click, "web")
                ,new MenuJson("代码生成工具", ButtonType.click, "database2sharp")
            });

            MenuJson relatedInfo = new MenuJson("相关连接", new MenuJson[] { 
                new MenuJson("公司介绍", ButtonType.click, "event_company"),
                new MenuJson("官方网站", ButtonType.view, "http://www.iqidi.com"),
                new MenuJson("联系咱们", ButtonType.click, "event_contact"),
                new MenuJson("应答系统", ButtonType.click, "set-1"),
                new MenuJson("人工客服", ButtonType.click, "event_customservice")
            });

            MenuListJson menuJson = new MenuListJson();
            menuJson.button.AddRange(new MenuJson[] { productInfo, frameworkInfo, relatedInfo });

            if (MessageUtil.ShowYesNoAndWarning("您确认要建立菜单吗") == System.Windows.Forms.DialogResult.Yes)
            {
                IMenuApi menuBLL = new MenuApi();
                CommonResult result = menuBLL.CreateMenu(token, menuJson);
                Console.WriteLine("建立菜单:" + (result.Success ? "成功" : "失败:" + result.ErrorMessage));
            }
        }

固然,通常状况下咱们都是在Web后台系统进行的,维护菜单都是在本身微信平台上进行菜单管理,而后一次性提交到微信服务器便可。

而在Web后台,只须要把数据库的数据变化为Json数据提交便可,操做和上面的相似。

        /// <summary>
        ///更新微信菜单
        /// </summary>
        /// <returns></returns>
        public ActionResult UpdateWeixinMenu()
        {
            string token = base.GetAccessToken();
            MenuListJson menuJson = GetWeixinMenu();

            IMenuApi menuApi = new MenuApi();
            CommonResult result = menuApi.CreateMenu(token, menuJson);
            return ToJsonContent(result);
        }

四、微信扫一扫功能集成 

 前面讲了,有了最新的功能,咱们就能够实现扫一扫功能,从而能够扫描条形码,二维码的功能。有了条形码、二维码的快速和识别,咱们就能开发一些如条码查询、商品处理等功能了。

这里咱们介绍如何在个人微信开发框架里面整合这个扫一扫的功能处理操做。

前面已经增长了一些新功能的测试菜单,咱们要作的就是响应这些事件处理,而后对他们进行应答处理就能够了。

下面是根据事件进行的一些API跳转处理,咱们同时定义了几个相关的实体类用来处理他们的信息,如RequestEventScancodePush、RequestEventScancodeWaitmsg、RequestEventPicSysphoto等等。

RequestEventScancodeWaitmsg实体类的代码以下所示,其余的相似处理。

    /// <summary>
    /// 扫码推事件且弹出“消息接收中”提示框的事件推送
    /// </summary>
    [System.Xml.Serialization.XmlRoot(ElementName = "xml")]
    public class RequestEventScancodeWaitmsg : BaseEvent
    {
        public RequestEventScancodeWaitmsg()
        {
            this.MsgType = RequestMsgType.Event.ToString().ToLower();
            this.Event = RequestEvent.scancode_waitmsg.ToString();
            this.ScanCodeInfo = new ScanCodeInfo();
        }

        /// <summary>
        /// 事件KEY值,由开发者在建立菜单时设定
        /// </summary>
        public string EventKey { get; set; }

        /// <summary>
        /// 扫描信息
        /// </summary>
        public ScanCodeInfo ScanCodeInfo { get; set; }

    }
 

而根据实体类强类型的处理接口流转操做以下所示。

                               case RequestEvent.scancode_push:
                                {
                                    //扫码推事件的事件推送
                                    RequestEventScancodePush info = XmlConvertor.XmlToObject(postStr, typeof(RequestEventScancodePush)) as RequestEventScancodePush;
                                    if (info != null)
                                    {
                                        responseContent = actionBLL.HandleEventScancodePush(info);
                                    }
                                }
                                break;

                            case RequestEvent.scancode_waitmsg:
                                {
                                    //扫码推事件且弹出“消息接收中”提示框的事件推送
                                    RequestEventScancodeWaitmsg info = XmlConvertor.XmlToObject(postStr, typeof(RequestEventScancodeWaitmsg)) as RequestEventScancodeWaitmsg;
                                    if (info != null)
                                    {
                                        responseContent = actionBLL.HandleEventScancodeWaitmsg(info);
                                    }
                                }
                                break;

                            case RequestEvent.pic_sysphoto:
                                {
                                    //弹出系统拍照发图的事件推送
                                    RequestEventPicSysphoto info = XmlConvertor.XmlToObject(postStr, typeof(RequestEventPicSysphoto)) as RequestEventPicSysphoto;
                                    if (info != null)
                                    {
                                        responseContent = actionBLL.HandleEventPicSysphoto(info);
                                    }
                                }
                                break;
..................

处理扫描结果并返回的最终代码以下所示。

        /// <summary>
        /// 扫码推事件且弹出“消息接收中”提示框的事件推送的处理
        /// </summary>
        /// <param name="info">扫描信息</param>
        /// <returns></returns>
        public string HandleEventScancodeWaitmsg(RequestEventScancodeWaitmsg info)
        {
            ResponseText response = new ResponseText(info);
            response.Content = string.Format("您的信息为:{0},能够结合后台进行数据查询。", info.ScanCodeInfo.ScanResult);
            return response.ToXml();
        }

最后咱们测试扫描一个条形码,能够看到返回的结果界面操做以下所示。

 

五、新菜单功能测试发现的问题

前面介绍了一些新菜单功能模块的集成,我我的对这种扫一扫菜单功能很是赞扬,这也是微信逐步整合更多硬件资源和接口处理的趋向,不过在集成使用的时候,发现公众号偶尔出现闪退的状况,还有就是这些新功能虽而后台可以实现数据的处理和接收,可是有一些不能返回应答消息,很郁闷。也许随着版本研发的加快,这些功能很快获得完善和解决。

另外微信开放平台也投入使用了,好些认证也是300元一年,不过暂时没有其应用的场景,我只是用到了它来获取微信帐号的unionid的功能,其余功能慢慢了解吧。

还有就是微信的企业号也已经出来了,并且我也已经申请认证经过,它的开发用户的API也有很多,有空继续研究并整合到微信开发框架里面吧。

 

若是对这个《C#开发微信门户及应用》系列感兴趣,能够关注个人其余文章,系列随笔以下所示:

C#开发微信门户及应用(20)-微信企业号的菜单管理

C#开发微信门户及应用(19)-微信企业号的消息发送(文本、图片、文件、语音、视频、图文消息等)

C#开发微信门户及应用(18)-微信企业号的通信录管理开发之成员管理

C#开发微信门户及应用(17)-微信企业号的通信录管理开发之部门管理

C#开发微信门户及应用(16)-微信企业号的配置和使用

C#开发微信门户及应用(15)-微信菜单增长扫一扫、发图片、发地理位置功能

 C#开发微信门户及应用(14)-在微信菜单中采用重定向获取用户数据

C#开发微信门户及应用(13)-使用地理位置扩展相关应用

C#开发微信门户及应用(12)-使用语音处理

C#开发微信门户及应用(11)--微信菜单的多种表现方式介绍

C#开发微信门户及应用(10)--在管理系统中同步微信用户分组信息

C#开发微信门户及应用(9)-微信门户菜单管理及提交到微信服务器

C#开发微信门户及应用(8)-微信门户应用管理系统功能介绍

C#开发微信门户及应用(7)-微信多客服功能及开发集成

C#开发微信门户及应用(6)--微信门户菜单的管理操做

C#开发微信门户及应用(5)--用户分组信息管理

C#开发微信门户及应用(4)--关注用户列表及详细信息管理

C#开发微信门户及应用(3)--文本消息和图文消息的应答

C#开发微信门户及应用(2)--微信消息的处理和应答

C#开发微信门户及应用(1)--开始使用微信接口

相关文章
相关标签/搜索