cocos2d-x移植安卓时解决引用sqlite3库问题

1.先说说cocos2d-x 3.x移植安卓简单步骤

(1)进入你工程的proj.android目录,打开jni目录里的Android.mk(别忘了先备份一个)

如果你工程文件少的话就android.mk里老老实实地把所有cpp文件都包含,  如:

LOCAL_SRC_FILES := hellocpp/main.cpp \

../../Classes/AppDelegate.cpp \

../../Classes/Audio.cpp \

../../Classes/Chinese.cpp \

../../Classes/ComboEffect.cpp \

这样做最保险,但是文件较多有成百个,你可以试试下面方法:

把原

LOCAL_SRC_FILES := AppDelegate.cpp \

HelloWorldScene.cpp

改为:

MY_CPP_LIST := $(wildcard $(LOCAL_PATH)/*.cpp)

MY_CPP_LIST += $(wildcard $(LOCAL_PATH)/hellocpp/*.cpp)

MY_CPP_LIST += $(wildcard $(LOCAL_PATH)/../../Classes/*.cpp)

LOCAL_SRC_FILES := $(MY_CPP_LIST:$(LOCAL_PATH)/%=%)

(2) 不需要执行build_native.py命令,白浪费时间. 我们用eclipse执行,在eclipse里直接导入proj.android工程,方法是File -> new -> other... ->Android Project from Existing Code,  libcocos库用那个E:\cocos2d-x-3.3\cocos\platform\android\java(事先建个工程导入)不要再拷什么java呀,ogg呀,不拷还好,一拷准出奇葩错误。

导入后插上手机,手机别让它进入休眠状态,工程右键 Debug As -> Andorod Project  就会直接执行build_native.py

编译时几乎100%出错,因为Eclipse检查错误比VS较严格,如非ANSI标准的itoa函数不准用,有些函数分支没有返回值不是警告而报错等等,请耐心改错

还有要命的是运行手机时闪退,报什么错我忘了,返正就是致命不提示原因的错误,但程序能运行一点,这个时候你只有从程序入口处一点点打log("xxx")函数,看logCat哪儿出错了。

2.sqlite3 库cocos2d-x 3.x移植安卓问题

(1)报错找不到sqlite一切库函数

在Android.mk里没有包含.c的编译,我们将sqlite3.h, sqlite3.c放到classes目录里,然后在Android.mk里这样写:

MY_CPP_LIST := $(wildcard $(LOCAL_PATH)/*.cpp)

MY_CPP_LIST += $(wildcard $(LOCAL_PATH)/hellocpp/*.cpp)

MY_CPP_LIST += $(wildcard $(LOCAL_PATH)/../../Classes/*.cpp)

MY_CPP_LIST += $(wildcard $(LOCAL_PATH)/../../Classes/*.c)   //这一句是新加的,编译所有的.c文件

这样做进程序不报错了,可是还是运行出错,只要用到数据库的地方都无效,因为访问你的xxx.db文件出错。

原因是android有文件权限检查,不在可读写路径上的数据库.db文件访问不了。你放在你的resource下就不行,得拷到可读写路径上,

我们写个函数:

我们在一个Tool类里,专门是工具函数的类,这样定义

//sqlite文件直接放在resources下在android环境是不能读取的,要拷到可读写路径下才能读写,此函数会将.db文件拷到writablePath下,再返回其路径

static std::string getDataBaseFilePath(std::string filePath);

然后实现文件这样写:

string Tools::getDataBaseFilePath(std::string filePath)
{
	sqlite3* dbFile = nullptr;

	string path = "";

	path = FileUtils::getInstance()->fullPathForFilename(filePath);

#if CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID
	path = FileUtils::getInstance()->getWritablePath(); //获取android环境下可读写路径,一般是SD卡
	path += filePath;

	FILE* file = fopen(path.c_str(), "r"); //尝试在可读写路径打开.db,但是此时应该没有这个文件,所以file返回空
	if (file == nullptr)
	{
		ssize_t size;
		const char* data = (char*)(FileUtils::getInstance()->getFileData(filePath, "rb", &size)); //取得resource下的数据库文件内容
		file = fopen(path.c_str(), "wb");  //打开那个android可读写路径下文件,这里是新建一个文件,采用写入方式
		fwrite(data, size, 1, file);  //将resource下的数据库文件拷入android可读写路径下
		CC_SAFE_DELETE_ARRAY(data);
	}
	fclose(file);

#endif
	log("database file: %s", path.c_str());

	return path;
}

代码就是将resource下的.db文件(必须是直接在resource根目录)拷到可读写路径中,然后我们就可以用了,

在要用到数据库文件的地方,这样写:

//打开一个数据库,如果该数据库不存在,则创建一个数据库文件
	string path = Tools::getDataBaseFilePath("game.db");
	result = sqlite3_open(path.c_str(), &pDB);

这样的path才是有效的数据库文件路径,我们就万事大吉了

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-08-28 08:28:48

cocos2d-x移植安卓时解决引用sqlite3库问题的相关文章

cocos2dx 3.0 学习笔记 引用cocostudio库 的环境配置

cocostudio创建UI并应用时须要引用cocostudio库,须要额外的环境配置: 之前已经搭配好了基础的开发环境,包含 1) JDK 2) Python 2.7 3) ant 4) visual Studio 2012 5) eclipse + ADT 这些都比較简单,然后也创建了project而且成功编译出了下面界面: 但之后尝试使用利用cocostudio做UI是发现还有非常多问题,环境仍然没有全然配置好. 研究好久最终攻克了: 右键项目 -> 属性 连接器->输入->附加依

Eclipse环境下JBoss调试,解决引用的工程不被部署的问题

其实算是一个很小的经验,在eclipse环境下进行jboss的部署,因为要定义某公共包的问题,将代码down下来做了个工程,部署时发现jboss提示:class not found! 从jboss部署目录中没有发现该类,在lib中也没有发现对应的jar包,考虑是编译时正确但运行时错误,原因就是没有部署. 后台经过同事指点,得知需要修改project的Deployment Assembly,需要将引用的工程通过jar的形式引入到jboss中.如图示: 重新部署,debug启动即可. Eclipse

UITableViewController 滚动引起的cocos2d动画暂停问题的解决

UITableViewController 滚动引起的cocos2d动画暂停问题的解决 之前在使用UITableViewController进行滚动时,cocos2d的动画会暂停,直至滚动完毕才会继续动画. 后来发现可以这样解决,想要了解更多,请查阅NSRunLoop相关知识. // .h NSTimer* m_timer; // .m- (void)updateCCDirector { [[CCDirector sharedDirector] drawScene]; if (!self.tab

Cocos2d-x3.2版本移植安卓提示'Serializing CDT Project settings..'has encountered a project

1.本人在使用Cocos2d-x3.2版本进行安卓移植的时候遇到了一个问题,如图在第一次移植成功了当我第二次打开我的eclipse 的时候就出现了这个问题,当我点击关闭时候再次Build Project 的时候有出现如下图的错误,搜索了一下解决的办法还是从我的同事那里知道的一个很偏门的解决办法   ,解决这个问题的步骤如下,找到你当前项目的proj.android文件夹,如图,然后找到.cproject这个文件,使用文本工具打开它,如图会显示如下,找到如图所示的配置信息,把所有的都给删除然后保存

php 中遍历数组时使用引用出现的问题

今天在使用foreach遍历数组时发现,当使用&时会出现问题: $arr = array( array('id' => 100, 'error'=> 'aa'), array('id' => 101, 'error'=> 'bb'), ); foreach($arr as &$value) { if($value['id'] == 101) $value['error'] = 'test'; } var_dump($arr); foreach($arr as $va

cocos2d-x 3.0 引用第三方库 及编译成apk时android mk文件写法

cocos2d-x 3.0 中,如果你需要使用CocosStudio.Extensions扩展库 等等,都需要自己手动添加. 添加步骤如下:(比如说现在我要添加libExtensions,libCocosStudio , libGUI) 1.添加附加项目 右击解决方案--->添加现有项目--->添加:项目目录\cocos2d\extensions\proj.win32\libExtensions,然后你会发现左边多了一个libExtensions扩展库 右击解决方案--->添加现有项目-

搭建php环境时解决jpeg6 make: ./libtool:命令未找到

搭建php环境时解决jpeg6 make: ./libtool:命令未找到 [[email protected] jpeg-6b]# make; make install ./libtool --mode=compile gcc -O2  -I. -c ./jcapimin.c make: ./libtool:命令未找到 make: *** [jcapimin.lo] 错误 127 ./libtool --mode=compile gcc -O2  -I. -c ./cjpeg.c make:

安卓开发解决android.os.NetworkOnMainThreadException异常方法(主线程不能直接调用webservice)

安卓开发解决android.os.NetworkOnMainThreadException异常方法 2013-01-07 14:01:04|  分类: 技术 |  标签:安卓  技术  java  |举报|字号 订阅 在android 2.3上访问网络的方法,在android 4.0上运行时报android.os.NetworkOnMainThreadException异常,主要问题在于4.0中访问网络不能在主线程中进行,有两个方法可以解决.第一种是在主线程中增加如下代码[不推荐]: // 详见

双系统(win7+ubuntu)ubuntu磁盘空间不足时解决方法

原文网址: http://www.lupaworld.com/thread-868507-1-1.html 问题描述: 双系统(win7+ubuntu)ubuntu系统提醒磁盘空间不足,又不想重装系统. 解决思路:第一步,在win7下划出一块可用空间:第二步,利用gparted软件将此可用空间划给ubuntu系统:第三步,最后利用grub修复技术修复损坏的grub. 具体步骤: 第一步:在win7下划出一块可用空间 登录win7系统--> (右击)计算机-->  属性  --> 存储 -