Android开发笔记(一百零七)统计分析SDK

APP统计分析

用户画像

对程序员来说,用户画像就是用户的属性和行为;通俗地说,用户画像是包括了个人信息、兴趣爱好、日常行为等血肉丰满的客户实体。用户画像是精准营销的产物,企业通过收集用户的行为,然后分析出用户的特征与偏好,进而挖掘潜在的商业价值,实现企业效益的最大化。


用户画像的一个具体应用是电商app的“猜你喜欢”栏目,电商平台通过对用户购买过的商品进行统计,可以分析用户日常生活用的是什么物品;电商平台还可以对用户的搜索行为、浏览行为进行统计,从中分析用户感兴趣的商品,或者说考虑购买的商品。电商平台得到包括日常生活、兴趣爱好、购买意向在内的用户画像后,自然就能有针对性的向用户推荐合适的商品,从而扩大销量、增加营业额。


下图是用户画像的一个具体例子
Android开发笔记(一百零七)统计分析SDK_第1张图片


统计分析的内容

app进行统计分析,主要有两方面的内容:
一、用户行为统计,包括
1、用户打开和关闭页面,以及在页面的停留时长;
2、用户点击行为的分布与频率;
3、用户输入的文字和图片,如搜索时的关键词、二维码的扫描信息、分享的图文内容等等;
4、用户对多媒体信息的接受程序,如听音乐的时长、看视频的时长等等;
二、运行情况分析,包括
1、app的启动时间;
2、app崩溃的日志信息;
3、app杀死进程;


友盟统计

集成步骤

1、在libs目录加入下面sdk包:
umeng-analytics-v6.0.1.jar
utdid4all-1.0.4.jar
2、在AndroidManifest.xml中补充权限定义,以及meta-data参数定义,包括UMENG_APPKEY、UMENG_CHANNEL等等,其中UMENG_APPKEY需要到友盟网站上注册申请;
3、代码里先设置采集参数,然后开始采集行为事件;


MobclickAgent

友盟统计分析主要用到MobclickAgent类。下面是MobclickAgent类与设置有关的方法说明:
setDebugMode : 设置是否开启调试模式。true为开启调试,false为关闭调试。
setSessionContinueMillis : 设置session的持续时间,单位毫秒。
startWithConfigure : 设置友盟的统计分析配置。该方法的参数是UMAnalyticsConfig对象,包含了appkey、渠道号、是否启用崩溃采集等等信息。
openActivityDurationTrack : 设置是否开启默认的Activity页面统计方式。true为开启,false为关闭。
setAutoLocation : 设置是否自动定位。
注意,友盟sdk的发送策略不在代码中设置,要在友盟的后台管理页面中设置。具体步骤为:点击应用名称->设置->发送策略,目前有两种:启动时发送(默认)、按间隔发送。
友盟sdk的老版本还提供了实时发送与仅在wifi下发送两种策略,但在新版本中取消了,原因如下:
1、实时发送会存在大量冗余字段的重复发送的现象,造成终端用户不必要的流量消耗;
2、仅在wifi下发送,数据的延迟会非常严重,造成数据统计结果的失真;


下面是MobclickAgent类与事件有关的方法说明:
onPageStart : 页面启动事件。
onPageEnd : 页面结束事件。
onResume : 恢复统计。
onPause : 暂停统计。
onEvent : 普通事件,一般是点击事件。
onEventValue : 复杂事件,比如说音乐播放事件。
onSocialEvent : 社会化分享事件。
onProfileSignIn : 登录事件。
onProfileSignOff : 注销事件。
onKillProcess : 杀死进程事件。


下面是友盟统计分析的代码例子:
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.os.Bundle;
import android.view.KeyEvent;
import android.view.View;

import com.example.exmanalysis.umeng.analytics.FragmentStack;
import com.example.exmanalysis.umeng.analytics.FragmentTabs;
import com.example.exmanalysis.umeng.analytics.WebviewAnalytic;
import com.umeng.analytics.MobclickAgent;
import com.umeng.analytics.MobclickAgent.EScenarioType;
import com.umeng.analytics.social.UMPlatformData;
import com.umeng.analytics.social.UMPlatformData.GENDER;
import com.umeng.analytics.social.UMPlatformData.UMedia;

