Android 怎么获取 umeng 的 渠道信息

Android 怎么获取 umeng 的 渠道信息,第1张

Andriod版本APP获取umeng的渠道信息,可以让技术人员在程序中嵌入渠道编码,具体步骤如下:

进入友盟网站,注册帐号,绑定友盟应用统计

下载友盟SDK文件,由技术开发人员嵌入到APP程序代码中,具体 *** 作方法可以参考友盟网站的嵌入指南;

根据安卓版本不同的发布渠道,定义好channel ID;

修改代码中与channel相关的代码,比如将<meta-data android:value="Channel ID" android:name="UMENG_CHANNEL"/> 中的Channel ID替换为您应用的推广渠道名称,channel id自定义。

对应每个渠道生成一一对应的APK安装包;

将标记好Channel ID的渠道安装包,在对应的渠道发布;

定时登录友盟后台查看渠道数据。

获取友盟渠道名

/**

* 获取渠道名

* @param ctx 此处习惯性的设置为activity,实际上context就可以

* @return 如果没有获取成功,那么返回值为空

*/

public static String getChannelName(Activity ctx) {

if (ctx == null) {

return null

}

String channelName = null

try {

PackageManager packageManager = ctx.getPackageManager()

if (packageManager != null) {

//注意此处为ApplicationInfo 而不是 ActivityInfo,因为友盟设置的meta-data是在application标签中,而不是某activity标签中,所以用ApplicationInfo

ApplicationInfo applicationInfo = packageManager.getApplicationInfo(ctx.getPackageName(), PackageManager.GET_META_DATA)

if (applicationInfo != null) {

if (applicationInfo.metaData != null) {

<span style="white-space:pre"></span>//key换成说需要的key

channelName = applicationInfo.metaData.getString(key)

}

}

}

} catch (PackageManager.NameNotFoundException e) {

e.printStackTrace()

}

return channelName

}

提取为通用方法:

/**

* 获取application中指定的meta-data

* @return 如果没有获取成功(没有对应值,或者异常),则返回值为空

*/

public static String getAppMetaData(Context ctx, String key) {

if (ctx == null || TextUtils.isEmpty(key)) {

return null

}

String resultData = null

try {

PackageManager packageManager = ctx.getPackageManager()

if (packageManager != null) {

ApplicationInfo applicationInfo = packageManager.getApplicationInfo(ctx.getPackageName(), PackageManager.GET_META_DATA)

if (applicationInfo != null) {

if (applicationInfo.metaData != null) {

resultData = applicationInfo.metaData.getString(key)

}

}

}

} catch (PackageManager.NameNotFoundException e) {

e.printStackTrace()

}

return resultData

}

Android 统计分析 SDK使用指南

1. 建立App,下载SDK

登录你的帐号后,看到友盟的管理后台,点击"+添加新应用",进入新应用信息填写的页面。

App建立成功后,可以获得该App的AppKey,以及最新的开发指南和SDK文件。

可在 这里 下载SDK,包含开发文档,demo程序和jar包。

说明:在新应用信息填写中,请尽量填写真实的信息。您可以通过友盟统计分析平台的特性节省重复建立App的时间。

如果您要对App不同的发布渠道进行统计,不需要创建新App,请使用分发渠道分析,通过分发渠道分析,您可以更方便的对比数据。

2. 实现基本的使用基本统计实现本的页面跳转,机型,分辨率,地理位置 …的统计1. 导入umeng-sdk*.jar(简称SDK)下载最新版sdk的zip包,解压将其中的umeng-sdk.jar释放到本地目录,Eclipse用户右键您的工程根目录,选择Properties ->Java Build Path ->Libraries, 然后点击 Add External JARs... 选择指向 Analytics_Android_SDK_*.jar的路径,点击OK,即导入成功。

2. 配置 AndroidManifest.xml<manifest……><application ……> ……<activity ……/><meta-dataandroid:value="YOUR_APP_KEY"android:name="UMENG_APPKEY"></meta-data><meta-dataandroid:value="Channel ID"android:name="UMENG_CHANNEL"/></application><uses-sdkandroid:minSdkVersion="4"></uses-sdk><uses-permissionandroid:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission><uses-permissionandroid:name="android.permission.INTERNET"></uses-permission><uses-permissionandroid:name="android.permission.READ_PHONE_STATE"></uses-permission><uses-permissionandroid:name="android.permission.READ_LOGS"></uses-permission></manifest>说明:

META-DATA用途

UMENG_APPKEY用来定位该应用程序的唯一性。

UMENG_CHANNEL用来标注应用推广渠道,区分新用户的来源来查看统计,您可以使用20位以内的英文和数字为渠道定名,替换value中的"Channel ID"。详见渠道统计。

权限用途

INTERNET(必须)允许应用程序联网,以便向我们的服务器端发送数据。

READ_PHONE_STATE(必须)获取用户手机的IMEI,用来唯一的标识用户。(如果您的应用会运行在无法读取IMEI的平板上,我们会将mac地址作为用户的唯一标识,请添加权限: android.permission.ACCESS_WIFI_STATE )

