溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C#如何實現(xiàn)微信菜單增加掃一掃、發(fā)圖片、發(fā)地理位置功能

發(fā)布時間:2021-09-09 16:28:23 來源:億速云 閱讀:132 作者:小新 欄目:移動開發(fā)

這篇文章將為大家詳細講解有關C#如何實現(xiàn)微信菜單增加掃一掃、發(fā)圖片、發(fā)地理位置功能 ,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

1、微信幾個功能的官方介紹

1). 掃碼推送事件

用戶點擊按鈕后,微信客戶端將調(diào)起掃一掃工具,完成掃碼操作后顯示掃描結果(如果是URL,將進入URL),且會將掃碼的結果傳給開發(fā)者,開發(fā)者可以下發(fā)消息。

2). 掃碼推送事件,且彈出“消息接收中”提示框

用戶點擊按鈕后,微信客戶端將調(diào)起掃一掃工具,完成掃碼操作后,將掃碼的結果傳給開發(fā)者,同時收起掃一掃工具,然后彈出“消息接收中”提示框,隨后可能會收到開發(fā)者下發(fā)的消息。

3). 彈出系統(tǒng)拍照發(fā)圖

用戶點擊按鈕后,微信客戶端將調(diào)起系統(tǒng)相機,完成拍照操作后,將拍攝的相片發(fā)送給開發(fā)者,并推送事件給開發(fā)者,同時收起系統(tǒng)相機,隨后可能會收到開發(fā)者下發(fā)的消息。

4). 彈出拍照或者相冊發(fā)圖

用戶點擊按鈕后,微信客戶端將彈出選擇器供用戶選擇“拍照”或者“從手機相冊選擇”。用戶選擇后即走其他兩種流程。

5). 彈出微信相冊發(fā)圖器

用戶點擊按鈕后,微信客戶端將調(diào)起微信相冊,完成選擇操作后,將選擇的相片發(fā)送給開發(fā)者的服務器,并推送事件給開發(fā)者,同時收起相冊,隨后可能會收到開發(fā)者下發(fā)的消息。

6). 彈出地理位置選擇器

用戶點擊按鈕后,微信客戶端將調(diào)起地理位置選擇工具,完成選擇操作后,將選擇的地理位置發(fā)送給開發(fā)者的服務器,同時收起位置選擇工具,隨后可能會收到開發(fā)者下發(fā)的消息。
但請注意,以上新增能力,均僅支持微信iPhone5.4.1以上版本,和Android5.4以上版本的微信用戶,舊版本微信用戶點擊后將沒有回應,開發(fā)者也不能正常接收到事件推送。

2、微信新菜單功能的測試公眾號

微信不僅增加了這些功能模塊的支持,還考慮到我們開發(fā)人員的方便,增加了一個叫做“menutest"的公眾號,方便我們測試。我們在公眾號搜索“menutest",然后關注它即可進行測試幾個新增功能了。

C#如何實現(xiàn)微信菜單增加掃一掃、發(fā)圖片、發(fā)地理位置功能

“menutest"的公眾號名稱是”自定義菜單拓展測試“,我關注它并進行了測試,二維碼、圖片、地理位置都很OK,本身能夠響應這些事件,并且圖片、地理位置自身還能出現(xiàn)一個對應的事件,如下所示。

圖片發(fā)送可以分為拍照、拍照和相冊、微信相冊三類,感覺后面兩個有點類似,但有這些功能都很不錯的。

C#如何實現(xiàn)微信菜單增加掃一掃、發(fā)圖片、發(fā)地理位置功能        C#如何實現(xiàn)微信菜單增加掃一掃、發(fā)圖片、發(fā)地理位置功能

3、改進菜單對象和提交菜單

前面說了,微信提供這些功能,可以在菜單里面進行集成,也就是菜單的類型由原來CLICK/VIEW兩種,變?yōu)楝F(xiàn)在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>
        /// 彈出系統(tǒng)拍照發(fā)圖的事件推送        /// </summary>        pic_sysphoto,        /// <summary>
        /// 彈出拍照或者相冊發(fā)圖的事件推送        /// </summary>        pic_photo_or_album,        /// <summary>
        /// 彈出微信相冊發(fā)圖器的事件推送        /// </summary>        pic_weixin,        /// <summary>
        /// 彈出地理位置選擇器的事件推送        /// </summary>        location_select
    }

