Cocos2d-js和Android交互

Posted Joe师傅

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Cocos2d-js和Android交互相关的知识,希望对你有一定的参考价值。

说白了,就是javascript和Java之间的函数互相调用。

 

先看一下效果

 

有了这个交互,为了以后接sdk做准备。

 

要点:

javascript调用java:

jsb.reflection.callStaticMethod("org/cocos2dx/javascript/AppActivity", "hello", "(Ljava/lang/String;)V", "this is a message from js");

 

java调用javaScript:

  Cocos2dxJavascriptJavaBridge.evalString("Global.mlayer.exit_cancle();"); // java to js  

 

在这里我把这cocos2d-js的app.js  和 android工程的AppActivity.java 的代码贴上,代码也有注释,纯干货,拿走就能用!

app.js:

var HelloWorldLayer = cc.Layer.extend({
    
	txt_info:null, 
	
	
	sprite:null,
	ctor:function () 
	{
        //////////////////////////////
        // 1. super init first
        this._super();

        /////////////////////////////
        // 2. add a menu item with "X" image, which is clicked to quit the program
        //    you may modify it.
        // ask the window size
        var size = cc.winSize;

        var mainscene = ccs.load(res.MainScene_json);
        this.addChild(mainscene.node);

        /* you can create scene with following comment code instead of using csb file.
        /////////////////////////////
        // 3. add your codes below...
        // add a label shows "Hello World"
        // create and initialize a label
        var helloLabel = new cc.LabelTTF("Hello World", "Arial", 38);
        // position the label on the center of the screen
        helloLabel.x = size.width / 2;
        helloLabel.y = size.height / 2 + 200;
        // add the label as a child to this layer
        this.addChild(helloLabel, 5);

        // add "HelloWorld" splash screen"
        this.sprite = new cc.Sprite(res.HelloWorld_png);
        this.sprite.attr({
            x: size.width / 2,
            y: size.height / 2
        });
        this.addChild(this.sprite, 0);
        */
		
		
		//“测试传参”按钮
		var btn_hello = ccui.helper.seekWidgetByName(mainscene.node, "Button_1");
		btn_hello.addTouchEventListener(this.btn_hello_clicked,this);
		
		//"测试返回值" 按钮
		var btn_testReturn = ccui.helper.seekWidgetByName(mainscene.node, "Button_2");
		btn_testReturn.addTouchEventListener(this.btn_testReturn_clicked,this);
		
		//“测试对话框” 按钮
		var btn_dialog = ccui.helper.seekWidgetByName(mainscene.node, "Button_3");
		btn_dialog.addTouchEventListener(this.btn_dialog_clicked,this);
		
		//文本提示
		this.txt_info = ccui.helper.seekWidgetByName(mainscene.node, "Text_1");
		this.txt_info.setString("default");
		
        return true;
    },
	
	//打开java层的对话框
	btn_dialog_clicked:function(sender,type)
	{
		if(type == ccui.Widget.TOUCH_ENDED)
		{			
			//弹出提示框 ok
			jsb.reflection.callStaticMethod("org/cocos2dx/javascript/AppActivity", "showAlertDialog", "(Ljava/lang/String;Ljava/lang/String;)V", "提示","您确认要退出游戏?");
			
		}
	},
	
	//测试 java函数的返回值
	btn_testReturn_clicked:function(sender,type)
	{
		if(type == ccui.Widget.TOUCH_ENDED)
		{
			//测试返回值 ok
			var result = jsb.reflection.callStaticMethod("org/cocos2dx/javascript/AppActivity", "sum", "(II)I", 3, 7);
			cc.log("result"+result);		
			this.txt_info.setString("sum="+result);						
		}
	},
	
	
	btn_hello_clicked:function(sender,type){
        //根据触发事件的类型进行分情况处理
        switch (type) 
		{
        case ccui.Widget.TOUCH_BEGAN:
            //cc.log("btn_hello Touch Began");
            
            break;
        case ccui.Widget.TOUCH_MOVED:
            //cc.log("btn_hello Touch Moved");
            break;
        case ccui.Widget.TOUCH_ENDED:
            //cc.log("btn_hello Touch Ended");
			cc.log("TODO call java");
			jsb.reflection.callStaticMethod("org/cocos2dx/javascript/AppActivity", "hello", "(Ljava/lang/String;)V", "this is a message from js");			
            break;
        case ccui.Widget.TOUCH_CANCELED:
            //cc.log("btn_hello Touch Canceled");
            break;
        default:
            break;
        }
	},
	
	exit_sure:function()
	{
		this.txt_info.setString("确定");
	},
	
	exit_cancle:function()
	{
		this.txt_info.setString("取消");
	},
	
});



	
var HelloWorldScene = cc.Scene.extend({
    onEnter:function () {
        this._super();
        var layer = new HelloWorldLayer();
		Global.mlayer = layer;//保存到全局变量
        this.addChild(layer);
    }
});

 

AppActivity.java:

/****************************************************************************
Copyright (c) 2008-2010 Ricardo Quesada
Copyright (c) 2010-2012 cocos2d-x.org
Copyright (c) 2011      Zynga Inc.
Copyright (c) 2013-2014 Chukong Technologies Inc.
 
http://www.cocos2d-x.org

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
****************************************************************************/
package org.cocos2dx.javascript;

import org.cocos2dx.lib.Cocos2dxActivity;
import org.cocos2dx.lib.Cocos2dxGLSurfaceView;

import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.content.pm.ActivityInfo;
import android.net.wifi.WifiInfo;
import android.net.wifi.WifiManager;
import android.os.Bundle;
import android.view.WindowManager;
import android.widget.Toast;


import org.cocos2dx.lib.Cocos2dxJavascriptJavaBridge;


// The name of .so is specified in AndroidMenifest.xml. NativityActivity will load it automatically for you.
// You can use "System.loadLibrary()" to load other .so files.

public class AppActivity extends Cocos2dxActivity{
    
    /*
     * by joe
     */
    private static AppActivity app = null;
    //private static Context mContent = null;
    
    static String hostIPAdress = "0.0.0.0";
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onCreate(savedInstanceState);
        
        if(nativeIsLandScape()) {
            setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_SENSOR_LANDSCAPE);
        } else {
            setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_SENSOR_PORTRAIT);
        }
        if(nativeIsDebug()){
            getWindow().setFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON, WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
        }
        hostIPAdress = getHostIpAddress();
        
        /**
         * by joe
         */
        app  =  this;
        //mContent = this;
    }
    
    @Override
    public Cocos2dxGLSurfaceView onCreateView() {
        Cocos2dxGLSurfaceView glSurfaceView = new Cocos2dxGLSurfaceView(this);
        // TestCpp should create stencil buffer
        glSurfaceView.setEGLConfigChooser(5, 6, 5, 0, 16, 8);

        return glSurfaceView;
    }

    public String getHostIpAddress() {
        WifiManager wifiMgr = (WifiManager) getSystemService(WIFI_SERVICE);
        WifiInfo wifiInfo = wifiMgr.getConnectionInfo();
        int ip = wifiInfo.getIpAddress();
        return ((ip & 0xFF) + "." + ((ip >>>= 8) & 0xFF) + "." + ((ip >>>= 8) & 0xFF) + "." + ((ip >>>= 8) & 0xFF));
    }
    
    public static String getLocalIpAddress() {
        return hostIPAdress;
    }
    
    private static native boolean nativeIsLandScape();
    private static native boolean nativeIsDebug();
    
    
    //---------------以下是cocos2dx-js 与  java 交互--------------------------
    
    /*
     * 目前Cocos2d-js中支持的Java类型签名有下面4种
    Java类型     签名
    int         I
    float       F
    boolean     Z
    String      Ljava/lang/String;
    */
    
    
    
    /**
     * 
     * jsb.reflection.callStaticMethod("org/cocos2dx/javascript/AppActivity", "hello", "(Ljava/lang/String;)V", "this is a message from js");
     * js->java
     * 测试无返回值的
     * @param msg
     */
    public static void hello(final String msg){  
        System.out.println(msg);  
        
        app.runOnUiThread(new Runnable() {
            
            @Override
            public void run() {
            
                Toast.makeText(app, msg, Toast.LENGTH_SHORT).show();
            }
        });

    }  
    
    /**
     * 
     * var result = jsb.reflection.callStaticMethod("org/cocos2dx/javascript/AppActivity", "sum", "(II)I", 3, 7);
     * js->java
     * 测试有返回值的
     * @param a
     * @param b
     * @return
     */
    public static int sum(int a, int b){
        return a + b;
    }
    
    
    /**
     * 弹出一个对话框
     * @param title
     * @param message
     */
    public static  void showAlertDialog(final String title,final String message) {

        //这里一定要使用runOnUiThread
        app.runOnUiThread(new Runnable() {
            @Override
            public void run() {
                // 创建构建器
                AlertDialog.Builder builder = new AlertDialog.Builder(app);
                builder.setTitle(title)//提示
                .setMessage(message)//您确认要退出游戏?
                .setIcon(null)//.setIcon(R.drawable.icon)
                .setPositiveButton("确定", new DialogInterface.OnClickListener(){

                    @Override
                    public void onClick(DialogInterface dialog, int which) {

                        //System.out.println("是 clicked");
                        Toast.makeText(app, "确定", Toast.LENGTH_SHORT).show();
                        
                        //跳出一个提示。
                        //Toast.makeText(mContent, "确定", Toast.LENGTH_SHORT).show();
                        
                        //call cocos 函数 exit_sure
                        app.runOnGLThread(new Runnable() {  
                            @Override  
                            public void run() {  
                                Cocos2dxJavascriptJavaBridge.evalString("Global.mlayer.exit_sure();"); // java to js  
                            }  
                        });
                        
                    }})
                .setNegativeButton("取消", new DialogInterface.OnClickListener(){

                    @Override
                    public void onClick(DialogInterface dialog, int which) {

                        //System.out.println("否 clicked");
                        Toast.makeText(app, "取消", Toast.LENGTH_SHORT).show();
                        
                        //call cocos 函数 exit_cancle
                        app.runOnGLThread(new Runnable() {  
                            @Override  
                            public void run() {  
                                Cocos2dxJavascriptJavaBridge.evalString("Global.mlayer.exit_cancle();"); // java to js  
                            }  
                        });
                        
                    }});
                builder.create().show();  
            }
        });
    }
         
    /**
     * java->js
     * @param a
     * @param b
     */
    public static void callcocos(int a){  

         app.runOnGLThread(new Runnable() {  
            @Override  
            public void run() {  
                //test
               // Cocos2dxJavascriptJavaBridge.evalString("SDKManage.javaToJSCall(\\"a\\", 5 , 7);"); // java to js  
            }  
        });
             
    }  
    
}

 

以上是关于Cocos2d-js和Android交互的主要内容,如果未能解决你的问题,请参考以下文章

[cocos2d-js] - 01

cocos2d-js反射

搭建Cocos2d-JS开发环境

Android中每个片段的不同操作栏 - 最佳方法?

完美搭建Cocos2d-JS开发环境(全)

HTML5 和 Cocos2d-js 的cc.sys.localStorage本地存储到哪里了?