ACCESS_NETWORK_STATE检测网络状态,友盟SDK 1.6版本新增权限。

READ_LOGS如果您想获得客户端crash的报告, 需要添加这个权限。具体见【使用错误报告】。

WRITE_EXTERNAL_STORAGE如果您使用了友盟自动更新提醒功能,需添加这个权限,为了将更新的APK临时存在SD卡里。

3. 添加代码

添加引用: import com.umeng.analytics.MobclickAgent

注册 Activity: 在每个Activity的onResume方法中调用 MobclickAgent.onResume(Context), onPause方法中调用

MobclickAgent.onPause(Context)

publicvoid onResume() {super.onResume() MobclickAgent.onResume(this)}publicvoid onPause() {super.onPause() MobclickAgent.onPause(this)}API:public void onResume(Context context)

context 当前Activity的引用,这里请不要将全局的application context传入。

public void onPause(Context context)

context 当前Activity的引用,这里请不要将全局的application context传入。

API说明:

void onResume(Context context)

context 当前Activity引用

void onPause(Context context)

context 当前Activity引用

说明:

方法将会自动地从AndroidManifest.xml文件里读取Appkey。

确保在所有的activity中都调用 MobclickAgent.onResume() 和MobclickAgent.onPause()方法,这两个调用将不会阻塞应用程序的主线程,也不会影响应用程序的性能。

注意如果您的Activity之间有继承或者控制关系请不要同时在父和子Activity中重复添加onPause和onResume方法,否则会造成重复统计(eg.使用TabHost、TabActivity、ActivityGroup时)。

一个应用程序在多个activity之间连续切换时,将会被视为同一个session(启动)。

当用户两次使用之间间隔超过30秒时,将被认为是两个的独立的session(启动),例如用户回到home,或进入其他程序,经过一段时间后再返回之前的应用。

4. 测试

确认所需的权限都已经添加:INTERNET, READ_PHONE_STATE, (READ_LOGS, WRITE_EXTERNAL_STORAGE)

确认APPKEY已经正确的写入Androidmanifest.xml

确认所有的Activity中都调用了onResume和onPause方法

确认测试手机(或者模拟器)已成功连入网络

启动应用程序,几分钟之后您应该已经可以看到相应的报表.

3. 使用错误报告友盟统计分析工具,还可以帮助您捕捉用户在使用应用程序过程中出现的异常退出(FC), 并在应用程序下次启动时将错误报告发送给服务器。

1. 自动捕获异常退出(FC)

在AndroidManifest.xml里面添加权限android.permission.READ_LOGS

在程序的Main Activity(应用程序入口)的onCreate方法里调用MobclickAgent.onError(Context).

publicvoid onCreate(Bundle savedinstanceState) {super.onCreate(savedInstanceState) MobclickAgent.onError(this) ...}API:public void onError(Context context)

context 当前Activity的引用

说明:错误报告包含应用程序版本, *** 作系统版本和设备型号以及程序出现异常时的Stacktrace,这些数据将帮助您修正应用程序的Bug。

2. 手动发送错误报告如果您自己捕获了程序中的异常,但是依然希望,将这次异常信息发送到友盟的服务器,您可以调用下面的函数。

MobclickAgent.reportError(Context context,String error) API:public void reportError(Context context, String error)

context 当前Activity的引用

error 开发者手动捕获的错误信息

说明:手动发送的异常信息和自动捕获的异常信息一样,都会展示在错误报告面板。

4. 使用自定义事件除了基本统计分析功能外,我们还支持您自定义的事件分析,例如您可以统计游戏中通过不同关卡的人数,广告的点击次数或者视频被播放的次数等等。 使用自定义事件功能请先在网站应用管理后台(设置->编辑自定义事件)中添加相应的自定义事件后,服务器才会对相应的自定义事件请求进行处理。

1. 事件数量统计1. 在您希望跟踪的代码部分,调用如下方法:MobclickAgent.onEvent(Context context, String event_id)API:public void onEvent(Context context, String event_id)

context 当前Activity的引用

event_id 为当前统计的事件ID,注意要先在友盟网站上注册此事件ID。

示例:统计微博应用中“转发"事件发生的次数,那么在“转发"的函数里调用

MobclickAgent.onEvent(this, "Forward") 2. 记录事件的不同属性及取值,调用如下方法:MobclickAgent.onEvent(Context context, String event_id, Map<String,String>map)API:public voidonEvent(Context context, String event_id, Map map)

context 当前Activity的引用

event_id 为当前统计的事件ID,注意要先在友盟网站上注册此事件ID。

map 为当前事件的属性和取值集合(key-value)

示例:MobclickAgent.onEvent(LoginActivity.this, "sinaLogin")

新浪用户登陆海知笔记

3. 考虑事件在一个属性上的取值,可以调用如下方法:MobclickAgent.onEvent(Context context, String event_id, String label)API:public void onEvent(Context context, String event_id, String label)

context 当前Activity的引用

event_id 为当前统计的事件ID,注意要先在友盟网站上注册此事件ID.

label 事件的一个属性描述

示例:统计游戏中“死亡"事件发生的关卡数,那么可以在死亡的函数里调用

