ImagePicker utility for cocos2d-x (Android and iOS[iPad] only).
This utility lets you load images from device gallery and load it to your application as a CCSprite. At the moment it supports only Android and iOS platforms, if I find more time I will add support for other.
For Android :
-
[ANDROID] Copy GalleryJNI.cpp and GalleryJNI.h to COCOS2DX_ROOT/cocos2dx/platform/android/jni
-
[ANDROID] Add
platform/android/jni/GalleryJNI.cpp \
to Android.mk in COCOS2DX_ROOT/cocos2dx -
[ANDROID] Copy & paste the contents of ImagePickerAndroid.java to Cocos2dxActivity.java, then rebuild cocos2dx library
-
[iOS] Add ObjCCalls folder to your iOS project
-
[GENERAL] Add ImagePicker.cpp and ImagePicker.h to your project
Usage is really simple - you basically call a static method
ImagePicker::pickImage(CCNode *target, CCPoint position, ImagePickerDelegate *delegate);
and after the user picks the image it will be added as a child to 'target' node at specified position. If you want to get a pointer to added CCSprite you can call
ImagePicker::getLastSprite();
but remember that it is not safe to make any assumptions about if the user actually did pick the image or not.
Because of that, if you want to get the pointer to created CCSprite, you should subclass ImagePickerDelegate and implement the
virutal void didFinishPickingWithResult(bool result);
It will be called when the user picked the image or cancelled.