public class UmengActivity extends Activity {
    private final static String TAG = "UmengActivity";
    private Context mContext;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_umeng);

        mContext = this;
        MobclickAgent.setDebugMode(true);
        // SDK在统计Fragment时,需要关闭Activity自带的页面统计,
        // 然后在每个页面中重新集成页面统计的代码(包括调用了 onResume 和 onPause 的Activity)。
        MobclickAgent.openActivityDurationTrack(false);
        // MobclickAgent.setAutoLocation(true);
        // MobclickAgent.setSessionContinueMillis(1000);
        // MobclickAgent.startWithConfigure(
        // new UMAnalyticsConfig(mContext, "4f83c5d852701564c0000011", "Umeng", EScenarioType.E_UM_NORMAL));
        MobclickAgent.setScenarioType(mContext, EScenarioType.E_UM_NORMAL);
    }

    @Override
    public void onResume() {
        super.onResume();
        MobclickAgent.onPageStart(TAG);
        MobclickAgent.onResume(mContext);
    }

    @Override
    public void onPause() {
        super.onPause();
        MobclickAgent.onPageEnd(TAG);
        MobclickAgent.onPause(mContext);
    }

    public void onButtonClick(View view) {
        int id = view.getId();
        switch (id) {
        case R.id.umeng_example_analytics_event_cc:
            List keyPath = new ArrayList();
            keyPath.add("one");
            keyPath.add("two");
            keyPath.add("tree");
            MobclickAgent.onEvent(mContext, keyPath, 20, "label");
            break;
        case R.id.umeng_example_analytics_event:
            MobclickAgent.onEvent(mContext, "click");
            MobclickAgent.onEvent(mContext, "click", "button");
            break;
        case R.id.umeng_example_analytics_ekv:
            Map map_ekv = new HashMap();
            map_ekv.put("type", "popular");
            map_ekv.put("artist", "JJLin");

            MobclickAgent.onEvent(mContext, "music", map_ekv);
            break;
        case R.id.umeng_example_analytics_duration:

            Map map_value = new HashMap();
            map_value.put("type", "popular");
            map_value.put("artist", "JJLin");

            MobclickAgent.onEventValue(this, "music", map_value, 12000);
            break;
        case R.id.umeng_example_analytics_make_crash:
            "123".substring(10);
            break;
        case R.id.umeng_example_analytics_js_analytic:
            startActivity(new Intent(this, WebviewAnalytic.class));
            break;
        case R.id.umeng_example_analytics_fragment_stack:
            startActivity(new Intent(this, FragmentStack.class));
            break;
        case R.id.umeng_example_analytics_fragment_tabs:
            startActivity(new Intent(this, FragmentTabs.class));
            break;
        case R.id.umeng_example_analytics_social:

            UMPlatformData platform = new UMPlatformData(UMedia.SINA_WEIBO, "user_id");
            platform.setGender(GENDER.MALE); // optional
            platform.setWeiboId("weiboId"); // optional

            MobclickAgent.onSocialEvent(this, platform);
            break;
        case R.id.umeng_example_analytics_signin:
            MobclickAgent.onProfileSignIn("example_id");
            break;

        case R.id.umeng_example_analytics_signoff:
            MobclickAgent.onProfileSignOff();
            break;
        }
    }

    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event) {
        if (keyCode == KeyEvent.KEYCODE_BACK) {
            Hook();
            return true;
        }

        return super.onKeyDown(keyCode, event);
    }

    // /对于好多应用,会在程序中杀死 进程,这样会导致我们统计不到此时Activity结束的信息,
    // /对于这种情况需要调用 'MobclickAgent.onKillProcess( Context )'
    // /方法,保存一些页面调用的数据。正常的应用是不需要调用此方法的。
    private void Hook() {
        AlertDialog.Builder builder = new AlertDialog.Builder(mContext);
        builder.setPositiveButton("退出应用", new DialogInterface.OnClickListener() {
            public void onClick(DialogInterface dialog, int whichButton) {
                MobclickAgent.onKillProcess(mContext);

                int pid = android.os.Process.myPid();
                android.os.Process.killProcess(pid);
            }
        });
        builder.setNeutralButton("后退一下", new DialogInterface.OnClickListener() {
            public void onClick(DialogInterface dialog, int whichButton) {
                finish();
            }
        });
        builder.setNegativeButton("点错了", new DialogInterface.OnClickListener() {
            public void onClick(DialogInterface dialog, int whichButton) {
            }
        });
        builder.show();
    }
}


