Skip to content

Umeng移动端统计Cordova插件,集成了官方最新版本的SDK,解决了github上很多封装的插件Android都没有页面访问路径数据的问题

License

Notifications You must be signed in to change notification settings

osvlabs/cordova-plugin-umeng-analytics

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

cordova-plugin-umeng-analytics

此插件集成了Umeng官方最新版本的SDK v8.0.0,github上很多旨在封装此功能的plugin都不能正常工作,尤其是Android(请注意看此插件Android部分PGCommonSDK中对官方init方法的修改,加上了下面这一句: Cordova生成的App只有唯一的一个Activity,需要手动统计。)

MobclickAgent.setPageCollectionMode(MobclickAgent.PageMode.LEGACY_MANUAL);

#Requirements

  • iOS 7 or higher

#Installation

命令行安装:

cordova plugin add https://github.com/shineabel/cordova-plugin-umeng-analytics

或者cordova项目的config.xml

    <plugin name="cordova-plugin-umeng-analytics" spec="git+https://github.com/shineabel/cordova-plugin-umeng-analytics.git" />

#Attention iOS: 按照下面这样修改cordova-ios 自动生成的AppDelegate.m 文件:


 #import "UMCommonModule.h" 
 #import <UMCommon/UMCommon.h> 
 #import <UMAnalytics/MobClick.h>

@implementation AppDelegate

- (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary*)launchOptions
{
    self.viewController = [[MainViewController alloc] init]; 
 [UMConfigure setLogEnabled:YES];
 [UMCommonModule initWithAppkey:@"具体key"channel:@"具体渠道"]; 
 [MobClick setScenarioType:E_UM_NORMAL];
    return [super application:application didFinishLaunchingWithOptions:launchOptions];
}  
@end

Android: 按照下面这样修改Cordova-android自动生成的MainActivity.java文件

 import com.umeng.analytics.MobclickAgent; 
 import com.umeng.commonsdk.UMConfigure; 
 import com.umeng.plugin.PGCommonSDK;

    @Override
        public void onResume() {
            super.onResume();
    
            MobclickAgent.onPageStart("Home");//Umeng建议写上,此字符串随便定义,与桥接js调用传过来的pageName无关
            MobclickAgent.onResume(this);
        }
    
        @Override
        protected void onPause() {
            super.onPause();
            MobclickAgent.onPageEnd("Home");//Umeng建议写上,此字符串随便定义,与桥接js调用传过来的pageName无关
            MobclickAgent.onPause(this);
        }

    @Override
    public void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);

        // enable Cordova apps to be started in the background
        Bundle extras = getIntent().getExtras();
        if (extras != null && extras.getBoolean("cdvStartInBackground", false)) {
            moveTaskToBack(true);
        }

        // Set by <content src="index.html" /> in config.xml
        loadUrl(launchUrl);
        UMConfigure.setLogEnabled(true); 
        PGCommonSDK.init(this,"your key","your channel",UMConfigure.DEVICE_TYPE_PHONE,"");//初始化SDK
    }

持续集成建议:
在Cordova-Android (Cordova-iOS)自动生成MainActivity (AppDelegate.m)文件后,用事先准备好的文件覆盖掉(cp)自动生成的即可

#使用

页面访问路径:注意一定要成对的线性调用,不能交叉,必须要onPageBegin A -> onPageEnd A 后才能开始下一个页面onPageBegin B -> onPageEnd B

let pageName = "PageA";
let successCallbak = function(){}
let errorCallback = function(){}
//进入页面时
if(AnalyticsAgent){
        AnalyticsAgent.onPageBegin(pageName,successCallbak,errorCallback);
}
//离开页面时
if(AnalyticsAgent){
        AnalyticsAgent.onPageEnd(pageName,successCallbak,errorCallback);
    
}

自定义事件埋点:(注意要事先在Umeng官网上注册好事件,然后才能看到数据)
 if (AnalyticsAgent){
    AnalyticsAgent.onEventWithParameters(
        umEvent,
        {key1:value1, key2:value2}, 
    function () {
        console.log("custom event success");
    }, function (reason) {
        console.error("custom event failed: " + reason);
    });
}

About

Umeng移动端统计Cordova插件,集成了官方最新版本的SDK,解决了github上很多封装的插件Android都没有页面访问路径数据的问题

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Objective-C 72.8%
  • Java 16.9%
  • JavaScript 10.3%