Allowing resolution being sent to CocosBuilder to be set by AppDelegate

This commit is contained in:
Rohan Kuruvilla 2013-01-25 00:29:55 -08:00
parent 6fdbff537a
commit f050fc9f08
7 changed files with 42 additions and 9 deletions

View File

@ -65,26 +65,30 @@ bool AppDelegate::applicationDidFinishLaunching()
CCSize designSize = CCSizeMake(320, 480); CCSize designSize = CCSizeMake(320, 480);
CCSize resourceSize = CCSizeMake(320, 480); CCSize resourceSize = CCSizeMake(320, 480);
string res = "xlarge";
if (screenSize.height > 1024) if (screenSize.height > 1024)
{ {
resourceSize = CCSizeMake(1280, 1920); resourceSize = CCSizeMake(1280, 1920);
CCFileUtils::sharedFileUtils()->setSearchResolutionsOrder(CCArray::create(CCString::create("resources-xlarge"), CCString::create(""), NULL)); CCFileUtils::sharedFileUtils()->setSearchResolutionsOrder(CCArray::create(CCString::create("resources-xlarge"), CCString::create(""), NULL));
res = "xlarge";
} }
else if (screenSize.height > 960) else if (screenSize.height > 960)
{ {
resourceSize = CCSizeMake(640, 960); resourceSize = CCSizeMake(640, 960);
CCFileUtils::sharedFileUtils()->setSearchResolutionsOrder(CCArray::create(CCString::create("resources-large"), CCString::create(""), NULL)); CCFileUtils::sharedFileUtils()->setSearchResolutionsOrder(CCArray::create(CCString::create("resources-large"), CCString::create(""), NULL));
res = "large";
} }
else if (screenSize.height > 480) else if (screenSize.height > 480)
{ {
resourceSize = CCSizeMake(480, 720); resourceSize = CCSizeMake(480, 720);
CCFileUtils::sharedFileUtils()->setSearchResolutionsOrder(CCArray::create(CCString::create("resources-medium"), CCString::create(""), NULL)); CCFileUtils::sharedFileUtils()->setSearchResolutionsOrder(CCArray::create(CCString::create("resources-medium"), CCString::create(""), NULL));
res = "medium";
} }
else else
{ {
resourceSize = CCSizeMake(320, 568); resourceSize = CCSizeMake(320, 568);
CCFileUtils::sharedFileUtils()->setSearchResolutionsOrder(CCArray::create(CCString::create("resources-small"), CCString::create(""), NULL)); CCFileUtils::sharedFileUtils()->setSearchResolutionsOrder(CCArray::create(CCString::create("resources-small"), CCString::create(""), NULL));
res = "small";
} }
pDirector->setContentScaleFactor(resourceSize.height/designSize.height); pDirector->setContentScaleFactor(resourceSize.height/designSize.height);
@ -93,6 +97,8 @@ bool AppDelegate::applicationDidFinishLaunching()
CCFileUtils::sharedFileUtils()->setSearchPath(CCArray::create(CCString::create(CCFileUtils::sharedFileUtils()->getWriteablePath()), CCFileUtils::sharedFileUtils()->setSearchPath(CCArray::create(CCString::create(CCFileUtils::sharedFileUtils()->getWriteablePath()),
CCString::create("assets/"), CCString::create(""), NULL)); CCString::create("assets/"), CCString::create(""), NULL));
PlayerStatus::setDeviceResolution(res);
// turn on display FPS // turn on display FPS
pDirector->setDisplayStats(true); pDirector->setDisplayStats(true);

View File

@ -10,6 +10,7 @@
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG,__VA_ARGS__) #define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG,__VA_ARGS__)
#define SOCKET_CLASS_NAME "org/cocos2dx/cocosplayer/CocosPlayerSocket" #define SOCKET_CLASS_NAME "org/cocos2dx/cocosplayer/CocosPlayerSocket"
#define STREAM_CLASS_NAME "org/cocos2dx/cocosplayer/CCBStreamHandler"
using namespace cocos2d; using namespace cocos2d;
using namespace std; using namespace std;
@ -29,5 +30,15 @@ extern "C" {
t.env->CallStaticVoidMethod(t.classID, t.methodID); t.env->CallStaticVoidMethod(t.classID, t.methodID);
t.env->DeleteLocalRef(t.classID); t.env->DeleteLocalRef(t.classID);
} }
} }
void setDeviceResolutionJNI(const char *res) {
JniMethodInfo t;
if (JniHelper::getStaticMethodInfo(t, STREAM_CLASS_NAME, "setDeviceResolution", "(Ljava/lang/String;)V")) {
jstring stringArg1 = t.env->NewStringUTF(res);
t.env->CallStaticVoidMethod(t.classID, t.methodID, stringArg1);
t.env->DeleteLocalRef(stringArg1);
t.env->DeleteLocalRef(t.classID);
}
}
} }