百度统计

集成步骤

1、在libs目录加入下面sdk包:
libcrash_analysis.so
user_profile_mtj_1.5.jar
2、在AndroidManifest.xml中补充权限定义,以及meta-data参数定义,包括BaiduMobAd_STAT_ID、BaiduMobAd_CHANNEL等等,其中BaiduMobAd_STAT_ID需要到百度网站上注册申请;
3、代码里先设置采集参数,然后开始采集行为事件;


StatService

百度统计分析主要用到StatService类。下面是与设置有关的方法说明:
setDebugOn : 设置是否开启调试模式。true为开启调试,false为关闭调试。
setSessionTimeOut : 设置session的超时时间,单位秒。
setAppKey : 设置appkey。建议在AndroidManifest.xml中填写。
setAppChannel : 设置应用的渠道。
setOn : 打开崩溃错误收集。默认是关闭的
setLogSenderDelayed : 设置启动时日志发送的延时,单位秒。
setSendLogStrategy : 设置日志发送的策略。SendStrategyEnum.APP_START表示应用启动时发送,SendStrategyEnum.ONCE_A_DAY表示每天发送一次,SendStrategyEnum.SET_TIME_INTERVAL表示固定时间间隔发送。


下面是与事件有关的方法说明:
onPageStart : 页面启动事件。
onPageEnd : 页面结束事件。
onResume : 恢复统计。
onPause : 暂停统计。
onEvent : 普通事件,一般是点击事件
onEventDuration : 持续一段时间的事件。
onEventStart : 事件开始。
onEventEnd : 事件结束。


下面是百度统计分析的代码例子:
import android.app.Activity;
import android.content.Intent;
import android.os.Build;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;

import com.baidu.mobstat.NativeCrashHandler;
import com.baidu.mobstat.SendStrategyEnum;
import com.baidu.mobstat.StatService;
import com.example.exmanalysis.baidu.AnotherDemoActivity1;
import com.example.exmanalysis.baidu.Conf;
import com.example.exmanalysis.baidu.DemoActivity2;
import com.example.exmanalysis.baidu.DemoActivity3;
import com.example.exmanalysis.baidu.WebViewActivity;
import com.example.exmanalysis.baidu.appfragment.AppFragmentDemoActivity;
import com.example.exmanalysis.baidu.supportv4fragment.MainFragmentActivity;

public class BaiduActivity extends Activity {
    private Button btnPrev;
    private Button btnNext;
    private Button btnWebview;
    private Button btnException;
    private Button btnNativeException;
    private Button btnSetTV;
    private Button btnEvent;
    private Button btnEventDuration;
    private Button btnEventStart;
    private Button btnEventEnd;
    private Button btnFragmentPage;
    private Button btnAppFragmentPage;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.baidu_activity);
        boolean isWear = getPackageManager().hasSystemFeature("android.hardware.type.watch");
        Log.e("TEST", "isWear: " + isWear);
        Log.e("TEAT", "manufacturer: " + Build.MANUFACTURER);

        // 设置AppKey
        // StatService.setAppKey("a9e2ad84a2"); // appkey必须在mtj网站上注册生成,该设置建议在AndroidManifest.xml中填写,代码设置容易丢失

        /*
         * 设置渠道的推荐方法。该方法同setAppChannel(String), 如果第三个参数设置为true(防止渠道代码设置会丢失的情况),将会保存该渠道,每次设置都会更新保存的渠道,
         * 如果之前的版本使用了该函数设置渠道,而后来的版本需要AndroidManifest.xml设置渠道,那么需要将第二个参数设置为空字符串,并且第三个参数设置为false即可。
         * appChannel是应用的发布渠道,不需要在mtj网站上注册,直接填写就可以 该参数也可以设置在AndroidManifest.xml中
         */
        // StatService.setAppChannel(this, "RepleceWithYourChannel", true);
        // 测试时,可以使用1秒钟session过期,这样不断的间隔1S启动退出会产生大量日志。
        StatService.setSessionTimeOut(30);
        // setOn也可以在AndroidManifest.xml文件中填写,BaiduMobAd_EXCEPTION_LOG,打开崩溃错误收集,默认是关闭的
        StatService.setOn(this, StatService.EXCEPTION_LOG);
        /*
         * 设置启动时日志发送延时的秒数
单位为秒,大小为0s到30s之间
注:请在StatService.setSendLogStrategy之前调用,否则设置不起作用 * * 如果设置的是发送策略是启动时发送,那么这个参数就会在发送前检查您设置的这个参数,表示延迟多少S发送。
这个参数的设置暂时只支持代码加入, * 在您的首个启动的Activity中的onCreate函数中使用就可以。
*/ StatService.setLogSenderDelayed(0); /* * 用于设置日志发送策略
嵌入位置:Activity的onCreate()函数中
* * 调用方式:StatService.setSendLogStrategy(this,SendStrategyEnum. SET_TIME_INTERVAL, 1, false); 第二个参数可选: * SendStrategyEnum.APP_START SendStrategyEnum.ONCE_A_DAY SendStrategyEnum.SET_TIME_INTERVAL 第三个参数: * 这个参数在第二个参数选择SendStrategyEnum.SET_TIME_INTERVAL时生效、 取值。为1-24之间的整数,即1<=rtime_interval<=24,以小时为单位 第四个参数: * 表示是否仅支持wifi下日志发送,若为true,表示仅在wifi环境下发送日志;若为false,表示可以在任何联网环境下发送日志 */ StatService.setSendLogStrategy(this, SendStrategyEnum.SET_TIME_INTERVAL, 1, false); // 调试百度统计SDK的Log开关,可以在Eclipse中看到sdk打印的日志,发布时去除调用,或者设置为false StatService.setDebugOn(true); String sdkVersion = StatService.getSdkVersion(); TextView sdkVersionTxtv = (TextView) findViewById(R.id.tv_sdk_version); if (sdkVersion != null) { sdkVersionTxtv.setText("sdk version is: " + sdkVersion); } btnPrev = (Button) findViewById(R.id.layout1_btn1); btnNext = (Button) findViewById(R.id.layout1_btn2); btnWebview = (Button) findViewById(R.id.layout1_btn_web_view); btnException = (Button) findViewById(R.id.layout1_btn_excep); btnNativeException = (Button) findViewById(R.id.layout1_btn_native_excep); btnNativeException.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { NativeCrashHandler.doNativeCrash(); } }); btnSetTV = (Button) findViewById(R.id.layout1_btn_set_TV); btnSetTV.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { StatService.setForTv(BaiduActivity.this, true); } }); btnEvent = (Button) findViewById(R.id.layout1_btn_event); btnEventDuration = (Button) findViewById(R.id.layout1_btn_event_duration); btnEventStart = (Button) findViewById(R.id.layout1_btn_event_start); btnEventEnd = (Button) findViewById(R.id.layout1_btn_event_end); btnFragmentPage = (Button) findViewById(R.id.layout1_fragment); btnAppFragmentPage = (Button) findViewById(R.id.layout1_app_fragment); findViewById(R.id.btn_another_process).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(BaiduActivity.this, AnotherDemoActivity1.class); startActivity(intent); } }); btnPrev.setOnClickListener(new OnClickListener() { public void onClick(View v) { Intent intent = new Intent(); intent.setClass(BaiduActivity.this, DemoActivity3.class); BaiduActivity.this.startActivity(intent); } }); btnNext.setOnClickListener(new OnClickListener() { public void onClick(View v) { Intent intent = new Intent(); intent.setClass(BaiduActivity.this, DemoActivity2.class); BaiduActivity.this.startActivity(intent); } }); btnWebview.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(); intent.setClass(BaiduActivity.this, WebViewActivity.class); BaiduActivity.this.startActivity(intent); } }); btnException.setOnClickListener(new OnClickListener() { public void onClick(View v) { Thread t = new Thread() { @Override public void run() { if (!MyApplication.SHIELD_EXCEPTION) { Log.w(Conf.TAG, 10 / 0 + ""); } } }; t.start(); } }); btnEvent.setOnClickListener(new OnClickListener() { public void onClick(View v) { StatService.onEvent(BaiduActivity.this.getApplicationContext(), "registered id", "pass", 1); } }); /** * 自定义事件的第一种方法,写入某个事件的持续时长 */ btnEventDuration.setOnClickListener(new OnClickListener() { public void onClick(View v) { // 事件id("registered id")的事件pass,其时长持续100毫秒 StatService.onEventDuration(BaiduActivity.this, "registered id", "pass", 100); } }); /* * 自定义事件的第二种方法,自己定义该事件的起始时间和结束时间 */ btnEventStart.setOnClickListener(new OnClickListener() { public void onClick(View v) { // 事件id("registered id")的事件pass,其时长持续10毫秒 StatService.onEventStart(BaiduActivity.this, "registered id", "pass"); // 必须和onEventEnd共用才行 } }); /* * 自定义事件的第二种方法,自己定义该事件的起始时间和结束时间 */ btnEventEnd.setOnClickListener(new OnClickListener() { public void onClick(View v) { // 事件id("registered id")的事件pass,其时长持续10毫秒 StatService.onEventEnd(BaiduActivity.this, "registered id", "pass"); // 必须和onEventStart共用才行 } }); btnFragmentPage.setOnClickListener(new OnClickListener() { public void onClick(View v) { Intent in = new Intent(); in.setClass(BaiduActivity.this, MainFragmentActivity.class); startActivity(in); } }); btnAppFragmentPage.setOnClickListener(new OnClickListener() { public void onClick(View v) { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) { Intent in = new Intent(); in.setClass(BaiduActivity.this, AppFragmentDemoActivity.class); startActivity(in); } } }); } public void onResume() { super.onResume(); //页面起始(每个Activity中都需要添加,如果有继承的父Activity中已经添加了该调用,那么子Activity中务必不能添加) //不能与StatService.onPageStart一级onPageEnd函数交叉使用 StatService.onResume(this); } public void onPause() { super.onPause(); //页面结束(每个Activity中都需要添加,如果有继承的父Activity中已经添加了该调用,那么子Activity中务必不能添加) //不能与StatService.onPageStart一级onPageEnd函数交叉使用 StatService.onPause(this); } }


腾讯统计

集成步骤

1、在libs目录加入下面sdk包:
libMtaNativeCrash.so
mid-sdk-2.3.jar
mta-android-stat-sdk-2.2.0_20160504.jar
2、在AndroidManifest.xml中补充权限定义,以及meta-data参数定义,包括TA_APPKEY、InstallChannel等等,其中TA_APPKEY需要到腾讯网站上注册申请;
3、代码里先设置采集参数,然后开始采集行为事件;


StatConfig

腾讯统计分析的参数设置用的是StatConfig类,主要方法说明如下:
setDebugEnable : 设置是否开启调试模式。true为开启调试,false为关闭调试。
setSessionTimoutMillis : 设置session的超时时间,单位秒。
setAppKey : 设置appkey。建议在AndroidManifest.xml中填写。
setInstallChannel : 设置安装的渠道。
setAutoExceptionCaught : 设置是否自动采集崩溃信息(即app未处理的异常)。true表示自动采集,false表示不采集。
setStatSendStrategy : 设置日志发送的策略。StatReportStrategy.PERIOD表示按时间间隔发送,StatReportStrategy.INSTANT实时发送即每个行为都立即发送,StatReportStrategy.ONLY_WIFI表示只在wifi网络下发送,StatReportStrategy.BATCH表示批量发送即达到缓存临界值时触发,StatReportStrategy.APP_LAUNCH表示应用启动时发送。
setEnableSmartReporting : 设置是否允许在WIFI网络下实时上报。
setSendPeriodMinutes : 设置日志发送的时间间隔。单位分钟,该方法在StatReportStrategy.PERIOD时启用。
setMaxStoreEventCount : 设置缓存中的事件最大数目。该方法在StatReportStrategy.BATCH时启用。


StatService