MobclickAgent.onEvent(this, "player_dead","level")2. 事件时长统计有的事件是持续发生的,需要记录其持续的时间,这里提供两种解决方法。

1. 在事件开始和结束时分别调用onEventBegin和 onEventEnd两个函数。MobclickAgent.onEventBegin(Context context, String event_id)...MobclickAgent.onEventEnd(Context context, String event_id)API:public voidonEventBegin(Context context, String event_id)

public void onEventEnd(Context context, String event_id)

context 当前Activity引用

event_id 为当前统计的事件ID,注意要先在友盟网站上注册此事件ID.

public void onEventBegin(Context context, String event_id, String label)

public void onEventEnd(Context context, String event_id, String label)

context 当前Activity引用

event_id 为当前统计的事件ID,注意要先在友盟网站上注册此事件ID.

label 事件的一个属性描述

示例:跟踪播放音乐事件发生的总时间,在音乐播放开始时调用:

MobclickAgent.onEventBegin(this, "music_play")在音乐播放结束时调用:

MobclickAgent.onEventEnd(this, "music_play")2. 跟踪时长的事件包含多个属性,在事件开始和结束时分别调用onKVEventBegin和 onKVEventEnd两个函数MobclickAgent.onKVEventBegin(Context context, String event_id, Map<String,String>map, String ekvFlag)...MobclickAgent.onKVEventEnd(Context context, String event_id, String ekvFlag)API:public void onKVEventBegin(Context context, String event_id, Map map, String ekvFlag)

context 当前Activity引用

event_id 为当前统计的事件ID,注意要先在友盟网站上注册此事件ID.

map 为当前事件的属性和取值集合(key-value)

ekvFlag 事件标示符

public void onKVEventEnd(Context context, String event_id, String ekvFlag)

context 当前Activity引用

event_id 为当前统计的事件ID,注意要先在友盟网站上注册此事件ID

ekvFlag 事件标示符,ekvFlag 和 event_id 一起标示一个唯一事件,并不会被统计;对于同一个事件,在onKVEventBegin和onKVEventEnd 中要传递相同的event_id 和 flag

示例跟踪每种类型的音乐播放了多久,在音乐播放开始时调用

Map<String,String>music = new HashMap<String,String>() music.put("type", "popular") music.put("artist", "JJLin") music.put("User_status", "registered")MobclickAgent.onKVEventBegin(this, "music",music,"m7")在音乐播放结束时调用:

MobclickAgent.onKVEventEnd(this, "music",music,"m7")3. 自己计算并上传event时长,在您想跟踪时长的代码部分,调用如下方法:MobclickAgent.onEventDuration(Context context, String event_id, long duration)orMobclickAgent.onEventDuration(Context context, String event_id,String label, long duration)orMobclickAgent.onEventDuration(Context context, String event_id, Map<String, String>map, long duration)API:public void onEventDuration(Context context, String event_id, long duration)

public void onEventDuration(Context context, String event_id,String label, long duration)

context 当前Activity引用

event_id 为当前统计的事件ID,注意要先在友盟网站上注册此事件ID

label 事件的一个属性描述

duration 事件持续时长,单位毫秒,您需要手动计算并传入时长,作为事件的时长参数

public void onEventDuration(Context context, String event_id, Map map, long duration)

context 当前Activity引用

event_id 为当前统计的事件ID,注意要先在友盟网站上注册此事件ID

map 为当前事件的属性和取值集合(key-value)

duration 事件持续时长,单位毫秒,您需要手动计算并传入时长,作为事件的时长参数

说明

时长是友盟统计的一个新功能,使用过程中可能会出现一些常见的错误,开发者应该尽量的避免,这里有一些可能出错的案例。

每个event的key不能超过10个,event ID、map中key和value都不能使用特殊字符,且长度不能超过255个字符(否则将截取前255个字符),“id", “ts", “du"是保留字段,不能作为event ID及key的名称

5. 使用分发渠道分析有时需要统计应用程序的分发渠道,例如有多少用户来从联想乐园下载了您的应用,又有多少用户通过Google android market下载到您的应用程序。您只需要在AndroidManifest.xml里添加meta-data,并将 value属性修改为对应的发布渠道名。

配置AndroidManifest.XML添加下面代码

<application ……><activity ……/><meta-dataandroid:value="Channel ID"android:name="UMENG_CHANNEL"/></application>当然,这需要您在不同渠道发布应用程序时,重新编译打包。

说明

不要改变'UMENG_CHANNEL',修改'Channel ID'为您的渠道名称,注意不能是纯数字(eg.value="AndroidMarket")。

每台设备只记录第一次统计到的渠道,您如果在测试的时候发现渠道统计到的设备数量不增加,很可能是因为您用同一个设备修改过渠道号,您换一台设备测试即可。

6. 使用在线配置功能这个功能目前可以帮你在网站上动态配置两种类型的参数:

自定义key-value型的键值对

数据发送策略

在程序的入口Activity的OnCreate()方法中调用

publicvoid onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState) MobclickAgent.updateOnlineConfig(this)}API:public voidupdateOnlineConfig(Context context)


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11768748.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存