您好,登錄后才能下訂單哦!
這篇文章主要介紹如何使用C#實現微信菜單增加掃一掃、發圖片、發地理位置功能,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
用戶點擊按鈕后,微信客戶端將調起掃一掃工具,完成掃碼操作后顯示掃描結果(如果是URL,將進入URL),且會將掃碼的結果傳給開發者,開發者可以下發消息。
用戶點擊按鈕后,微信客戶端將調起掃一掃工具,完成掃碼操作后,將掃碼的結果傳給開發者,同時收起掃一掃工具,然后彈出“消息接收中”提示框,隨后可能會收到開發者下發的消息。
用戶點擊按鈕后,微信客戶端將調起系統相機,完成拍照操作后,將拍攝的相片發送給開發者,并推送事件給開發者,同時收起系統相機,隨后可能會收到開發者下發的消息。
用戶點擊按鈕后,微信客戶端將彈出選擇器供用戶選擇“拍照”或者“從手機相冊選擇”。用戶選擇后即走其他兩種流程。
用戶點擊按鈕后,微信客戶端將調起微信相冊,完成選擇操作后,將選擇的相片發送給開發者的服務器,并推送事件給開發者,同時收起相冊,隨后可能會收到開發者下發的消息。
用戶點擊按鈕后,微信客戶端將調起地理位置選擇工具,完成選擇操作后,將選擇的地理位置發送給開發者的服務器,同時收起位置選擇工具,隨后可能會收到開發者下發的消息。
但請注意,以上新增能力,均僅支持微信iPhone5.4.1以上版本,和Android5.4以上版本的微信用戶,舊版本微信用戶點擊后將沒有回應,開發者也不能正常接收到事件推送。
微信不僅增加了這些功能模塊的支持,還考慮到我們開發人員的方便,增加了一個叫做“menutest"的公眾號,方便我們測試。我們在公眾號搜索“menutest",然后關注它即可進行測試幾個新增功能了。
“menutest"的公眾號名稱是”自定義菜單拓展測試“,我關注它并進行了測試,二維碼、圖片、地理位置都很OK,本身能夠響應這些事件,并且圖片、地理位置自身還能出現一個對應的事件,如下所示。
圖片發送可以分為拍照、拍照和相冊、微信相冊三類,感覺后面兩個有點類似,但有這些功能都很不錯的。
前面說了,微信提供這些功能,可以在菜單里面進行集成,也就是菜單的類型由原來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.php.cn/"), 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; } }
而根據實體類強類型的處理接口流轉操作如下所示。
RequestEventScancodePush info = XmlConvertor.XmlToObject(postStr, (RequestEventScancodePush)) (info != = RequestEventScancodeWaitmsg info = XmlConvertor.XmlToObject(postStr, (RequestEventScancodeWaitmsg)) (info != = RequestEventPicSysphoto info = XmlConvertor.XmlToObject(postStr, (RequestEventPicSysphoto)) (info != =; ..................
處理掃描結果并返回的最終代碼如下所示。
/// <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(); }
以上是“如何使用C#實現微信菜單增加掃一掃、發圖片、發地理位置功能”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。