mirror of https://github.com/axmolengine/axmol.git
hot fix:Repair the crash of cocostudio and the bug of some lua test samples can't come in
This commit is contained in:
parent
bac14ab3e5
commit
5c8d24a11e
|
@ -622,9 +622,9 @@ Object* CCBAnimationManager::actionForCallbackChannel(CCBSequenceProperty* chann
|
||||||
|
|
||||||
Array *actions = Array::create();
|
Array *actions = Array::create();
|
||||||
Array *keyframes = channel->getKeyframes();
|
Array *keyframes = channel->getKeyframes();
|
||||||
int numKeyframes = keyframes->count();
|
long numKeyframes = keyframes->count();
|
||||||
|
|
||||||
for (int i = 0; i < numKeyframes; ++i)
|
for (long i = 0; i < numKeyframes; ++i)
|
||||||
{
|
{
|
||||||
|
|
||||||
CCBKeyframe *keyframe = (CCBKeyframe*)keyframes->getObjectAtIndex(i);
|
CCBKeyframe *keyframe = (CCBKeyframe*)keyframes->getObjectAtIndex(i);
|
||||||
|
@ -640,10 +640,14 @@ Object* CCBAnimationManager::actionForCallbackChannel(CCBSequenceProperty* chann
|
||||||
|
|
||||||
if(_jsControlled) {
|
if(_jsControlled) {
|
||||||
String* callbackName = String::createWithFormat("%d:%s", selectorTarget, selectorName.c_str());
|
String* callbackName = String::createWithFormat("%d:%s", selectorTarget, selectorName.c_str());
|
||||||
CallFunc *callback = ((CallFunc*)(_keyframeCallFuncs->objectForKey(callbackName->getCString())))->clone();
|
Object* callback = _keyframeCallFuncs->objectForKey(callbackName->getCString());
|
||||||
|
if (nullptr != callback)
|
||||||
if(callback != NULL) {
|
{
|
||||||
actions->addObject(callback);
|
CallFunc *callbackClone = (static_cast<CallFunc*>(callback))->clone();
|
||||||
|
|
||||||
|
if(callbackClone != NULL) {
|
||||||
|
actions->addObject(callbackClone);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
@ -1203,7 +1203,7 @@ void array_to_luaval(lua_State* L,Array* inValue)
|
||||||
if (nullptr == obj)
|
if (nullptr == obj)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
uint32_t typeId = typeid(*obj).hash_code();
|
long typeId = typeid(*obj).hash_code();
|
||||||
auto iter = g_luaType.find(typeId);
|
auto iter = g_luaType.find(typeId);
|
||||||
if (g_luaType.end() != iter)
|
if (g_luaType.end() != iter)
|
||||||
{
|
{
|
||||||
|
@ -1292,7 +1292,7 @@ void dictionary_to_luaval(lua_State* L, Dictionary* dict)
|
||||||
if (NULL == element)
|
if (NULL == element)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
uint32_t typeId = typeid(element->getObject()).hash_code();
|
long typeId = typeid(element->getObject()).hash_code();
|
||||||
|
|
||||||
auto iter = g_luaType.find(typeId);
|
auto iter = g_luaType.find(typeId);
|
||||||
if (g_luaType.end() != iter)
|
if (g_luaType.end() != iter)
|
||||||
|
|
|
@ -691,7 +691,7 @@ int register_cocos2dx_extension_CCBProxy(lua_State* tolua_S)
|
||||||
tolua_endmodule(tolua_S);
|
tolua_endmodule(tolua_S);
|
||||||
tolua_endmodule(tolua_S);
|
tolua_endmodule(tolua_S);
|
||||||
|
|
||||||
uint32_t typeId = typeid(CCBProxy).hash_code();
|
long typeId = typeid(CCBProxy).hash_code();
|
||||||
g_luaType[typeId] = "CCBProxy";
|
g_luaType[typeId] = "CCBProxy";
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue