2019-11-23 20:27:39 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
|
2021-09-07 17:24:07 +08:00
|
|
|
Copyright (c) 2021 Bytedance Inc.
|
|
|
|
|
2022-10-01 16:24:52 +08:00
|
|
|
https://axmolengine.github.io/
|
2021-09-07 17:24:07 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
2021-09-07 17:24:07 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
2021-09-07 17:24:07 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include "HelloWorldScene.h"
|
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
USING_NS_AX;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
// Print useful error message instead of segfaulting when files are not there.
|
|
|
|
static void problemLoading(const char* filename)
|
|
|
|
{
|
|
|
|
printf("Error while loading: %s\n", filename);
|
2021-09-07 17:24:07 +08:00
|
|
|
printf(
|
2023-08-31 19:55:52 +08:00
|
|
|
"Depending on how you compiled you might have to add 'Content/' in front of filenames in "
|
2021-09-07 17:24:07 +08:00
|
|
|
"HelloWorldScene.cpp\n");
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// on "init" you need to initialize your instance
|
|
|
|
bool HelloWorld::init()
|
|
|
|
{
|
|
|
|
//////////////////////////////
|
|
|
|
// 1. super init first
|
2021-09-07 17:24:07 +08:00
|
|
|
if (!Scene::init())
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2022-08-18 09:13:09 +08:00
|
|
|
auto visibleSize = _director->getVisibleSize();
|
2023-03-30 21:41:44 +08:00
|
|
|
auto origin = _director->getVisibleOrigin();
|
|
|
|
auto safeArea = _director->getSafeAreaRect();
|
|
|
|
auto safeOrigin = safeArea.origin;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/////////////////////////////
|
|
|
|
// 2. add a menu item with "X" image, which is clicked to quit the program
|
|
|
|
// you may modify it.
|
|
|
|
|
|
|
|
// add a "close" icon to exit the progress. it's an autorelease object
|
2021-09-07 17:24:07 +08:00
|
|
|
auto closeItem = MenuItemImage::create("CloseNormal.png", "CloseSelected.png",
|
2023-03-30 21:41:44 +08:00
|
|
|
AX_CALLBACK_1(HelloWorld::menuCloseCallback, this));
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-09-07 17:24:07 +08:00
|
|
|
if (closeItem == nullptr || closeItem->getContentSize().width <= 0 || closeItem->getContentSize().height <= 0)
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
problemLoading("'CloseNormal.png' and 'CloseSelected.png'");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2021-10-09 14:48:18 +08:00
|
|
|
float x = safeOrigin.x + safeArea.size.width - closeItem->getContentSize().width / 2;
|
|
|
|
float y = safeOrigin.y + closeItem->getContentSize().height / 2;
|
2021-09-07 17:24:07 +08:00
|
|
|
closeItem->setPosition(Vec2(x, y));
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// create menu, it's an autorelease object
|
|
|
|
auto menu = Menu::create(closeItem, NULL);
|
|
|
|
menu->setPosition(Vec2::ZERO);
|
|
|
|
this->addChild(menu, 1);
|
|
|
|
|
|
|
|
/////////////////////////////
|
|
|
|
// 3. add your codes below...
|
|
|
|
|
2023-03-14 15:25:12 +08:00
|
|
|
// Some templates (uncomment what you need)
|
2023-03-30 21:41:44 +08:00
|
|
|
auto touchListener = EventListenerTouchAllAtOnce::create();
|
2023-03-14 15:25:12 +08:00
|
|
|
touchListener->onTouchesBegan = AX_CALLBACK_2(HelloWorld::onTouchesBegan, this);
|
|
|
|
touchListener->onTouchesMoved = AX_CALLBACK_2(HelloWorld::onTouchesMoved, this);
|
|
|
|
touchListener->onTouchesEnded = AX_CALLBACK_2(HelloWorld::onTouchesEnded, this);
|
|
|
|
_eventDispatcher->addEventListenerWithSceneGraphPriority(touchListener, this);
|
|
|
|
|
|
|
|
//auto mouseListener = EventListenerMouse::create();
|
|
|
|
//mouseListener->onMouseMove = AX_CALLBACK_1(HelloWorld::onMouseMove, this);
|
|
|
|
//mouseListener->onMouseUp = AX_CALLBACK_1(HelloWorld::onMouseUp, this);
|
|
|
|
//mouseListener->onMouseDown = AX_CALLBACK_1(HelloWorld::onMouseDown, this);
|
|
|
|
//mouseListener->onMouseScroll = AX_CALLBACK_1(HelloWorld::onMouseScroll, this);
|
|
|
|
//_eventDispatcher->addEventListenerWithSceneGraphPriority(mouseListener, this);
|
|
|
|
|
|
|
|
//auto keyboardListener = EventListenerKeyboard::create();
|
|
|
|
//keyboardListener->onKeyPressed = AX_CALLBACK_2(HelloWorld::onKeyPressed, this);
|
|
|
|
//keyboardListener->onKeyReleased = AX_CALLBACK_2(HelloWorld::onKeyReleased, this);
|
|
|
|
//_eventDispatcher->addEventListenerWithFixedPriority(keyboardListener, 11);
|
|
|
|
|
|
|
|
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
// add a label shows "Hello World"
|
|
|
|
// create and initialize a label
|
|
|
|
|
|
|
|
auto label = Label::createWithTTF("Hello World", "fonts/Marker Felt.ttf", 24);
|
|
|
|
if (label == nullptr)
|
|
|
|
{
|
|
|
|
problemLoading("'fonts/Marker Felt.ttf'");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// position the label on the center of the screen
|
2021-09-07 17:24:07 +08:00
|
|
|
label->setPosition(
|
|
|
|
Vec2(origin.x + visibleSize.width / 2, origin.y + visibleSize.height - label->getContentSize().height));
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
// add the label as a child to this layer
|
|
|
|
this->addChild(label, 1);
|
|
|
|
}
|
|
|
|
// add "HelloWorld" splash screen"
|
2021-12-31 12:12:40 +08:00
|
|
|
auto sprite = Sprite::create("HelloWorld.png"sv);
|
2019-11-23 20:27:39 +08:00
|
|
|
if (sprite == nullptr)
|
|
|
|
{
|
|
|
|
problemLoading("'HelloWorld.png'");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// position the sprite on the center of the screen
|
2021-09-07 17:24:07 +08:00
|
|
|
sprite->setPosition(Vec2(visibleSize.width / 2 + origin.x, visibleSize.height / 2 + origin.y));
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
// add the sprite as a child to this layer
|
|
|
|
this->addChild(sprite, 0);
|
2021-09-07 17:24:07 +08:00
|
|
|
auto drawNode = DrawNode::create();
|
|
|
|
drawNode->setPosition(Vec2(0, 0));
|
|
|
|
addChild(drawNode);
|
|
|
|
|
2023-03-30 21:41:44 +08:00
|
|
|
drawNode->drawRect(safeArea.origin + Vec2(1, 1), safeArea.origin + safeArea.size, Color4F::BLUE);
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
2021-09-07 17:24:07 +08:00
|
|
|
|
2023-01-06 13:02:55 +08:00
|
|
|
// scheduleUpdate() is required to ensure update(float) is called on every loop
|
2023-01-03 05:26:23 +08:00
|
|
|
scheduleUpdate();
|
|
|
|
|
2023-03-30 21:41:44 +08:00
|
|
|
return true;
|
2023-01-03 05:26:23 +08:00
|
|
|
}
|
|
|
|
|
2023-03-14 15:25:12 +08:00
|
|
|
|
|
|
|
void HelloWorld::onTouchesBegan(const std::vector<ax::Touch*>& touches, ax::Event* event)
|
|
|
|
{
|
|
|
|
for (auto&& t : touches)
|
|
|
|
{
|
|
|
|
AXLOG("onTouchesBegan detected, X:%f Y:%f", t->getLocation().x, t->getLocation().y);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void HelloWorld::onTouchesMoved(const std::vector<ax::Touch*>& touches, ax::Event* event)
|
|
|
|
{
|
|
|
|
for (auto&& t : touches)
|
|
|
|
{
|
|
|
|
AXLOG("onTouchesMoved detected, X:%f Y:%f", t->getLocation().x, t->getLocation().y);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void HelloWorld::onTouchesEnded(const std::vector<ax::Touch*>& touches, ax::Event* event)
|
|
|
|
{
|
|
|
|
for (auto&& t : touches)
|
|
|
|
{
|
|
|
|
AXLOG("onTouchesEnded detected, X:%f Y:%f", t->getLocation().x, t->getLocation().y);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void HelloWorld::onMouseDown(Event* event)
|
|
|
|
{
|
|
|
|
EventMouse* e = static_cast<EventMouse*>(event);
|
|
|
|
AXLOG("onMouseDown detected, Key: %d", static_cast<int>(e->getMouseButton()));
|
|
|
|
}
|
|
|
|
|
|
|
|
void HelloWorld::onMouseUp(Event* event)
|
|
|
|
{
|
|
|
|
EventMouse* e = static_cast<EventMouse*>(event);
|
|
|
|
AXLOG("onMouseUp detected, Key: %d", static_cast<int>(e->getMouseButton()));
|
|
|
|
}
|
|
|
|
|
|
|
|
void HelloWorld::onMouseMove(Event* event)
|
|
|
|
{
|
|
|
|
EventMouse* e = static_cast<EventMouse*>(event);
|
|
|
|
AXLOG("onMouseMove detected, X:%f Y:%f", e->getCursorX(), e->getCursorY());
|
|
|
|
}
|
|
|
|
|
|
|
|
void HelloWorld::onMouseScroll(Event* event)
|
|
|
|
{
|
|
|
|
EventMouse* e = static_cast<EventMouse*>(event);
|
|
|
|
AXLOG("onMouseScroll detected, X:%f Y:%f", e->getScrollX(), e->getScrollY());
|
|
|
|
}
|
|
|
|
|
|
|
|
void HelloWorld::onKeyPressed(EventKeyboard::KeyCode code, Event* event)
|
|
|
|
{
|
|
|
|
AXLOG("onKeyPressed, keycode: %d", static_cast<int>(code));
|
|
|
|
}
|
|
|
|
|
|
|
|
void HelloWorld::onKeyReleased(EventKeyboard::KeyCode code, Event* event)
|
|
|
|
{
|
|
|
|
AXLOG("onKeyReleased, keycode: %d", static_cast<int>(code));
|
|
|
|
}
|
|
|
|
|
2023-01-03 05:26:23 +08:00
|
|
|
void HelloWorld::update(float delta)
|
|
|
|
{
|
2023-01-06 13:02:55 +08:00
|
|
|
switch (_gameState)
|
2023-01-03 05:26:23 +08:00
|
|
|
{
|
2023-01-06 13:02:55 +08:00
|
|
|
case ExampleGameState::init:
|
2023-03-30 21:41:44 +08:00
|
|
|
{
|
2023-01-06 13:02:55 +08:00
|
|
|
_gameState = ExampleGameState::update;
|
|
|
|
break;
|
2023-03-30 21:41:44 +08:00
|
|
|
}
|
2023-01-06 13:02:55 +08:00
|
|
|
|
|
|
|
case ExampleGameState::update:
|
2023-03-30 21:41:44 +08:00
|
|
|
{
|
2023-01-03 05:26:23 +08:00
|
|
|
/////////////////////////////
|
|
|
|
// Add your codes below...like....
|
|
|
|
//
|
|
|
|
// UpdateJoyStick();
|
|
|
|
// UpdatePlayer();
|
|
|
|
// UpdatePhysics();
|
|
|
|
// ...
|
|
|
|
break;
|
2023-03-30 21:41:44 +08:00
|
|
|
}
|
2023-01-03 05:26:23 +08:00
|
|
|
|
2023-01-06 13:02:55 +08:00
|
|
|
case ExampleGameState::pause:
|
2023-03-30 21:41:44 +08:00
|
|
|
{
|
2023-01-03 05:26:23 +08:00
|
|
|
/////////////////////////////
|
|
|
|
// Add your codes below...like....
|
|
|
|
//
|
|
|
|
// anyPauseStuff()
|
2023-03-30 21:41:44 +08:00
|
|
|
|
2023-01-03 05:26:23 +08:00
|
|
|
break;
|
2023-03-30 21:41:44 +08:00
|
|
|
}
|
2023-01-03 05:26:23 +08:00
|
|
|
|
2023-01-06 13:02:55 +08:00
|
|
|
case ExampleGameState::menu1:
|
2023-03-30 21:41:44 +08:00
|
|
|
{ /////////////////////////////
|
2023-01-03 05:26:23 +08:00
|
|
|
// Add your codes below...like....
|
|
|
|
//
|
|
|
|
// UpdateMenu1();
|
|
|
|
break;
|
2023-03-30 21:41:44 +08:00
|
|
|
}
|
2023-01-03 05:26:23 +08:00
|
|
|
|
2023-01-06 13:02:55 +08:00
|
|
|
case ExampleGameState::menu2:
|
2023-03-30 21:41:44 +08:00
|
|
|
{ /////////////////////////////
|
2023-01-03 05:26:23 +08:00
|
|
|
// Add your codes below...like....
|
|
|
|
//
|
|
|
|
// UpdateMenu2();
|
|
|
|
break;
|
2023-03-30 21:41:44 +08:00
|
|
|
}
|
2023-01-03 05:26:23 +08:00
|
|
|
|
2023-01-06 13:02:55 +08:00
|
|
|
case ExampleGameState::end:
|
2023-03-30 21:41:44 +08:00
|
|
|
{ /////////////////////////////
|
2023-01-03 05:26:23 +08:00
|
|
|
// Add your codes below...like....
|
|
|
|
//
|
|
|
|
// CleanUpMyCrap();
|
2023-01-03 17:40:05 +08:00
|
|
|
menuCloseCallback(this);
|
2023-01-03 05:26:23 +08:00
|
|
|
break;
|
|
|
|
}
|
2023-03-30 21:41:44 +08:00
|
|
|
|
|
|
|
} //switch
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
|
2021-09-07 17:24:07 +08:00
|
|
|
void HelloWorld::menuCloseCallback(Ref* sender)
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
2023-01-03 05:26:23 +08:00
|
|
|
// Close the axmol game scene and quit the application
|
2022-08-18 09:13:09 +08:00
|
|
|
_director->end();
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-09-07 17:24:07 +08:00
|
|
|
/*To navigate back to native iOS screen(if present) without quitting the application ,do not use
|
2022-08-18 09:13:09 +08:00
|
|
|
* _director->end() as given above,instead trigger a custom event created in RootViewController.mm
|
2021-09-07 17:24:07 +08:00
|
|
|
* as below*/
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2023-03-30 21:41:44 +08:00
|
|
|
// EventCustom customEndEvent("game_scene_close_event");
|
|
|
|
//_eventDispatcher->dispatchEvent(&customEndEvent);
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|