然后在Winform里面調(diào)用創(chuàng)建菜單操作代碼如下所示:

        private void btnCreateMenu_Click(object sender, EventArgs e)
        {
            MenuJson productInfo = new MenuJson("新功能測試", new MenuJson[] { 
                new MenuJson("掃碼推事件", ButtonType.scancode_push, "scancode_push") 
                ,new MenuJson("系統(tǒng)拍照發(fā)圖", ButtonType.pic_sysphoto, "pic_sysphoto") 
                , new MenuJson("拍照相冊發(fā)圖", ButtonType.pic_photo_or_album, "pic_photo_or_album") 
                , new MenuJson("微信相冊發(fā)圖", ButtonType.pic_weixin, "pic_weixin") 
                , new MenuJson("地理位置選擇", ButtonType.location_select, "location_select") 
            });                                    

            MenuJson frameworkInfo = new MenuJson("框架產(chǎn)品", new MenuJson[] { 
                new MenuJson("Win開發(fā)框架", ButtonType.click, "win"),                new MenuJson("WCF開發(fā)框架", ButtonType.click, "wcf"),                new MenuJson("混合式框架", ButtonType.click, "mix"), 
                new MenuJson("Web開發(fā)框架", ButtonType.click, "web")
                ,new MenuJson("代碼生成工具", ButtonType.click, "database2sharp")
            });

            MenuJson relatedInfo = new MenuJson("相關鏈接", new MenuJson[] { 
                new MenuJson("公司介紹", ButtonType.click, "event_company"),                
                new MenuJson("官方網(wǎng)站", ButtonType.view, "http://www.php.cn/"),                
                new MenuJson("聯(lián)系我們", ButtonType.click, "event_contact"),                
                new MenuJson("應答系統(tǒng)", 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("您確認要創(chuàng)建菜單嗎") == System.Windows.Forms.DialogResult.Yes)
            {
                IMenuApi menuBLL = new MenuApi();
                CommonResult result = menuBLL.CreateMenu(token, menuJson);
                Console.WriteLine("創(chuàng)建菜單:" + (result.Success ? "成功" : "失敗:" + result.ErrorMessage));
            }
        }

當然,一般情況下我們都是在Web后臺系統(tǒng)進行的,維護菜單都是在自己微信平臺上進行菜單管理,然后一次性提交到微信服務器即可。

C#如何實現(xiàn)微信菜單增加掃一掃、發(fā)圖片、發(fā)地理位置功能

而在Web后臺,只需要把數(shù)據(jù)庫的數(shù)據(jù)變化為Json數(shù)據(jù)提交即可,操作和上面的類似。

        /// <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);
        }

4、微信掃一掃功能集成

前面講了,有了最新的功能,我們就可以實現(xiàn)掃一掃功能,從而可以掃描條形碼,二維碼的功能。有了條形碼、二維碼的快速和識別,我們就能開發(fā)一些如條碼查詢、商品處理等功能了。

這里我們介紹如何在我的微信開發(fā)框架里面整合這個掃一掃的功能處理操作。

前面已經(jīng)增加了一些新功能的測試菜單,我們要做的就是響應這些事件處理,然后對他們進行應答處理就可以了。

下面是根據(jù)事件進行的一些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值,由開發(fā)者在創(chuàng)建菜單時設定        /// </summary>
        public string EventKey { get; set; }        /// <summary>
        /// 掃描信息        /// </summary>
        public ScanCodeInfo ScanCodeInfo { get; set; }

    }

而根據(jù)實體類強類型的處理接口流轉操作如下所示。

                               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:
                                {                                    //彈出系統(tǒng)拍照發(fā)圖的事件推送
                                    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},可以結合后臺進行數(shù)據(jù)查詢。", info.ScanCodeInfo.ScanResult);            return response.ToXml();
        }

最后我們測試掃描一個條形碼,可以看到返回的結果界面操作如下所示。

C#如何實現(xiàn)微信菜單增加掃一掃、發(fā)圖片、發(fā)地理位置功能

5、新菜單功能測試發(fā)現(xiàn)的問題

前面介紹了一些新菜單功能模塊的集成,我個人對這種掃一掃菜單功能非常贊賞,這也是微信逐步整合更多硬件資源和接口處理的趨向,不過在集成使用的時候,發(fā)現(xiàn)公眾號偶爾出現(xiàn)閃退的情況,還有就是這些新功能雖然后臺能夠?qū)崿F(xiàn)數(shù)據(jù)的處理和接收,但是有一些不能返回應答消息,很郁悶。也許隨著版本研發(fā)的加快,這些功能很快得到完善和解決。

另外微信開放平臺也投入使用了,好些認證也是300元一年,不過暫時沒有其應用的場景,我只是用到了它來獲取微信賬號的unionid的功能,其他功能慢慢了解吧。

還有就是微信的企業(yè)號也已經(jīng)出來了,而且我也已經(jīng)申請認證通過,它的開發(fā)用戶的API也有不少,有空繼續(xù)研究并整合到微信開發(fā)框架里面吧。

關于“C#如何實現(xiàn)微信菜單增加掃一掃、發(fā)圖片、發(fā)地理位置功能 ”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI