从开始做这一块的工作开始,就开始找各种的资料,最后还是老老实实的去看官方文档。

对于Xamarin.Android的绑定属于纯jar的绑定,这个难度较小,添加Bindings Library,将libammsdk.jar添加到指定的文件夹中编译,不出意外的会报出两个错误,解决办法是:双击错误提示到相应的文件,然后找到错误提示中提到的类的定义,类定义的上面有路径,拷贝到Transforms文件夹下的Metadata.xml文件中,如下图所示,这样就ok了,编译通过

在调用的微信API的过程中,要求在微信申请的AppID与应用的包名以及应用签名要完全对应起来,有一个没有对应起来,在调用的时候会出现调用微信闪退的情况。

另外,我在App中用的是微信的网页链接分享功能,在获取图片的byte数组的时候用的是下面几行代码

1
2
3
4
5
6
7
Bitmap thumb=BitmapFactory.DecodeResource(Utility.resources,Resource.Drawable.icon);
 
MemoryStream stream=new MemoryStream();
 
thumb.Compress(Bitmap.CompressFormat.Png,0,stream);
 
byte[] bitmapData=stream.ToArray();

还有一点要注意的是Resource.Drawable.icon对应的资源要在每个drawable文件夹里都放一份icon,不然的话获取的bitmapData会有问题,调用分享功能的时候,程序会出现没有响应的情况。

下面来说一下Xamarin.iOS的绑定,这个相对来说比较麻烦,也是在QQ群里遇到大神的指点才绑定成功的,对于iOS的微信绑定来说,只要Bundle ID与微信开放平台申请的AppID 能对应起来就OK了。

同样的先添加一个iOS的Bindings Library,根据官方文档,安装了sharpie 还有xcode command line,接下来就是把下载下来的微信SDK for iOS用sharpie来转换一下:

1
sharpie bind -output=iOS.WechatBinding -namespace=iOS.WechatBinding -sdk=iphoneos10.1 [绝对路径]/OpenSDK1.7.5/*.h

执行完成会提示有两个错误,但是照样会生成ApiDefinitions.cs跟StructsAndEnums.cs两个文件,根据官方文档,将两个文件中的内容分别复制黏贴到Bindings Library下的ApiDefinition.cs以及Structs.cs文件中,并且将libWeChatSDK.a添加到Native References中。

编译后会报出一堆错误,这些错误其实是起到一个提示的作用,让程序员验证一下sharpie的转换是不是正确,这里我将[Verify(************)]全部注释掉,也可以删掉,再次编译通过。

在iOS接入微信的sdk中会发现这样一段话:开发者需要在工程中链接上:SystemConfiguration.framework, libz.dylib, libsqlite3.0.dylib, libc++.dylib, Security.framework, CoreTelephony.framework, CFNetwork.framework。在这里需要编辑一下引入的libWeChatSDK.a的属性,Native References下的libWeChatSDK,右键属性,配置如下:

配置完成后,绑定工作算是大功告成了,可以继续后面的工作了。

欢迎大家指正。

Xamarin绑定微信SDK 实现分享功能的更多相关文章

  1. Xamarin Android绑定微信SDK

    现在几乎所有的APP都集成了向微博,微信等社交平台分享的功能.这些社交平台官方也提供了SDK让开发者使用,对于Android和IOS平台而言,只需要下载官方的SDK,按照官方说明文档进行集成就可以轻松 ...

  2. 微信JSSdk实现分享功能

    1. 概述 微信分享服务器的作用是为用户在微信浏览器端对来自网站以及客户端的页面进行二次分享链接时更友好的展示提供服务.为实现二次分享功能需要使用微信JS-SDK来开发. 微信JS-SDK是微信公众平 ...

  3. 微信小程序--分享功能

    微信小程序--分享功能 微信小程序前段时间开放了小程序右上角的分享功能, 可以分享任意一个页面到好友或者群聊, 但是不能分享到朋友圈 这里有微信开发文档链接:点击跳转到微信分享功能API 入口方法: ...

  4. 微信app的分享功能

    最近在做微信app,需要用到分享功能,横观文档,压根没有提过分享功能自定义的事情……后来在搜索中找到一些前辈的文章,使用WeixinJSBridge这个接口实现,但是,我非常非常好奇,这是什么渠道透露 ...

  5. 微信 SDK 不能 分享

    说多了都是泪水,真的. 前段时间,做好了微信的分享功能,测试通过的,最近我又跑了一遍用例,发现不能启动微信客户端了,怎么都启动不了,日志如下:ignore wechat app signature v ...

  6. 微信JS-SDK实际分享功能

    为了净化网络,整顿诱导分享及诱导关注行为,微信于2014年12月30日发布了<微信公众平台关于整顿诱导分享及诱导关注行为的公告>,微信平台开发者发现,原有的微信分享功能不能用了,在ipho ...

  7. Egret白鹭开发微信小游戏分享功能

    今天给大家分享一下微信分享转发功能,话不多说,直接干 方法一: 1.在egret中打开Platfrom.ts文件,添加代码如下(当然,你也可以直接复制粘贴) /** * 平台数据接口. * 由于每款游 ...

  8. 微信JS-SDK实现分享功能

    1 申请一个微信公众号,并确认在开发–接口权限中拥有分享功能的权限. 2 公众号设置–功能设置:在JS接口安全域名中添加安全域名,这个安全域名不是url,只需添加一级域名即可. 3 开发,基本配置中, ...

  9. Android 微信SDK图片分享(checkArgs fail, thumbData is invalid)

    微信官网给的Demo中.图片的分享例子他是这么描述的: String url = "http://pic2.nipic.com/20090506/1478953_125254084_2.jp ...

随机推荐

  1. Spring Boot 概念知识

    转 http://rapharino.com/coder/Spring-Boot-Induction/ Spring Boot Induction 发表于 2016-10-29   |   分类于 c ...

  2. mysql分区 详解

    第18章:分区 目录 18.1. MySQL中的分区概述 18.2. 分区类型 18.2.1. RANGE分区 18.2.2. LIST分区 18.2.3. HASH分区 18.2.4. KEY分区 ...

  3. 简单实例,说明自动生成Makefile的详细过程

    为了编译一个简单的源文件main.c,需要自动生成一个makefile,以下是步骤: 第一步:----------在/root/project/main目录下创建一个文件main.c,其内容如下:-- ...

  4. CSS3背景总结

    值 描述 CSS background-color 规定要使用的背景颜色. 1 background-position 规定背景图像的位置. 1 background-size 规定背景图片的尺寸. ...

  5. 一个很好用的系统管理的命令lsof(转载)

    最近发现LOSF 命令在系统管理方面特别有用,把我搜集的资料总结如下 1.当在lsof后边没有跟任何参数时,该命令将会列出当前系统中被所有进程打开的所有文件#lsof|nl #nl命令打印出行号 2. ...

  6. 本地vagrant配置虚拟域名的坑

    修改 /usr/local/php56/etc/php.d/Zend.ini   文件 将developer.zl的路径加上去 修改nginx 的vhost里面的xx.com.conf 和上一级目录的 ...

  7. oracle 存储过程学习感悟

    1.跟大白话差不多 2.if...then.... else ....写的比较多 3.调用存储过程命令:execute procedure_name 4.调用存储函数命令:select '0' str ...

  8. Linux kernel 之 kobject

    总听有人说 Linux kernel 拥有一团无比巨大看似杂乱无章其实有迹可循的链表,今天参考一下其他大牛的相关资料记录一下. kset 结构体 151 /** 152 * struct kset - ...

  9. fontDialog-字体对话框和colorDialog-颜色对话框

    private void button1_Click(object sender, EventArgs e) { DialogResult dr = fontDialog1.ShowDialog(); ...

  10. CSS(二):选择器

    一.基本选择器 1.标签选择器 HTML标签作为标签选择器的名称,例如<h1>~<h6>.<p>等. 语法: p{font-size: 16px;} p:标签选择器 ...