View File

@ -29,6 +29,7 @@ THE SOFTWARE.
extern "C" { extern "C" {
extern void setPairingCodeJNI(int code); extern void setPairingCodeJNI(int code);
extern void cleanCacheDirJNI(); extern void cleanCacheDirJNI();
extern void setDeviceResolutionJNI(const char* res);
} }
#endif #endif

View File

@ -46,6 +46,10 @@ SEL_MenuHandler PlayerStatus::onResolveCCBCCMenuItemSelector(CCObject * pTarget,
return NULL; return NULL;
} }
void PlayerStatus::setDeviceResolution(std::string res) {
setDeviceResolutionJNI(res.c_str());
}
void editBoxCallbackFunc(const char* pText, void* ctx) void editBoxCallbackFunc(const char* pText, void* ctx)
{ {
PlayerStatus *thiz = (PlayerStatus *)ctx; PlayerStatus *thiz = (PlayerStatus *)ctx;

View File

@ -41,6 +41,7 @@ public:
void pressedReset(CCObject * pSender, cocos2d::extension::CCControlEvent pCCControlEvent); void pressedReset(CCObject * pSender, cocos2d::extension::CCControlEvent pCCControlEvent);
void pressedRun(CCObject * pSender, cocos2d::extension::CCControlEvent pCCControlEvent); void pressedRun(CCObject * pSender, cocos2d::extension::CCControlEvent pCCControlEvent);
static void loadMainScene(const char *fileName); static void loadMainScene(const char *fileName);
static void setDeviceResolution(std::string res);
cocos2d::CCMenuItemImage* mBtnRun; cocos2d::CCMenuItemImage* mBtnRun;
cocos2d::CCMenuItemImage* mBtnReset; cocos2d::CCMenuItemImage* mBtnReset;

View File

@ -23,6 +23,7 @@ import java.nio.ByteOrder;
public class CCBStreamHandler { public class CCBStreamHandler {
private static String resolution = "xlarge";
public static final String TAG = CocosPlayerSocket.class.getSimpleName(); public static final String TAG = CocosPlayerSocket.class.getSimpleName();
public static NSDictionary parseBinaryPLIST(InputStream is) { public static NSDictionary parseBinaryPLIST(InputStream is) {
@ -95,7 +96,7 @@ public class CCBStreamHandler {
root.put("cmd", "deviceinfo"); root.put("cmd", "deviceinfo");
root.put("devicename", android.os.Build.MODEL); root.put("devicename", android.os.Build.MODEL);
root.put("devicetype", "Android"); root.put("devicetype", "Android");
root.put("preferredresourcetype", "xlarge"); root.put("preferredresourcetype", resolution);
String payload = root.toXMLPropertyList(); String payload = root.toXMLPropertyList();
// String data = new String(header, 0 , header.length); // String data = new String(header, 0 , header.length);
@ -104,4 +105,13 @@ public class CCBStreamHandler {
} }
return null; return null;
} }
public static void setDeviceResolution(String res) {
CocosPlayerSocket server = new CocosPlayerSocket();
Log.i(TAG, "Starting with resolution: "+res);
resolution = res;
server.setContext(CocosPlayer.c);
server.createServer();
}
} }

View File

@ -27,15 +27,15 @@ import org.cocos2dx.lib.Cocos2dxActivity;
import android.os.Bundle; import android.os.Bundle;
import android.content.Intent; import android.content.Intent;
import android.content.ContextWrapper;
import android.content.Context;
public class CocosPlayer extends Cocos2dxActivity{ public class CocosPlayer extends Cocos2dxActivity{
public static Context c;
protected void onCreate(Bundle savedInstanceState){ protected void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
c = getApplicationContext();
CocosPlayerSocket server = new CocosPlayerSocket();
server.setContext(getApplicationContext());
server.createServer();
} }
static { static {