<activity
android:name=“com.mob.tools.MobUIShell”
android:theme="@android:style/Theme.Translucent.NoTitleBar"
android:configChanges=“keyboardHidden|orientation|screenSize”
android:screenOrientation=“portrait”
android:windowSoftInputMode=“stateHidden|adjustResize” >
注意: MobUIShell的路径是固定的,一定要在“cn.sharesdk.framework”下,因为它在Share-Core中。
将上面代码平台AppId处修改成申请到的AppId即可 。
如果项目集成了微信,还需要添加以下WXEntryActivity,不然的话,mob后台无法做微信的分享统计:(在工程的包下新建wxapi目录再放置WXEntryActivity)
WXEntryActivity.java
package com.smyhvae.sharedemo.wxapi;
import android.content.Intent;
import android.widget.Toast;
《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》
浏览器打开:qq.cn.hn/FTe 免费领取
import cn.sharesdk.wechat.utils.WXAppExtendObject;
import cn.sharesdk.wechat.utils.WXMediaMessage;
import cn.sharesdk.wechat.utils.WechatHandlerActivity;
/** 微信客户端回调activity示例 */
public class WXEntryActivity extends WechatHandlerActivity {
/**
-
处理微信发出的向第三方应用请求app message
-
-
在微信客户端中的聊天页面有“添加工具”,可以将本应用的图标添加到其中
-
此后点击图标,下面的代码会被执行。Demo仅仅只是打开自己而已,但你可
-
做点其他的事情,包括根本不打开任何页面
*/
public void onGetMessageFromWXReq(WXMediaMessage msg) {
Intent iLaunchMyself = getPackageManager().getLaunchIntentForPackage(getPackageName());
startActivity(iLaunchMyself);
}
/**
-
处理微信向第三方应用发起的消息
-
-
此处用来接收从微信发送过来的消息,比方说本demo在wechatpage里面分享
-
应用时可以不分享应用文件,而分享一段应用的自定义信息。接受方的微信
-
客户端会通过这个方法,将这个信息发送回接收方手机上的本demo中,当作
-
回调。
-
-
本Demo只是将信息展示出来,但你可做点其他的事情,而不仅仅只是Toast
*/
public void onShowMessageFromWXReq(WXMediaMessage msg) {
if (msg != null && msg.mediaObject != null
&& (msg.mediaObject instanceof WXAppExtendObject)) {
WXAppExtendObject obj = (WXAppExtendObject) msg.mediaObject;
Toast.makeText(this, obj.extInfo, Toast.LENGTH_SHORT).show();
}
}
}
接下来配置的是微信回调activity的配置(如果不需要的平台可以不配置的)
<activity
android:name=".wxapi.WXEntryActivity"
android:configChanges=“keyboardHidden|orientation|screenSize”
android:exported=“true”
android:screenOrientation=“portrait”
android:theme="@android:style/Theme.Translucent.NoTitleBar"/>
3. 添加代码
(1)在项目的入口Activity,在其onCreate方法中插入下面的代码进行初始化
ShareSDK.initSDK(this);
(2)在项目Activity的onDestroy方法中第一行中加入
ShareSDK.stopSDK(this);
(3)调用onekeyshare的界面分享
private void showShare() {
OnekeyShare oks = new OnekeyShare();
//关闭sso授权
oks.disableSSOWhenAuthorize();
// title标题,印象笔记、邮箱、信息、微信、人人网和QQ空间等使用
oks.setTitle(“标题”);
// titleUrl是标题的网络链接,QQ和QQ空间等使用
oks.setTitleUrl(“http://sharesdk.cn”);
// text是分享文本,所有平台都需要这个字段
oks.setText(“我是分享文本”);
// imagePath是图片的本地路径,Linked-In以外的平台都支持此参数
//oks.setImagePath("/sdcard/test.jpg");//确保SDcard下面存在此张图片
// url仅在微信(包括好友和朋友圈)中使用
oks.setUrl(“http://sharesdk.cn”);
// comment是我对这条分享的评论,仅在人人网和QQ空间使用
oks.setComment(“我是测试评论文本”);
// site是分享此内容的网站名称,仅在QQ空间使用
oks.setSite(getString(R.string.app_name));
// siteUrl是分享此内容的网站地址,仅在QQ空间使用
oks.setSiteUrl(“http://sharesdk.cn”);
// 启动分享GUI
oks.show(this);
}
这是官方给出的配置onekeyshare的代码
(4)activity_main.xml布局文件(添加Button)
<Button
android:id="@+id/button"
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:text=“分享”/>
(5)自己写个showShare()方法,里面onekeyshare的对象调用分享参数,调用show方法启动我们默认的界面;
五. 运行效果