【转载】cocs2dx中c++与c#互调

文章有参考http://www.cnblogs.com/zhxilin/archive/2013/03/20/2971331.html

下面以接入九幽数据统计插件为例

Step 1:如果是cocos2dx的话,每个版本不一样,比如3.6的话,已不支持wp8的,原因如下:

WP8: remove WP8 support because Angle don‘t support WP8 any more

以3.3的版本为例,直接打开proj.wp8-xaml目录下的工程文件;

如果不是cocos2dx,那就创建一个directx and xaml 工程。

Step 2:

新建 文件ICallback.h,例如内容可参考如下:

/***

Code begin

***/

#pragma once

namespace SilverlightDirect3DInterop1Comp

{

[Windows::Foundation::Metadata::WebHostHidden]

public interface class ICallback

{

public:

virtual void Exec(Platform::String ^Command, Platform::String ^Param);

int getOfferPoints();

void startLevel(int nLevel);

void failLevel(int nLevel);

void filishLevel(int nLevel);

};

}

/***

Code end

***/

Step 3:在Direct3DInterop.h文件中加入成员变量和成员函数

public:

void SetXmalCallback(ICallback^ callback){ m_globalCallback = callback; };

private:

ICallback^ m_globalCallback;

Step 4:

新建文件JiuYouCallback.cs,内容可参考如下:

using System;

using System.ComponentModel;

using System.Collections.Generic;

using System.Linq;

using System.Net;

using System.Windows;

using System.Windows.Threading;

using JYAnalyticsSdk;

namespace SilverlightDirect3DInterop1Comp

{

    public sealed class JiuYouCallback : ICallback

    {

        //public MainPage m_mainPage;

        static public int s_nOffserPoints;

        public void Exec(String Command, String Param)

        {

            //Execute some C# code, if you call UI stuff you will need to call this too

            //Deployment.Current.Dispatcher.BeginInvoke(() => { 

            // //Lambda code

            //}

        }

       public int getOfferPoints()

       {

            MessageBox.Show("jiuyou", "jiuyou", MessageBoxButton.OK);

           return 10;

       }

        public void startLevel(int nLevel) 

        {

            JYAnalytics.TrackEvent("startlevel", Convert.ToString(nLevel));

        }

        public void failLevel(int nLevel) 

        {

            JYAnalytics.TrackEvent("faillevel", Convert.ToString(nLevel));

        }

        public void filishLevel(int nLevel) 

        {

            JYAnalytics.TrackEvent("filishlevel", Convert.ToString(nLevel));

        }

    }

}

Step 5

在 MainPage.xaml.cs中的找到

private void DrawingSurface_Loaded(object sender, RoutedEventArgs e)

在里面加入

 JiuYouCallback sCallBack = new JiuYouCallback();

 m_d3dInterop.SetXmalCallback(sCallBack);//这句是c#调用c++的方法

Step 6

前面5步已经把c++ c#互调的框架搭好了。下面测下是否成功

在Direct3DInterop.cpp文件里添加如下

void Direct3DInterop::OnPointerReleased(DrawingSurfaceManipulationHost^ sender, PointerEventArgs^ args)

{

  int nPoints = m_globalCallback->getOfferPoints();

}

Step 7,运行程序,记得把弄成如下图这样测试

Step 8

接入九幽统计插件,参考文档《九幽数据统计插件(WP8)使用说明文档》

Ps:

注意命名空间要一致,否则可运行不起来哦

比如cocos2d的,c#跟c++这边都有cocos2d

原文链接:http://blog.csdn.net/kuovane/article/details/45723645

时间: 2024-08-01 05:04:31

【转载】cocs2dx中c++与c#互调的相关文章

[转载]Java中异常的捕获顺序(多个catch)

http://blog.sina.com.cn/s/blog_6b022bc60101cdbv.html [转载]Java中异常的捕获顺序(多个catch) (2012-11-05 09:47:28) 转载▼ 标签: 转载 分类: 转载 原文地址:Java中异常的捕获顺序(多个catch)作者:leesa Java代码 import java.io.IOException; public class ExceptionTryCatchTest { public void doSomething(

转载http中302与301的区别

http://blog.csdn.net/qmhball/article/details/7838989 一.官方说法301,302 都是HTTP状态的编码,都代表着某个URL发生了转移,不同之处在于: 301 redirect: 301 代表永久性转移(Permanently Moved).302 redirect: 302 代表暂时性转移(Temporarily Moved ). 这是很官方的说法,那么它们的区别到底是什么呢? 二.现实中的差异2.1.对于用户301,302对用户来说没有区别

[转载]eclipse中设置文件的编码格式为utf-8

免责声明:     本文转自网络文章,转载此文章仅为个人收藏,分享知识,如有侵权,请联系博主进行删除.     原文作者:ryxxlong     原文地址:http://ryxxlong.iteye.com/blog/788469 1.可以在 eclipse 中配置 workspace 项下 text file encoding 属性的值来决定此工作区间下所有的 eclipse 项目的文档的编码属性. Window-->Preferences-->General-->Workspace

(转载)JavaScript中面向对象那点事

鉴于自己在JavaScript这方面比较薄弱,所以就找了一本书恶补了一下(被称为犀利书的JavaScript权威指南).书的内容虽然多了点,但这也充分说明了js中的东西还是挺多的.虽然我们的定位不是前端,但最好还是了解一下js这个发展了将近20年但依然很火的技术. 两年前,写过一篇关于JavaScript闭包的博客,所以对闭包这个词印象很深,在看这书的时候,又看到了闭包,那么这次再看闭包,会有什么不同的理解呢? 大家都知道,在JavaScript中是没有类的概念的,更没有私有.公有的成员变量这样

[转载]VC6中的文件后缀

VC文件扩展名 .APS:存放二进制资源的中间文件,VC把当前资源文件转换成二进制格式,并存放在APS文件中,以加快资源装载速度. .BMP:位图资源文件. .BSC:浏览信息文件,由浏览信息维护工具(BSCMAKE)从原始浏览信息文件(.SBR)中生成,BSC文件可以用来在源代码编辑窗口中进行快速定位. .C:用C语言编写的源代码文件. .CLW:ClassWizard生成的用来存放类信息的文件. .CNT:用来定义帮助文件中“Contents”的结构. .CPP或.CXX:用C++语言编写的

[转载]Matlab中fft与fftshift命令的小结与分析

http://blog.sina.com.cn/s/blog_68f3a4510100qvp1.html 注:转载请注明出处——by author. 我们知道Fourier分析是信号处理里很重要的技术,matlab提供了强大的信号处理能力,但是有一些细节部分需要我们注意. 记信号f(t)的起始时间为t_start, 终止时间为t_end, 采样周期为t_s, 可以计算信号的持续时间Duration为 t_end – t_start, 信号离散化造成的采样点数 N = Duration/t_s +

[转载]DllMain中不当操作导致死锁问题的分析--线程退出时产生了死锁

(转载于breaksoftware的csdn博客) 我们回顾下之前举得例子 case DLL_PROCESS_ATTACH: { printf("DLL DllWithoutDisableThreadLibraryCalls_A:\tProcess attach (tid = %d)\n", tid); HANDLE hThread = CreateThread(NULL, 0, ThreadCreateInDllMain, NULL, 0, NULL); WaitForSingleO

[转载]DllMain中不当操作导致死锁问题的分析——线程中调用GetModuleFileName、GetModuleHandle等导致死锁

(转载于breaksoftware的csdn博客) 之前的几篇文章已经讲解了在DllMain中创建并等待线程导致的死锁的原因.是否还记得,我们分析了半天汇编才知道在线程中的死锁位置.如果对于缺乏调试经验的同学来说,可能发现这个位置有点麻烦.那么本文就介绍几个例子,它们会在线程明显的位置死锁掉. DLL中的代码依旧简单.它获取叫EVENT的命名事件,然后等待这个事件被激活.激活的操作自然放在线程中.这次我们不用在DLL中创建线程,而是在Exe中创建. switch (ul_reason_for_c

[转载]DllMain中不当操作导致死锁问题的分析--进程对DllMain函数的调用规律的研究和分析

(转载于breaksoftware的csdn博客) 不知道大家是否思考过一个过程:系统试图运行我们写的程序,它是怎么知道程序起始位置的?很多同学想到,我们在编写程序时有个函数,类似Main这样的名字.是的!这就是系统给我们提供的控制程序最开始的地方(注意这儿是提供给我们的,而实际有比这个还要靠前的main).于是看到DllMain就可以想到它是干嘛的了:Dll的入口点函数.那何时调用这个函数的呢?以及各种调用场景都传给了它什么参数呢? 进程对DLL的载入卸载,以及新线程的创建和退出都会导致对Dl