使用IntelRealScene设备结合Cocos引擎实现体感游戏开发

本文主要是介绍使用IntelRealScene设备结合Cocos引擎实现体感游戏开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

标题:使用IntelRealScene设备结合Cocos引擎实现体感游戏开发

内容:

Cocos游戏开发引擎对于广大开发者来说都比较熟悉,Intel RealScene是什么呢,简单理解是一种特殊的摄像头,可以捕捉用户的手势,面部表情等,进而实现AR,VR的特殊应用,本案例通过摄像头结合Cocos引擎实现一款跑酷游戏,游戏截图如下:

07游戏主界面.png 

1-cocos+IntelRealScene实现的跑酷游戏

1.游戏玩法:

   1.在摄像头前坐好

   2.当游戏主角前方有障碍物或陷阱时候迅速移动头部向左,游戏主角会跳起

   3.恢复坐好状态

   (目前我的最好成绩是24秒!!!)

2.项目运行工程网盘地址:

   链接: http://pan.baidu.com/s/1ntB0kwL 密码: nzrd

3.项目源码网盘地址:

  链接: http://pan.baidu.com/s/1qWj9Iws 密码: buj6   

4.开发和运行环境要求:

         4.1 Win7以上64位操作系统

         4.2 使用了Intel F200摄像头设备

         4.3 正确安装F200驱动程序(下载在)

         4.4 安装vs2013

5.开发核心步骤

   5.1 登录www.cocos.com下载最新版的cocos引擎源码,然后安装,并创建一个新的Cocos工程(此处略过10000字,详细方法可以登录cvp.cocos.com),并使用vs打开。

   1创建cocos项目.png

   5.2. 重要,若要cocos支持RealScene设备需要加载库,可以通过属性表一次性完成该操作,在VS中找到【视图】【其他窗口】【属性管理器】,如下图:

02配置属性.png 

然后找到添加属性按钮,如下图:

03添加现有属性.png 

选择C:\Program Files (x86)\Intel\RSSDK\props

选择任意VS2010-13.Integration.MD.props 或者 VS2010-13.Integration.MT.props

如下图:

04选择属性配置文件.png 

在项目名上面右键,查看项目属性,检查是否加载成功,如下图:

05检查属性是否配置成功.png 

我们看到包含目录和库目录中已经有了关于RSSDK的内容,说明属性文件生效,但是这时候编译工程会出现找不到lib库的错误,解决方法如下:

在库目录增加一行只想RSSDK\sample\common\lib\x64\v140

06解决编译错误.png 

然后编译项目,ok

6.核心编码

     6.1 在AppDelegate中启动摄像头并在独立线程中更新数据。

#include "CCStdC.h"

#include <SDKDDKVer.h>

#include <pxcsession.h>

#include <stdio.h>

#include <stdlib.h>

#include <pxcsensemanager.h>

#include <util_render.h>

#include <pxcfaceconfiguration.h>

引入以上库文件,在构造函数启动线程

AppDelegate::AppDelegate() {

std::thread t([&](){

printf("init realsence\n");

 

PXCSession* session = PXCSession_Create();

if (session)

{

PXCSession::ImplVersion version = session->QueryVersion();

CCLOG("SDK Version is %d.%d\n", version.major, version.minor);

session->Release();

}

 ///初始化rs模块

PXCSenseManager* senseManager = PXCSenseManager::CreateInstance();

 

if (senseManager)

{

CCLOG("intel PXCSenseManager ok");

 

senseManager->EnableFace();//开启脸部识别模块 

CCLOG("intel realsence EnableFace");

if (senseManager->Init() == PXC_STATUS_NO_ERROR)

{

CCLOG("intel senseManager->Init() ok");

 

// 获取faceModule

PXCFaceModule* faceModule = senseManager->QueryFace();

PXCFaceData* faceData = faceModule->CreateOutput();

PXCFaceConfiguration* faceConfiguration = 

faceModule->CreateActiveConfiguration();

设置3d跟踪模式

faceConfiguration->SetTrackingMode(

PXCFaceConfiguration::TrackingModeType::FACE_MODE_COLOR_PLUS_DEPTH);

faceConfiguration->detection.isEnabled = true;

faceConfiguration->ApplyChanges();

 

bool quit = false;

while (!quit)

{

// //获取跟踪的坐标

faceData->Update();

int faceNum = faceData->QueryNumberOfDetectedFaces();

if (faceNum > 0)

{

PXCFaceData::Face *trackedFace = 

faceData->QueryFaceByIndex(0);

PXCFaceData::DetectionData* detectionData = 

trackedFace->QueryDetection();

PXCRectI32 rectangle;

detectionData->QueryBoundingRect(&rectangle);

Game::x = rectangle.x;

Game::y = rectangle.y;

Game::w = rectangle.w;

Game::h = rectangle.h;

}

   senseManager->ReleaseFrame();

}

faceData->Release();

faceConfiguration->Release();

senseManager->Close();

}

else{

CCLOG("intel realsence error2");

}

senseManager->Release();

}

else{

CCLOG("intel realsence error1");

}

});

t.detach();

}

以上代码,会时时更新数据,捕获人脸的x,y,w,h在屏幕的坐标,缺省是640X360的范围,可以通过Log查看数据的变化。

     6.2 在GameScene中启动计划任务scheduleUpdate,并在每一帧处理。

void Game::update(float t)

{

//每帧保存一个点

if (allPoint.size() < 60)

{

MyPoint * newp = new MyPoint(x, y, w, h);

newp->autorelease();

allPoint.pushBack(newp);

}

else

{

MyPoint * newp = new MyPoint(x, y, w, h);

newp->autorelease();

 

allPoint.eraseObject(allPoint.front());

allPoint.pushBack(newp);

  int farx = (allPoint.back()->x - allPoint.front()->x);

std::string str = 

StringUtils::format("%d %d %d %d  %d", x, y, w, h, farx);

CCLOG("%s", str.c_str());

if (farx >30 && farx<200)

{

if (this->_dir == Stop)

{

this->_dir = Up;

 allPoint.clear();

}

 

}

}

  。。。。。。

}

这里用60个点来记录每一帧人脸坐标的变化,通过计算是否有超过40的移动来确定玩家是否跳起(这里很偷懒,可以使用的人脸的点可以达到78个点)

文章结束了,是不是还没看明白,下次再说。

这篇关于使用IntelRealScene设备结合Cocos引擎实现体感游戏开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/367818

相关文章

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

在Java中使用OpenCV实践

《在Java中使用OpenCV实践》用户分享了在Java项目中集成OpenCV4.10.0的实践经验,涵盖库简介、Windows安装、依赖配置及灰度图测试,强调其在图像处理领域的多功能性,并计划后续探... 目录前言一 、OpenCV1.简介2.下载与安装3.目录说明二、在Java项目中使用三 、测试1.测

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin

go动态限制并发数量的实现示例

《go动态限制并发数量的实现示例》本文主要介绍了Go并发控制方法,通过带缓冲通道和第三方库实现并发数量限制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录带有缓冲大小的通道使用第三方库其他控制并发的方法因为go从语言层面支持并发,所以面试百分百会问到

Go语言并发之通知退出机制的实现

《Go语言并发之通知退出机制的实现》本文主要介绍了Go语言并发之通知退出机制的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、通知退出机制1.1 进程/main函数退出1.2 通过channel退出1.3 通过cont

游戏闪退弹窗提示找不到storm.dll文件怎么办? Stormdll文件损坏修复技巧

《游戏闪退弹窗提示找不到storm.dll文件怎么办?Stormdll文件损坏修复技巧》DLL文件丢失或损坏会导致软件无法正常运行,例如我们在电脑上运行软件或游戏时会得到以下提示:storm.dll... 很多玩家在打开游戏时,突然弹出“找不到storm.dll文件”的提示框,随后游戏直接闪退,这通常是由于

Python实现PDF按页分割的技术指南

《Python实现PDF按页分割的技术指南》PDF文件处理是日常工作中的常见需求,特别是当我们需要将大型PDF文档拆分为多个部分时,下面我们就来看看如何使用Python创建一个灵活的PDF分割工具吧... 目录需求分析技术方案工具选择安装依赖完整代码实现使用说明基本用法示例命令输出示例技术亮点实际应用场景扩

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

C++中detach的作用、使用场景及注意事项

《C++中detach的作用、使用场景及注意事项》关于C++中的detach,它主要涉及多线程编程中的线程管理,理解detach的作用、使用场景以及注意事项,对于写出高效、安全的多线程程序至关重要,下... 目录一、什么是join()?它的作用是什么?类比一下:二、join()的作用总结三、join()怎么