腾讯统计分析的事件跟踪用的是StatService类,主要方法说明如下:
startStatService : 开始统计服务。如果集成统计服务的是普通app,则无需调用该方法;如果提供出来的是第三方sdk,由于jar包不包含AndroidManifest.xml,因此必须在代码中调用该方法,才能启用统计服务。
onResume : 恢复统计。
onPause : 暂停统计。
addActionListener : 监听前后台状态。该方法的参数为StatActionListener对象,对象内部需实现两个方法,分别是前台运行onBecameForeground、后台运行onBecameBackground。
trackCustomEvent : 跟踪自定义事件。
trackCustomBeginEvent : 跟踪自定义事件开始。
trackCustomEndEvent : 跟踪自定义事件结束。
trackCustomKVEvent : 跟踪自定义的key-value事件。
trackCustomBeginKVEvent : 跟踪自定义的key-value事件开始。
trackCustomEndKVEvent : 跟踪自定义的key-value事件结束。
reportError : 上报错误信息。
reportException : 上报异常信息。


下面是腾讯统计分析的代码例子:
import java.util.HashMap;
import java.util.Map;
import java.util.Properties;

import android.app.Activity;
import android.app.ActivityManager;
import android.content.Context;
import android.os.Bundle;
import android.os.Environment;
import android.os.MemoryFile;
import android.util.Log;
import android.view.View;
import android.widget.Button;

import com.tencent.stat.StatAppMonitor;
import com.tencent.stat.StatConfig;
import com.tencent.stat.StatNativeCrashReport;
import com.tencent.stat.StatService;
import com.tencent.stat.StatServiceImpl;

public class TencentActivity extends Activity {
    private final static String TAG = "TencentActivity";

	private Context ctx = null;
	private Button btn_customevent_args_count = null;
	private Button btn_customevent_kv_count = null;
	private Button btn_customevent_args_duration_begin = null;
	private Button btn_customevent_args_duration_end = null;
	private Button btn_customevent_kv_duration_begin = null;
	private Button btn_customevent_kv_duration_end = null;
	private Button btn_report_error = null;
	private Button btn_report_exception = null;
	private Button btn_catch_unhandled_exception = null;
	private Button btn_init_nativeCrash = null;
	private Button btn_catch_native_crash = null;
	private Button btn_monitor_events = null;

	public void onActivityOpen() { // 你的函数
		Properties prop = new Properties();
		prop.setProperty("aty", "抢票活动"); // 活动页面
		prop.setProperty("gid", "潜在付费用户"); // 用户组名称
		prop.setProperty("attr", "1"); // 用户属性(年龄、性别等)
		prop.setProperty("act_type", "1"); // 行为类型(最近30天启动过、最近30天使用时长超过、最近30天是否有过升级行为等)
		prop.setProperty("act_val", "10"); // 行为取值
		StatService.trackCustomKVEvent(this, "mta_tag_activity_open", prop);
	}

	public void onActivityClick2() { // 你的函数
		Properties prop = new Properties();
		prop.setProperty("aty", "抢票活动"); // 活动页面
		prop.setProperty("btn", "报名"); // 按钮
		prop.setProperty("gid", "潜在付费用户"); // 用户组名称
		prop.setProperty("attr ", "1"); // 用户属性(年龄、性别等)
		prop.setProperty("act_type ", "1"); // 行为类型(最近30天启动过、最近30天使用时长超过、最近30天是否有过升级行为等)
		prop.setProperty("act_val ", "10"); // 行为取值
		StatService.trackCustomKVEvent(this, "mta_tag_activity_click", prop);
	}

	public void onUserPay() { // 你的函数
		Properties prop = new Properties();
		prop.setProperty("scene", "通关"); // 付费场景
		prop.setProperty("amount", "350"); // 付费金额
		prop.setProperty("way", "手机支付"); // 付费方式(可选择上报)
		StatService.trackCustomKVEvent(null, "mta_tag_user_pay", prop);
	}
	MemoryFile memoryFile = null;
	private View.OnClickListener l = new View.OnClickListener() {
		@Override
		public void onClick(View v) {
			Log.d(TAG, "ctx==" + ctx);
			int id = v.getId();
			switch (id) {
			case R.id.btn_customevent_args_count:
				StatService.trackCustomEvent(ctx, "trackCustomEvent", "args");
				StatService.trackCustomEvent(ctx, "id1", "args");
				StatService.trackCustomEvent(ctx, "id2", "");
				StatService.trackCustomEvent(ctx, "trackCustomEvent", null);
				StatServiceImpl.trackBackground(getApplicationContext(), 10, null);
				break;
			case R.id.btn_customevent_kv_count:
				Properties prop = new Properties();
				prop.setProperty("key", "value");
				prop.setProperty("key2", "value2");
				StatService.trackCustomKVEvent(ctx, "trackCustomKVEvent", prop);
				prop = new Properties();
				prop.setProperty("a", "b");
				StatService.trackCustomKVEvent(ctx, "4", prop);
				StatService.trackCustomKVEvent(ctx, "trackCustomKVEvent", prop);
				prop = new Properties();
				prop.setProperty("num", "3434");
				StatService.trackCustomKVEvent(ctx, "trackCustomKVEvent", prop);
				break;
			case R.id.btn_customevent_args_duration_begin:
				StatService.trackCustomBeginEvent(ctx, "trackCustomEvent", "loadConfigFile");
				break;
			case R.id.btn_customevent_args_duration_end:
				StatService.trackCustomEndEvent(ctx, "trackCustomEvent", "loadConfigFile");
				break;
			case R.id.btn_customevent_kv_duration_begin:
				Properties properties = new Properties();
				properties.setProperty("load", "config");
				StatService.trackCustomBeginKVEvent(ctx, "trackCustomEvent", properties);
				break;
			case R.id.btn_customevent_kv_duration_end:
				properties = new Properties();
				properties.setProperty("load", "config");
				StatService.trackCustomEndKVEvent(ctx, "trackCustomEvent", properties);
				break;
			case R.id.btn_report_error:
				StatService.reportError(ctx, "I hate error.");
				StatService.commitEvents(getApplicationContext(), -1);
				break;
			case R.id.btn_report_exception:
				try {
					String myNull = null;
					int length = myNull.length();
				} catch (NullPointerException ex) {
					StatService.reportException(ctx, ex);
				}
				break;
			case R.id.btn_monitor_events:
				// 新建监控接口对象
				StatAppMonitor monitor = new StatAppMonitor("ping:www.qq.com");
				// 接口开始执行
				String ip = "www.qq.com";
				Runtime run = Runtime.getRuntime();
				java.lang.Process proc = null;
				try {
					String str = "ping -c 3 -i 0.2 -W 1 " + ip;
					long starttime = System.currentTimeMillis();
					proc = run.exec(str);
					int retCode = proc.waitFor();
					long difftime = System.currentTimeMillis() - starttime;
					// 设置接口耗时
					monitor.setMillisecondsConsume(difftime);
					// 设置接口返回码
					monitor.setReturnCode(retCode);
					// 设置请求包大小,若有的话
					monitor.setReqSize(1000);
					// 设置响应包大小,若有的话
					monitor.setRespSize(2000);
					// 设置抽样率,默认为1,表示100%。如果是50%,则填2(100/50),如果是25%,则填4(100/25),以此类推。
					// monitor.setSampling(2);
					if (retCode == 0) {
						Log.d(TAG, "ping连接成功");
						// 标记为成功
						monitor.setResultType(StatAppMonitor.SUCCESS_RESULT_TYPE);
					} else {
						Log.d(TAG, "ping测试失败");
						// 标记为逻辑失败,可能由网络未连接等原因引起的,但对于业务来说不是致命的,是可容忍的
						monitor.setResultType(StatAppMonitor.LOGIC_FAILURE_RESULT_TYPE);
					}
				} catch (Exception e) {
					Log.d(TAG, e.getMessage());
					// 接口调用出现异常,致命的,标识为失败
					monitor.setResultType(StatAppMonitor.FAILURE_RESULT_TYPE);
				} finally {
					proc.destroy();
				}
				// 上报接口监控的信息
				StatService.reportAppMonitorStat(ctx, monitor);

				Map map = new HashMap();
				map.put("www.qq.com", 80);
				map.put("pingma.qq.com", 80);
				StatService.testSpeed(ctx, map);
				break;
			case R.id.btn_catch_unhandled_exception:
				int i = 1 / 0;
				break;
			case R.id.btn_init_nativeCrash:
				String tombfilepath = Environment.getExternalStorageDirectory()
						.getAbsolutePath() + "/my";
				StatConfig.initNativeCrashReport(ctx, null);
				break;
			case R.id.btn_catch_native_crash:
				StatNativeCrashReport.doNativeCrashTest();
				break;
			default:
				break;
			}
		}
	};

	String getCurProcessName(Context context) {
		int pid = android.os.Process.myPid();
		ActivityManager mActivityManager = (ActivityManager) context
				.getSystemService(Context.ACTIVITY_SERVICE);
		for (ActivityManager.RunningAppProcessInfo appProcess : mActivityManager
				.getRunningAppProcesses()) {
			if (appProcess.pid == pid) {
				return appProcess.processName;
			}
		}
		return null;
	}

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_tencent);
		ctx = this;
		
		// 高级功能:在线配置更新
		// String onOrOff = StatConfig.getCustomProperty("switch", "off");
		// Log.d(TAG, "switch" + onOrOff);
		// if(onOrOff.equalsIgnoreCase("on")){
		// // 打开某项功能
		// }else{
		// // 禁用某项功能
		// }
		// String appid = "互联的appid";
		// String appkey = "Aqc" + appid;
		// StatConfig.setAutoExceptionCaught(false); // 禁止捕获app未处理的异常
		// StatConfig.setEnableSmartReporting(true); // 禁止WIFI网络实时上报
		// StatConfig.setSendPeriodMinutes(24 * 60); // PERIOD间隔周期,24小时
		// StatConfig.setStatSendStrategy(StatReportStrategy.PERIOD); //
		// PERIOD上报策略
		// try {
		// StatService.startStatService(this, appkey,
		// com.tencent.stat.common.StatConstants.VERSION);
		// } catch (MtaSDkException e) {
		// Log.e("DEBUG", "MTA init Failed.");
		// }
		initActivity();
	}

	private void initActivity() {
		setTitle("常用统计分析");

		btn_customevent_args_count = (Button) findViewById(R.id.btn_customevent_args_count);
		btn_customevent_kv_count = (Button) findViewById(R.id.btn_customevent_kv_count);
		btn_customevent_args_duration_begin = (Button) findViewById(R.id.btn_customevent_args_duration_begin);
		btn_customevent_args_duration_end = (Button) findViewById(R.id.btn_customevent_args_duration_end);
		btn_customevent_kv_duration_begin = (Button) findViewById(R.id.btn_customevent_kv_duration_begin);
		btn_customevent_kv_duration_end = (Button) findViewById(R.id.btn_customevent_kv_duration_end);
		btn_report_error = (Button) findViewById(R.id.btn_report_error);
		btn_report_exception = (Button) findViewById(R.id.btn_report_exception);
		btn_catch_unhandled_exception = (Button) findViewById(R.id.btn_catch_unhandled_exception);
		btn_catch_native_crash = (Button) findViewById(R.id.btn_catch_native_crash);
		btn_init_nativeCrash = (Button) findViewById(R.id.btn_init_nativeCrash);
		btn_monitor_events = (Button) findViewById(R.id.btn_monitor_events);

		btn_customevent_args_count.setOnClickListener(l);
		btn_customevent_kv_count.setOnClickListener(l);
		btn_customevent_args_duration_begin.setOnClickListener(l);
		btn_customevent_args_duration_end.setOnClickListener(l);
		btn_customevent_kv_duration_begin.setOnClickListener(l);
		btn_customevent_kv_duration_end.setOnClickListener(l);
		btn_report_error.setOnClickListener(l);
		btn_report_exception.setOnClickListener(l);
		btn_catch_unhandled_exception.setOnClickListener(l);
		btn_init_nativeCrash.setOnClickListener(l);
		btn_catch_native_crash.setOnClickListener(l);
		btn_monitor_events.setOnClickListener(l);
	}

	@Override
	protected void onResume() {
		super.onResume();
		StatService.onResume(this);
	}

	@Override
	protected void onPause() {
		super.onPause();
		StatService.onPause(this);
	}
}





点此查看Android开发笔记的完整目录

你可能感兴趣的:(android开发,Android开发笔记)