Update ci branch name

This commit is contained in:
halx99 2021-12-31 11:00:35 +08:00
parent e726066595
commit 64d7b55366
1098 changed files with 46409 additions and 42237 deletions

42
.appveyor.yml Normal file
View File

@ -0,0 +1,42 @@
version: 1.0.{build}
skip_tags: true
skip_branch_with_pr: true
image:
- Visual Studio 2019
environment:
PYTHON: "C:\\Python27"
PYTHON_VERSION: "2.7.13"
PYTHON_ARCH: "32"
matrix:
- build_type: windows32_cmake_test
# - build_type: android_cpp_tests
# - build_type: android_lua_tests
# - build_type: android_cocos_new_test
# - build_type: android_cpp_empty_test
# - build_type: android_gen_libs
platform:
- x86
configuration:
- Release
before_build:
- ps: ./tools/appveyor-scripts/before-build.ps1
build_script:
- ps: ./tools/appveyor-scripts/build.ps1
branches:
except:
- v1
- v2
- v4-develop
- v3-doc
- v3.11_backup
- v35-for-tizen
clone_depth: 50
test: off

View File

@ -4,7 +4,7 @@ on:
push:
branches:
- dev
- main
- release
paths:
- cmake/**/*
- cocos/**/*
@ -16,9 +16,12 @@ on:
env:
# Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.)
GH_OS_NAME: linux
TRAVIS_OS_NAME: linux
BUILD_TARGET: android
# Simple let github action to build all (TODO: optimize in the future)
TRAVIS_PULL_REQUEST: true
BUILD_TYPE: Release
GITHUB_CI: true
PYENV_VERSION: 2.7.18
jobs:
@ -48,8 +51,8 @@ jobs:
- name: Create Build Environment
# Some projects don't allow in-source building, so create a separate build directory
# We'll use this as our working directory for all
run: tools/unix-ci/before-install.sh
run: tools/travis-scripts/before-install.sh
- name: Build
# Execute the build. You can specify a specific target with "--target <NAME>"
run: tools/unix-ci/run-script.sh
run: tools/travis-scripts/run-script.sh

View File

@ -7,7 +7,7 @@ on:
# actions run ID
description: 'Commit clang-format changes?'
# Default value if no value is explicitly provided
default: 'false'
default: false
# Input has to be provided for the workflow to run
required: false
@ -21,9 +21,9 @@ jobs:
- name: Run clang-format lint
uses: DoozyX/clang-format-lint-action@v0.13
with:
source: './cocos ./extensions ./tests ./templates'
exclude: './thidrparty ./extensions/fairygui ./extensions/scripting/lua-bindings/auto ./extensions/spine ./tests/fairygui-tests'
extensions: 'h,cpp,c,mm'
source: './cocos ./extensions'
exclude: './thidrparty ./extensions/fairygui ./extensions/scripting/lua-bindings/auto ./extensions/spine'
extensions: 'h,cpp,c'
clangFormatVersion: 13
inplace: True
- name: Commit clang-format changes

View File

@ -1,36 +0,0 @@
name: genbindings
on:
push:
branches:
- dev
- main
paths:
- cocos/**/*
- extensions/**/*
- .github/workflows/genbindings-ci.yml
jobs:
build:
if: ${{ !startsWith(github.event.commits[0].message, 'Merge pull request') }}
# The CMake configure and build commands are platform agnostic and should work equally
# well on Windows or Mac. You can convert this to a matrix build if you need
# cross-platform coverage.
# See: https://docs.github.com/en/actions/configuring-and-managing-workflows/configuring-a-workflow#configuring-a-build-matrix
runs-on: windows-latest
steps:
- uses: actions/checkout@v2
with:
submodules: 'recursive'
lfs: 'true'
- name: Setup Python
uses: actions/setup-python@v2
- uses: ilammy/msvc-dev-cmd@v1.9.0
with:
arch: ${{ env.BUILD_ARCH }}
- name: Build
run: tools\win-ci\genbindings.ps1

View File

@ -4,7 +4,7 @@ on:
push:
branches:
- dev
- main
- release
paths:
- cmake/**/*
- cocos/**/*
@ -16,9 +16,12 @@ on:
env:
# Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.)
GH_OS_NAME: osx
TRAVIS_OS_NAME: osx
BUILD_TARGET: ios
# Simple let github action to build all (TODO: optimize in the future)
TRAVIS_PULL_REQUEST: true
BUILD_TYPE: Release
GITHUB_CI: true
jobs:
build:
@ -38,8 +41,8 @@ jobs:
- name: Create Build Environment
# Some projects don't allow in-source building, so create a separate build directory
# We'll use this as our working directory for all
run: tools/unix-ci/before-install.sh
run: tools/travis-scripts/before-install.sh
- name: Build
# Execute the build. You can specify a specific target with "--target <NAME>"
run: tools/unix-ci/run-script.sh
run: tools/travis-scripts/run-script.sh

View File

@ -4,7 +4,7 @@ on:
push:
branches:
- dev
- main
- release
paths:
- cmake/**/*
- cocos/**/*
@ -16,10 +16,12 @@ on:
env:
# Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.)
GH_OS_NAME: linux
TRAVIS_OS_NAME: linux
BUILD_TARGET: linux
# Simple let github action to build all (TODO: optimize in the future)
TRAVIS_PULL_REQUEST: true
BUILD_TYPE: Release
PYENV_VERSION: 2.7.18
GITHUB_CI: true
jobs:
build:
@ -39,8 +41,8 @@ jobs:
- name: Create Build Environment
# Some projects don't allow in-source building, so create a separate build directory
# We'll use this as our working directory for all subsequent commands
run: tools/unix-ci/before-install.sh
run: tools/travis-scripts/before-install.sh
- name: Build
# Execute the build. You can specify a specific target with "--target <NAME>"
run: tools/unix-ci/run-script.sh
run: tools/travis-scripts/run-script.sh

View File

@ -4,7 +4,7 @@ on:
push:
branches:
- dev
- main
- release
paths:
- cmake/**/*
- cocos/**/*
@ -16,9 +16,12 @@ on:
env:
# Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.)
GH_OS_NAME: osx
TRAVIS_OS_NAME: osx
BUILD_TARGET: osx
# Simple let github action to build all (TODO: optimize in the future)
TRAVIS_PULL_REQUEST: true
BUILD_TYPE: Release
GITHUB_CI: true
jobs:
build:
@ -38,8 +41,8 @@ jobs:
- name: Create Build Environment
# Some projects don't allow in-source building, so create a separate build directory
# We'll use this as our working directory for all
run: tools/unix-ci/before-install.sh
run: tools/travis-scripts/before-install.sh
- name: Build
# Execute the build. You can specify a specific target with "--target <NAME>"
run: tools/unix-ci/run-script.sh
run: tools/travis-scripts/run-script.sh

View File

@ -8,7 +8,9 @@ on:
env:
# Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.)
BUILD_TYPE: Release
PYENV_VERSION: 2.7.18
# Simple let github action to build all (TODO: optimize in the future)
TRAVIS_PULL_REQUEST: true
GITHUB_CI: true
jobs:
build-windows:
@ -29,13 +31,13 @@ jobs:
- name: Setup Python
uses: actions/setup-python@v2
- name: Build
run: tools\win-ci\build.ps1 $env:BUILD_ARCH
run: tools\windows-ci\build.ps1 $env:BUILD_ARCH
build-linux:
name: build-linux
runs-on: ubuntu-latest
env:
GH_OS_NAME: linux
TRAVIS_OS_NAME: linux
BUILD_TARGET: linux
steps:
- uses: actions/checkout@v2
@ -44,8 +46,8 @@ jobs:
lfs: 'true'
- name: Build
run: |
tools/unix-ci/before-install.sh
tools/unix-ci/run-script.sh
tools/travis-scripts/before-install.sh
tools/travis-scripts/run-script.sh
build-android:
name: build-android
@ -57,8 +59,9 @@ jobs:
- arm64-v8a
- x86
env:
GH_OS_NAME: linux
TRAVIS_OS_NAME: linux
BUILD_TARGET: android
PYENV_VERSION: 2.7.18
BUILD_ARCH: ${{ matrix.arch }}
steps:
- uses: actions/checkout@v2
@ -67,14 +70,14 @@ jobs:
lfs: 'true'
- name: Build
run: |
tools/unix-ci/before-install.sh
tools/unix-ci/run-script.sh
tools/travis-scripts/before-install.sh
tools/travis-scripts/run-script.sh
build-osx:
name: build-osx
runs-on: macos-latest
env:
GH_OS_NAME: osx
TRAVIS_OS_NAME: osx
BUILD_TARGET: osx
steps:
- uses: actions/checkout@v2
@ -83,14 +86,14 @@ jobs:
lfs: 'true'
- name: Build
run: |
tools/unix-ci/before-install.sh
tools/unix-ci/run-script.sh
tools/travis-scripts/before-install.sh
tools/travis-scripts/run-script.sh
build-ios:
name: build-ios
runs-on: macos-latest
env:
GH_OS_NAME: osx
TRAVIS_OS_NAME: osx
BUILD_TARGET: ios
steps:
- uses: actions/checkout@v2
@ -99,5 +102,5 @@ jobs:
lfs: 'true'
- name: Build
run: |
tools/unix-ci/before-install.sh
tools/unix-ci/run-script.sh
tools/travis-scripts/before-install.sh
tools/travis-scripts/run-script.sh

View File

@ -4,7 +4,7 @@ on:
push:
branches:
- dev
- main
- release
paths:
- cmake/**/*
- cocos/**/*
@ -44,4 +44,4 @@ jobs:
arch: ${{ env.BUILD_ARCH }}
- name: Build
run: tools\win-ci\build.ps1 $env:BUILD_ARCH
run: tools\windows-ci\build.ps1 $env:BUILD_ARCH

View File

@ -1,9 +1,7 @@
# adxe
[![dev](https://img.shields.io/badge/v1.0.0-beta5-yellow.svg)](https://github.com/adxeproject/adxe/releases)
[![LICENSE](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/adxeproject/adxe/blob/master/LICENSE)
[![Codacy Badge](https://api.codacy.com/project/badge/Grade/1c5628dea478449ea0c6e1b0e30c3be9)](https://app.codacy.com/gh/adxeproject/adxe?utm_source=github.com&utm_medium=referral&utm_content=adxeproject/adxe&utm_campaign=Badge_Grade_Settings)
[![PRs Welcome](https://img.shields.io/badge/PRs-welcome-blue.svg)](https://github.com/adxeproject/adxe/pulls)
[![dev](https://img.shields.io/badge/v1.0.0-beta4-yellow.svg)](https://github.com/adxeproject/adxe/releases)
[![LICENSE](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/adxeproject/adxe/blob/master/LICENSE)
[![Windows Build Status](https://github.com/adxeproject/adxe/actions/workflows/windows-ci.yml/badge.svg)](https://github.com/adxeproject/adxe/actions/workflows/windows-ci.yml)
[![Android Build Status](https://github.com/adxeproject/adxe/workflows/android/badge.svg)](https://github.com/adxeproject/adxe/actions?query=workflow%3Aandroid)
@ -11,7 +9,7 @@
[![Linux Build Status](https://github.com/adxeproject/adxe/workflows/linux/badge.svg)](https://github.com/adxeproject/adxe/actions?query=workflow%3Alinux)
[![macOS Build Status](https://github.com/adxeproject/adxe/workflows/osx/badge.svg)](https://github.com/adxeproject/adxe/actions?query=workflow%3Aosx)
**This is another more radical fork of *Cocos2d-x-4.0*, use OpenAL for all platforms, single texture multi GPU texture handler, C++ 17 and some more (see 'Highlight Features' for more info).**
**This is another more radical fork of *Cocos2d-x-4.0*, use OpenAL for all platforms, single texture multi GPU texture handler, C++ 14/17 and some more (see 'Highlight Features' for more info).**
### View code with vscode online:
- [![github1s](https://img.shields.io/badge/github1s-green.svg)](https://github1s.com/adxeproject/adxe)
@ -21,9 +19,10 @@
**[简体中文](README_CN.md)**
### Purpose Summary
* C++ 17
* C++ 14/17
* Focus on native game dev (quick starting, easy to use, fast)
* Bugfixes ASAP
* Usefull PRs from **you** are welcome (review/merge ASAP)
### Highlight Features
* Windows x64 build support
@ -37,7 +36,7 @@
* Implement all .wav formats supported by ```OpenAL Soft```, such as MS-ADPCM, ADPCM, ...
* Use modern GL loader ```Glad```
* Google [angle](https://github.com/google/angle) renderer backend support
* C++ 17 standard
* C++ 14 standard
* IOS SDK 9.0 as minimal deployment
* Use fast pugixml
* Use [curl](https://github.com/curl/curl) for transferring data with URL syntax
@ -137,7 +136,7 @@ https://github.com/adxeproject/adxe/discussions/411
- @aismann
- @weiwest
### Fully changes since cocos2d-x-4.0
### Fullly changes since cocos2d-x-4.0
- [HIGHLIGHT] Implement Windows WebView using WebView2 Edge Chromium, thanks to @rh101
- [HIGHLIGHT] Windows x64 build support

View File

@ -1,9 +1,8 @@
# adxe
[![dev](https://img.shields.io/badge/v1.0.0-beta5-yellow.svg)](https://github.com/adxeproject/adxe/releases)
[![LICENSE](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/adxeproject/adxe/blob/master/LICENSE)
[![Codacy Badge](https://api.codacy.com/project/badge/Grade/1c5628dea478449ea0c6e1b0e30c3be9)](https://app.codacy.com/gh/adxeproject/adxe?utm_source=github.com&utm_medium=referral&utm_content=adxeproject/adxe&utm_campaign=Badge_Grade_Settings)
[![PRs Welcome](https://img.shields.io/badge/PRs-welcome-blue.svg)](https://github.com/adxeproject/adxe/pulls)
[![dev](https://img.shields.io/badge/v1.0.0-beta4-yellow.svg)](https://github.com/adxeproject/adxe/releases)
[![LICENSE](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/adxeproject/adxe/blob/master/LICENSE)
[![Windows Build Status](https://github.com/adxeproject/adxe/actions/workflows/windows-ci.yml/badge.svg)](https://github.com/adxeproject/adxe/actions/workflows/windows-ci.yml)
[![Android Build Status](https://github.com/adxeproject/adxe/workflows/android/badge.svg)](https://github.com/adxeproject/adxe/actions?query=workflow%3Aandroid)
@ -12,15 +11,16 @@
[![macOS Build Status](https://github.com/adxeproject/adxe/workflows/osx/badge.svg)](https://github.com/adxeproject/adxe/actions?query=workflow%3Aosx)
**这是另外一个基于 *Cocos2d-x-4.0* 持续维护的分支, 全平台基于OpenAL, c++17...**
**这是另外一个基于 *Cocos2d-x-4.0* 持续维护的分支, 全平台基于OpenAL, c++14/17...**
**[English](README.md)**
### 宗旨:
* C++17
* C++14/17
* Focus on native game dev only
* Fix bugs ASAP
* Review PR ASAP
* Excellent PRs from any guys are welcome, we will review & merge ASAP
### 主要特性:
* Windows x64编译支持
@ -33,7 +33,7 @@
* AudioEngine实现wav所有 ```openal-soft``` 支持的封装格式, 例如MS-ADPCM, ADPCM等
* 使用现代化的GL加载器glad代替glew
* 增加google angle渲染后端支持
* C++最低标准要求: C++17
* 设置默认C++标准为C++14
* 设置ios下最低目标平台为ios9.0
* 使用更快的xml解析库pugixml代替tinyxml2
* Downloader全平台统一实现均基于curl

View File

@ -247,7 +247,7 @@ Vec2 ShuffleTiles::getDelta(const Vec2& pos) const
pos2.x = (float)(_tilesOrder[idx] / (int)_gridSize.height);
pos2.y = (float)(_tilesOrder[idx] % (int)_gridSize.height);
return Vec2(static_cast<float>((int)(pos2.x - pos.width)), static_cast<float>((int)(pos2.y - pos.height)));
return Vec2((int)(pos2.x - pos.width), (int)(pos2.y - pos.height));
}
void ShuffleTiles::placeTile(const Vec2& pos, Tile* t)

View File

@ -29,7 +29,7 @@ THE SOFTWARE.
NS_CC_BEGIN
ActionTween* ActionTween::create(float duration, std::string_view key, float from, float to)
ActionTween* ActionTween::create(float duration, const std::string& key, float from, float to)
{
ActionTween* ret = new ActionTween();
if (ret->initWithDuration(duration, key, from, to))
@ -42,7 +42,7 @@ ActionTween* ActionTween::create(float duration, std::string_view key, float fro
return nullptr;
}
bool ActionTween::initWithDuration(float duration, std::string_view key, float from, float to)
bool ActionTween::initWithDuration(float duration, const std::string& key, float from, float to)
{
if (ActionInterval::initWithDuration(duration))
{

View File

@ -59,7 +59,7 @@ public:
@param value The new value of the specified key.
@param key The key of property which should be updated.
*/
virtual void updateTweenAction(float value, std::string_view key) = 0;
virtual void updateTweenAction(float value, const std::string& key) = 0;
};
/** ActionTween
@ -93,7 +93,7 @@ public:
* @param to The value of the specified property when the action end.
* @return If the creation success, return a pointer of ActionTween; otherwise, return nil.
*/
static ActionTween* create(float duration, std::string_view key, float from, float to);
static ActionTween* create(float duration, const std::string& key, float from, float to);
// Overrides
void startWithTarget(Node* target) override;
@ -111,7 +111,7 @@ public:
* @return If the initialization success, return true; otherwise, return false.
*/
bool
initWithDuration(float duration, std::string_view key, float from, float to);
initWithDuration(float duration, const std::string& key, float from, float to);
protected:
std::string _key;

View File

@ -165,7 +165,7 @@ void Animation::addSpriteFrame(SpriteFrame* spriteFrame)
_totalDelayUnits++;
}
void Animation::addSpriteFrameWithFile(std::string_view filename)
void Animation::addSpriteFrameWithFile(const std::string& filename)
{
Texture2D* texture = Director::getInstance()->getTextureCache()->addImage(filename);
Rect rect = Rect::ZERO;

View File

@ -199,7 +199,7 @@ public:
* Added to facilitate the migration from v0.8 to v0.9.
* @param filename The path of SpriteFrame.
*/
void addSpriteFrameWithFile(std::string_view filename);
void addSpriteFrameWithFile(const std::string& filename);
/** Adds a frame with a texture and a rect. Internally it will create a SpriteFrame and it will add it.
* The frame will be added with one "delay unit".

View File

@ -63,12 +63,12 @@ AnimationCache::~AnimationCache()
CCLOGINFO("deallocing AnimationCache: %p", this);
}
void AnimationCache::addAnimation(Animation* animation, std::string_view name)
void AnimationCache::addAnimation(Animation* animation, const std::string& name)
{
_animations.insert(std::string{name}, animation);
_animations.insert(name, animation);
}
void AnimationCache::removeAnimation(std::string_view name)
void AnimationCache::removeAnimation(const std::string& name)
{
if (name.empty())
return;
@ -76,7 +76,7 @@ void AnimationCache::removeAnimation(std::string_view name)
_animations.erase(name);
}
Animation* AnimationCache::getAnimation(std::string_view name)
Animation* AnimationCache::getAnimation(const std::string& name)
{
return _animations.at(name);
}
@ -205,7 +205,7 @@ void AnimationCache::parseVersion2(const ValueMap& animations)
}
}
void AnimationCache::addAnimationsWithDictionary(const ValueMap& dictionary, std::string_view plist)
void AnimationCache::addAnimationsWithDictionary(const ValueMap& dictionary, const std::string& plist)
{
auto anisItr = dictionary.find("animations");
if (anisItr == dictionary.end())
@ -245,7 +245,7 @@ void AnimationCache::addAnimationsWithDictionary(const ValueMap& dictionary, std
}
/** Read an NSDictionary from a plist file and parse it automatically for animations */
void AnimationCache::addAnimationsWithFile(std::string_view plist)
void AnimationCache::addAnimationsWithFile(const std::string& plist)
{
CCASSERT(!plist.empty(), "Invalid texture file name");
if (plist.empty())
@ -259,7 +259,7 @@ void AnimationCache::addAnimationsWithFile(std::string_view plist)
CCASSERT(!dict.empty(), "CCAnimationCache: File could not be found");
if (dict.empty())
{
log("AnimationCache::addAnimationsWithFile error:%s not exist!", plist.data());
log("AnimationCache::addAnimationsWithFile error:%s not exist!", plist.c_str());
}
addAnimationsWithDictionary(dict, plist);

View File

@ -81,13 +81,13 @@ public:
* @param animation An animation.
* @param name The name of animation.
*/
void addAnimation(Animation* animation, std::string_view name);
void addAnimation(Animation* animation, const std::string& name);
/** Deletes a Animation from the cache.
*
* @param name The name of animation.
*/
void removeAnimation(std::string_view name);
void removeAnimation(const std::string& name);
/** Returns a Animation that was previously added.
* If the name is not found it will return nil.
@ -95,7 +95,7 @@ public:
*
* @return A Animation that was previously added. If the name is not found it will return nil.
*/
Animation* getAnimation(std::string_view name);
Animation* getAnimation(const std::string& name);
/** Adds an animation from an NSDictionary.
* Make sure that the frames were previously loaded in the SpriteFrameCache.
@ -104,7 +104,7 @@ public:
* @since v1.1
@js NA
*/
void addAnimationsWithDictionary(const ValueMap& dictionary, std::string_view plist);
void addAnimationsWithDictionary(const ValueMap& dictionary, const std::string& plist);
/** Adds an animation from a plist file.
* Make sure that the frames were previously loaded in the SpriteFrameCache.
@ -113,14 +113,14 @@ public:
* @lua addAnimations
* @param plist An animation from a plist file.
*/
void addAnimationsWithFile(std::string_view plist);
void addAnimationsWithFile(const std::string& plist);
private:
void parseVersion1(const ValueMap& animations);
void parseVersion2(const ValueMap& animations);
private:
StringMap<Animation*> _animations;
Map<std::string, Animation*> _animations;
static AnimationCache* s_sharedAnimationCache;
};

View File

@ -47,7 +47,7 @@ AtlasNode::~AtlasNode()
CC_SAFE_RELEASE(_textureAtlas);
}
AtlasNode* AtlasNode::create(std::string_view tile, int tileWidth, int tileHeight, int itemsToRender)
AtlasNode* AtlasNode::create(const std::string& tile, int tileWidth, int tileHeight, int itemsToRender)
{
AtlasNode* ret = new AtlasNode();
if (ret->initWithTileFile(tile, tileWidth, tileHeight, itemsToRender))
@ -59,7 +59,7 @@ AtlasNode* AtlasNode::create(std::string_view tile, int tileWidth, int tileHeigh
return nullptr;
}
bool AtlasNode::initWithTileFile(std::string_view tile, int tileWidth, int tileHeight, int itemsToRender)
bool AtlasNode::initWithTileFile(const std::string& tile, int tileWidth, int tileHeight, int itemsToRender)
{
CCASSERT(!tile.empty(), "file size should not be empty");
Texture2D* texture = _director->getTextureCache()->addImage(tile);
@ -222,7 +222,7 @@ void AtlasNode::setIgnoreContentScaleFactor(bool ignoreContentScaleFactor)
auto label = dynamic_cast<LabelProtocol*>(this);
if (label)
{
Vec2 s = Vec2(static_cast<float>(label->getString().size() * _itemWidth), static_cast<float>(_itemHeight));
Vec2 s = Vec2(label->getString().size() * _itemWidth, _itemHeight);
this->setContentSize(s);
}
}

View File

@ -57,7 +57,7 @@ public:
* @param tileHeight The height of the item.
* @param itemsToRender The quantity of items to render.
*/
static AtlasNode* create(std::string_view filename, int tileWidth, int tileHeight, int itemsToRender);
static AtlasNode* create(const std::string& filename, int tileWidth, int tileHeight, int itemsToRender);
/** updates the Atlas (indexed vertex array).
* Shall be overridden in subclasses.
@ -106,7 +106,7 @@ public:
/** Initializes an AtlasNode with an Atlas file the width and height of each item and the quantity of items to
* render*/
bool initWithTileFile(std::string_view tile, int tileWidth, int tileHeight, int itemsToRender);
bool initWithTileFile(const std::string& tile, int tileWidth, int tileHeight, int itemsToRender);
/** Initializes an AtlasNode with a texture the width and height of each item measured in points and the quantity
* of items to render*/

View File

@ -168,7 +168,7 @@ float PolygonInfo::getArea() const
return area;
}
AutoPolygon::AutoPolygon(std::string_view filename)
AutoPolygon::AutoPolygon(const std::string& filename)
: _image(nullptr), _data(nullptr), _filename(""), _width(0), _height(0), _scaleFactor(0)
{
_filename = filename;
@ -714,7 +714,7 @@ PolygonInfo AutoPolygon::generateTriangles(const Rect& rect, float epsilon, floa
return ret;
}
PolygonInfo AutoPolygon::generatePolygon(std::string_view filename, const Rect& rect, float epsilon, float threshold)
PolygonInfo AutoPolygon::generatePolygon(const std::string& filename, const Rect& rect, float epsilon, float threshold)
{
AutoPolygon ap(filename);
return ap.generateTriangles(rect, epsilon, threshold);

View File

@ -117,8 +117,8 @@ public:
const Rect& getRect() const { return _rect; }
void setRect(const Rect& rect) { _rect = rect; }
std::string_view getFilename() const { return _filename; }
void setFilename(std::string_view filename) { _filename = filename; }
const std::string& getFilename() const { return _filename; }
void setFilename(const std::string& filename) { _filename = filename; }
// FIXME: this should be a property, not a public ivar
TrianglesCommand::Triangles triangles;
@ -147,7 +147,7 @@ public:
* @param filename a path to image file, e.g., "scene1/monster.png".
* @return an AutoPolygon object;
*/
AutoPolygon(std::string_view filename);
AutoPolygon(const std::string& filename);
/**
* Destructor of AutoPolygon.
@ -254,7 +254,7 @@ public:
* auto sp = Sprite::create(AutoPolygon::generatePolygon("grossini.png"));
* @endcode
*/
static PolygonInfo generatePolygon(std::string_view filename,
static PolygonInfo generatePolygon(const std::string& filename,
const Rect& rect = Rect::ZERO,
float epsilon = 2.0f,
float threshold = 0.05f);

View File

@ -71,12 +71,12 @@ CameraBackgroundDepthBrush* CameraBackgroundBrush::createDepthBrush(float depth)
return CameraBackgroundDepthBrush::create(depth);
}
CameraBackgroundSkyBoxBrush* CameraBackgroundBrush::createSkyboxBrush(std::string_view positive_x,
std::string_view negative_x,
std::string_view positive_y,
std::string_view negative_y,
std::string_view positive_z,
std::string_view negative_z)
CameraBackgroundSkyBoxBrush* CameraBackgroundBrush::createSkyboxBrush(const std::string& positive_x,
const std::string& negative_x,
const std::string& positive_y,
const std::string& negative_y,
const std::string& positive_z,
const std::string& negative_z)
{
return CameraBackgroundSkyBoxBrush::create(positive_x, negative_x, positive_y, negative_y, positive_z, negative_z);
}
@ -303,12 +303,12 @@ CameraBackgroundSkyBoxBrush::~CameraBackgroundSkyBoxBrush()
#endif
}
CameraBackgroundSkyBoxBrush* CameraBackgroundSkyBoxBrush::create(std::string_view positive_x,
std::string_view negative_x,
std::string_view positive_y,
std::string_view negative_y,
std::string_view positive_z,
std::string_view negative_z)
CameraBackgroundSkyBoxBrush* CameraBackgroundSkyBoxBrush::create(const std::string& positive_x,
const std::string& negative_x,
const std::string& positive_y,
const std::string& negative_y,
const std::string& positive_z,
const std::string& negative_z)
{
CameraBackgroundSkyBoxBrush* ret = nullptr;

View File

@ -105,12 +105,12 @@ public:
@param negative_z texture for the rear side of the texture cube face.
@return A new brush inited with given parameters.
*/
static CameraBackgroundSkyBoxBrush* createSkyboxBrush(std::string_view positive_x,
std::string_view negative_x,
std::string_view positive_y,
std::string_view negative_y,
std::string_view positive_z,
std::string_view negative_z);
static CameraBackgroundSkyBoxBrush* createSkyboxBrush(const std::string& positive_x,
const std::string& negative_x,
const std::string& positive_y,
const std::string& negative_y,
const std::string& positive_z,
const std::string& negative_z);
/**
* draw the background
*/
@ -253,12 +253,12 @@ public:
@param negative_z texture for the rear side of the texture cube face.
@return A new brush inited with given parameters.
*/
static CameraBackgroundSkyBoxBrush* create(std::string_view positive_x,
std::string_view negative_x,
std::string_view positive_y,
std::string_view negative_y,
std::string_view positive_z,
std::string_view negative_z);
static CameraBackgroundSkyBoxBrush* create(const std::string& positive_x,
const std::string& negative_x,
const std::string& positive_y,
const std::string& negative_y,
const std::string& positive_z,
const std::string& negative_z);
/** Creates a Skybox brush with 6 textures.
*/

View File

@ -60,8 +60,8 @@ public:
bool isEnabled() const { return _enabled; }
virtual void setEnabled(bool enabled);
std::string_view getName() const { return _name; }
virtual void setName(std::string_view name) { _name = name; }
const std::string& getName() const { return _name; }
virtual void setName(const std::string& name) { _name = name; }
Node* getOwner() const { return _owner; }
virtual void setOwner(Node* owner);

View File

@ -33,7 +33,7 @@ ComponentContainer::ComponentContainer(Node* node) : _owner(node) {}
ComponentContainer::~ComponentContainer() {}
Component* ComponentContainer::get(std::string_view name) const
Component* ComponentContainer::get(const std::string& name) const
{
Component* ret = nullptr;
@ -60,7 +60,7 @@ bool ComponentContainer::add(Component* com)
CCASSERT(false, "ComponentContainer already have this kind of component");
break;
}
hlookup::set_item(_componentMap, componentName, com); //_componentMap[componentName] = com;
_componentMap[componentName] = com;
com->retain();
com->setOwner(_owner);
com->onAdd();
@ -70,7 +70,7 @@ bool ComponentContainer::add(Component* com)
return ret;
}
bool ComponentContainer::remove(std::string_view componentName)
bool ComponentContainer::remove(const std::string& componentName)
{
bool ret = false;
do

View File

@ -54,10 +54,10 @@ public:
/**
* @js getComponent
*/
Component* get(std::string_view name) const;
Component* get(const std::string& name) const;
bool add(Component* com);
bool remove(std::string_view name);
bool remove(const std::string& name);
bool remove(Component* com);
void removeAll();
void visit(float delta);
@ -68,7 +68,7 @@ public:
bool isEmpty() const { return _componentMap.empty(); }
private:
hlookup::string_map<Component*> _componentMap;
std::unordered_map<std::string, Component*> _componentMap;
Node* _owner;
friend class Node;

View File

@ -799,7 +799,7 @@ void FastTMXLayer::removeChild(Node* node, bool cleanup)
}
// TMXLayer - Properties
Value FastTMXLayer::getProperty(std::string_view propertyName) const
Value FastTMXLayer::getProperty(const std::string& propertyName) const
{
auto propItr = _properties.find(propertyName);
if (propItr != _properties.end())

View File

@ -152,7 +152,7 @@ public:
* @param propertyName The value for the specific property name.
* @return The value for the specific property name.
*/
Value getProperty(std::string_view propertyName) const;
Value getProperty(const std::string& propertyName) const;
/** Creates the tiles. */
void setupTiles();
@ -161,13 +161,13 @@ public:
*
* @return The tile layer name.
*/
std::string_view getLayerName() { return _layerName; }
const std::string& getLayerName() { return _layerName; }
/** Set the tile layer name.
*
* @param layerName The new layer name.
*/
void setLayerName(std::string_view layerName) { _layerName = layerName; }
void setLayerName(const std::string& layerName) { _layerName = layerName; }
/** Gets the size of the layer in tiles.
*

View File

@ -33,7 +33,7 @@ NS_CC_BEGIN
// implementation FastTMXTiledMap
FastTMXTiledMap* FastTMXTiledMap::create(std::string_view tmxFile)
FastTMXTiledMap* FastTMXTiledMap::create(const std::string& tmxFile)
{
FastTMXTiledMap* ret = new FastTMXTiledMap();
if (ret->initWithTMXFile(tmxFile))
@ -45,7 +45,7 @@ FastTMXTiledMap* FastTMXTiledMap::create(std::string_view tmxFile)
return nullptr;
}
FastTMXTiledMap* FastTMXTiledMap::createWithXML(std::string_view tmxString, std::string_view resourcePath)
FastTMXTiledMap* FastTMXTiledMap::createWithXML(const std::string& tmxString, const std::string& resourcePath)
{
FastTMXTiledMap* ret = new FastTMXTiledMap();
if (ret->initWithXML(tmxString, resourcePath))
@ -57,7 +57,7 @@ FastTMXTiledMap* FastTMXTiledMap::createWithXML(std::string_view tmxString, std:
return nullptr;
}
bool FastTMXTiledMap::initWithTMXFile(std::string_view tmxFile)
bool FastTMXTiledMap::initWithTMXFile(const std::string& tmxFile)
{
CCASSERT(tmxFile.size() > 0, "FastTMXTiledMap: tmx file should not be empty");
@ -77,7 +77,7 @@ bool FastTMXTiledMap::initWithTMXFile(std::string_view tmxFile)
return true;
}
bool FastTMXTiledMap::initWithXML(std::string_view tmxString, std::string_view resourcePath)
bool FastTMXTiledMap::initWithXML(const std::string& tmxString, const std::string& resourcePath)
{
setContentSize(Vec2::ZERO);
@ -194,7 +194,7 @@ void FastTMXTiledMap::buildWithMapInfo(TMXMapInfo* mapInfo)
}
// public
FastTMXLayer* FastTMXTiledMap::getLayer(std::string_view layerName) const
FastTMXLayer* FastTMXTiledMap::getLayer(const std::string& layerName) const
{
CCASSERT(!layerName.empty(), "Invalid layer name!");
@ -214,7 +214,7 @@ FastTMXLayer* FastTMXTiledMap::getLayer(std::string_view layerName) const
return nullptr;
}
TMXObjectGroup* FastTMXTiledMap::getObjectGroup(std::string_view groupName) const
TMXObjectGroup* FastTMXTiledMap::getObjectGroup(const std::string& groupName) const
{
CCASSERT(!groupName.empty(), "Invalid group name!");
@ -233,7 +233,7 @@ TMXObjectGroup* FastTMXTiledMap::getObjectGroup(std::string_view groupName) cons
return nullptr;
}
Value FastTMXTiledMap::getProperty(std::string_view propertyName) const
Value FastTMXTiledMap::getProperty(const std::string& propertyName) const
{
auto propsItr = _properties.find(propertyName);
if (propsItr != _properties.end())

View File

@ -101,7 +101,7 @@ public:
*
* @return An autorelease object.
*/
static FastTMXTiledMap* create(std::string_view tmxFile);
static FastTMXTiledMap* create(const std::string& tmxFile);
/** Initializes a TMX Tiled Map with a TMX formatted XML string and a path to TMX resources.
*
@ -109,25 +109,25 @@ public:
* @param resourcePath A path to TMX resources.
* @return An autorelease object.
*/
static FastTMXTiledMap* createWithXML(std::string_view tmxString, std::string_view resourcePath);
static FastTMXTiledMap* createWithXML(const std::string& tmxString, const std::string& resourcePath);
/** Return the FastTMXLayer for the specific layer.
*
* @return Return the FastTMXLayer for the specific layer.
*/
FastTMXLayer* getLayer(std::string_view layerName) const;
FastTMXLayer* getLayer(const std::string& layerName) const;
/** Return the TMXObjectGroup for the specific group.
*
* @return Return the TMXObjectGroup for the specific group.
*/
TMXObjectGroup* getObjectGroup(std::string_view groupName) const;
TMXObjectGroup* getObjectGroup(const std::string& groupName) const;
/** Return the value for the specific property name.
*
* @return Return the value for the specific property name.
*/
Value getProperty(std::string_view propertyName) const;
Value getProperty(const std::string& propertyName) const;
/** Return properties dictionary for tile GID.
*
@ -207,7 +207,7 @@ public:
int getLayerCount() const { return _layerCount; }
std::string_view getResourceFile() const { return _tmxFile; }
const std::string& getResourceFile() const { return _tmxFile; }
CC_CONSTRUCTOR_ACCESS :
/**
@ -221,10 +221,10 @@ public:
virtual ~FastTMXTiledMap();
/** initializes a TMX Tiled Map with a TMX file */
bool initWithTMXFile(std::string_view tmxFile);
bool initWithTMXFile(const std::string& tmxFile);
/** initializes a TMX Tiled Map with a TMX formatted XML string and a path to TMX resources */
bool initWithXML(std::string_view tmxString, std::string_view resourcePath);
bool initWithXML(const std::string& tmxString, const std::string& resourcePath);
protected:
FastTMXLayer* parseLayer(TMXLayerInfo* layerInfo, TMXMapInfo* mapInfo);

View File

@ -520,9 +520,9 @@ void FontAtlas::setLineHeight(float newHeight)
_lineHeight = newHeight;
}
std::string_view FontAtlas::getFontName() const
std::string FontAtlas::getFontName() const
{
std::string_view fontName = _fontFreeType ? _fontFreeType->getFontName() : ""sv;
std::string fontName = _fontFreeType ? _fontFreeType->getFontName() : "";
if (fontName.empty())
return fontName;
auto idx = fontName.rfind('/');

View File

@ -86,7 +86,7 @@ public:
float getLineHeight() const { return _lineHeight; }
void setLineHeight(float newHeight);
std::string_view getFontName() const;
std::string getFontName() const;
Texture2D* getTexture(int slot);
const Font* getFont() const { return _font; }

View File

@ -36,7 +36,7 @@
NS_CC_BEGIN
hlookup::string_map<FontAtlas*> FontAtlasCache::_atlasMap;
std::unordered_map<std::string, FontAtlas*> FontAtlasCache::_atlasMap;
#define ATLAS_MAP_KEY_PREFIX_BUFFER_SIZE 255
void FontAtlasCache::purgeCachedData()
@ -80,7 +80,8 @@ FontAtlas* FontAtlasCache::getFontAtlasTTF(const _ttfConfig* config)
auto tempAtlas = font->newFontAtlas();
if (tempAtlas)
{
return _atlasMap.emplace(atlasName, tempAtlas).first->second;
_atlasMap[atlasName] = tempAtlas;
return _atlasMap[atlasName];
}
}
}
@ -90,17 +91,16 @@ FontAtlas* FontAtlasCache::getFontAtlasTTF(const _ttfConfig* config)
return nullptr;
}
FontAtlas* FontAtlasCache::getFontAtlasFNT(std::string_view fontFileName)
FontAtlas* FontAtlasCache::getFontAtlasFNT(const std::string& fontFileName)
{
return getFontAtlasFNT(fontFileName, Rect::ZERO, false);
}
FontAtlas* FontAtlasCache::getFontAtlasFNT(std::string_view fontFileName, std::string_view subTextureKey)
FontAtlas* FontAtlasCache::getFontAtlasFNT(const std::string& fontFileName, const std::string& subTextureKey)
{
const auto realFontFilename = FileUtils::getInstance()->getNewFilename(
fontFileName); // resolves real file path, to prevent storing multiple atlases for the same file.
std::string atlasName{subTextureKey};
atlasName.append(" ", 1).append(realFontFilename);
std::string atlasName = subTextureKey + " " + realFontFilename;
const auto it = _atlasMap.find(atlasName);
if (it == _atlasMap.end())
@ -123,7 +123,7 @@ FontAtlas* FontAtlasCache::getFontAtlasFNT(std::string_view fontFileName, std::s
return nullptr;
}
FontAtlas* FontAtlasCache::getFontAtlasFNT(std::string_view fontFileName, const Rect& imageRect, bool imageRotated)
FontAtlas* FontAtlasCache::getFontAtlasFNT(const std::string& fontFileName, const Rect& imageRect, bool imageRotated)
{
const auto realFontFilename = FileUtils::getInstance()->getNewFilename(
fontFileName); // resolves real file path, to prevent storing multiple atlases for the same file.
@ -153,14 +153,14 @@ FontAtlas* FontAtlasCache::getFontAtlasFNT(std::string_view fontFileName, const
return nullptr;
}
FontAtlas* FontAtlasCache::getFontAtlasFNT(std::string_view fontFileName, const Vec2& imageOffset)
FontAtlas* FontAtlasCache::getFontAtlasFNT(const std::string& fontFileName, const Vec2& imageOffset)
{
return getFontAtlasFNT(fontFileName, Rect(imageOffset.x, imageOffset.y, 0, 0), false);
}
FontAtlas* FontAtlasCache::getFontAtlasCharMap(std::string_view plistFile)
FontAtlas* FontAtlasCache::getFontAtlasCharMap(const std::string& plistFile)
{
std::string_view atlasName = plistFile;
const std::string& atlasName = plistFile;
auto it = _atlasMap.find(atlasName);
if (it == _atlasMap.end())
@ -172,8 +172,8 @@ FontAtlas* FontAtlasCache::getFontAtlasCharMap(std::string_view plistFile)
auto tempAtlas = font->newFontAtlas();
if (tempAtlas)
{
hlookup::set_item(_atlasMap, atlasName, tempAtlas); // _atlasMap[atlasName] = tempAtlas;
return tempAtlas;
_atlasMap[atlasName] = tempAtlas;
return _atlasMap[atlasName];
}
}
}
@ -210,7 +210,7 @@ FontAtlas* FontAtlasCache::getFontAtlasCharMap(Texture2D* texture, int itemWidth
return nullptr;
}
FontAtlas* FontAtlasCache::getFontAtlasCharMap(std::string_view charMapFile,
FontAtlas* FontAtlasCache::getFontAtlasCharMap(const std::string& charMapFile,
int itemWidth,
int itemHeight,
int startCharMap)
@ -263,7 +263,7 @@ bool FontAtlasCache::releaseFontAtlas(FontAtlas* atlas)
return false;
}
void FontAtlasCache::reloadFontAtlasFNT(std::string_view fontFileName, const Rect& imageRect, bool imageRotated)
void FontAtlasCache::reloadFontAtlasFNT(const std::string& fontFileName, const Rect& imageRect, bool imageRotated)
{
char keyPrefix[ATLAS_MAP_KEY_PREFIX_BUFFER_SIZE];
snprintf(keyPrefix, ATLAS_MAP_KEY_PREFIX_BUFFER_SIZE, "%.2f %.2f ", imageRect.origin.x, imageRect.origin.y);
@ -288,12 +288,12 @@ void FontAtlasCache::reloadFontAtlasFNT(std::string_view fontFileName, const Rec
}
}
void FontAtlasCache::reloadFontAtlasFNT(std::string_view fontFileName, const Vec2& imageOffset)
void FontAtlasCache::reloadFontAtlasFNT(const std::string& fontFileName, const Vec2& imageOffset)
{
reloadFontAtlasFNT(fontFileName, Rect(imageOffset.x, imageOffset.y, 0, 0), false);
}
void FontAtlasCache::unloadFontAtlasTTF(std::string_view fontFileName)
void FontAtlasCache::unloadFontAtlasTTF(const std::string& fontFileName)
{
auto item = _atlasMap.begin();
while (item != _atlasMap.end())

View File

@ -43,17 +43,17 @@ class CC_DLL FontAtlasCache
public:
static FontAtlas* getFontAtlasTTF(const _ttfConfig* config);
static FontAtlas* getFontAtlasFNT(std::string_view fontFileName);
static FontAtlas* getFontAtlasFNT(std::string_view fontFileName, std::string_view subTextureKey);
static FontAtlas* getFontAtlasFNT(std::string_view fontFileName, const Rect& imageRect, bool imageRotated);
CC_DEPRECATED_ATTRIBUTE static FontAtlas* getFontAtlasFNT(std::string_view fontFileName, const Vec2& imageOffset);
static FontAtlas* getFontAtlasFNT(const std::string& fontFileName);
static FontAtlas* getFontAtlasFNT(const std::string& fontFileName, const std::string& subTextureKey);
static FontAtlas* getFontAtlasFNT(const std::string& fontFileName, const Rect& imageRect, bool imageRotated);
CC_DEPRECATED_ATTRIBUTE static FontAtlas* getFontAtlasFNT(const std::string& fontFileName, const Vec2& imageOffset);
static FontAtlas* getFontAtlasCharMap(std::string_view charMapFile,
static FontAtlas* getFontAtlasCharMap(const std::string& charMapFile,
int itemWidth,
int itemHeight,
int startCharMap);
static FontAtlas* getFontAtlasCharMap(Texture2D* texture, int itemWidth, int itemHeight, int startCharMap);
static FontAtlas* getFontAtlasCharMap(std::string_view plistFile);
static FontAtlas* getFontAtlasCharMap(const std::string& plistFile);
static bool releaseFontAtlas(FontAtlas* atlas);
@ -66,19 +66,19 @@ public:
CAUTION : All component use this font texture should be reset font name, though the file name is same!
otherwise, it will cause program crash!
*/
static void reloadFontAtlasFNT(std::string_view fontFileName, const Rect& imageRect, bool imageRotated);
static void reloadFontAtlasFNT(const std::string& fontFileName, const Rect& imageRect, bool imageRotated);
CC_DEPRECATED_ATTRIBUTE static void reloadFontAtlasFNT(std::string_view fontFileName,
CC_DEPRECATED_ATTRIBUTE static void reloadFontAtlasFNT(const std::string& fontFileName,
const Vec2& imageOffset = Vec2::ZERO);
/** Unload all texture atlas texture create by special file name.
CAUTION : All component use this font texture should be reset font name, though the file name is same!
otherwise, it will cause program crash!
*/
static void unloadFontAtlasTTF(std::string_view fontFileName);
static void unloadFontAtlasTTF(const std::string& fontFileName);
private:
static hlookup::string_map<FontAtlas*> _atlasMap;
static std::unordered_map<std::string, FontAtlas*> _atlasMap;
};
NS_CC_END

View File

@ -33,7 +33,7 @@
NS_CC_BEGIN
FontCharMap* FontCharMap::create(std::string_view plistFile)
FontCharMap* FontCharMap::create(const std::string& plistFile)
{
std::string pathStr = FileUtils::getInstance()->fullPathForFilename(plistFile);
std::string relPathStr = pathStr.substr(0, pathStr.find_last_of('/')) + "/";
@ -64,7 +64,7 @@ FontCharMap* FontCharMap::create(std::string_view plistFile)
return tempFont;
}
FontCharMap* FontCharMap::create(std::string_view charMapFile, int itemWidth, int itemHeight, int startCharMap)
FontCharMap* FontCharMap::create(const std::string& charMapFile, int itemWidth, int itemHeight, int startCharMap)
{
Texture2D* tempTexture = Director::getInstance()->getTextureCache()->addImage(charMapFile);

View File

@ -38,9 +38,9 @@ class Texture2D;
class FontCharMap : public Font
{
public:
static FontCharMap* create(std::string_view charMapFile, int itemWidth, int itemHeight, int startCharMap);
static FontCharMap* create(const std::string& charMapFile, int itemWidth, int itemHeight, int startCharMap);
static FontCharMap* create(Texture2D* texture, int itemWidth, int itemHeight, int startCharMap);
static FontCharMap* create(std::string_view plistFile);
static FontCharMap* create(const std::string& plistFile);
virtual int* getHorizontalKerningForTextUTF32(const std::u32string& text, int& outNumLetters) const override;
virtual FontAtlas* newFontAtlas() override;

View File

@ -56,15 +56,15 @@ struct _FontDefHashElement;
//
// FNTConfig Cache - free functions
//
static StringMap<BMFontConfiguration*>* s_configurations = nullptr;
static Map<std::string, BMFontConfiguration*>* s_configurations = nullptr;
BMFontConfiguration* FNTConfigLoadFile(std::string_view fntFile)
BMFontConfiguration* FNTConfigLoadFile(const std::string& fntFile)
{
BMFontConfiguration* ret = nullptr;
if (s_configurations == nullptr)
{
s_configurations = new StringMap<BMFontConfiguration*>();
s_configurations = new Map<std::string, BMFontConfiguration*>();
}
ret = s_configurations->at(fntFile);
@ -84,7 +84,7 @@ BMFontConfiguration* FNTConfigLoadFile(std::string_view fntFile)
// BitmapFontConfiguration
//
BMFontConfiguration* BMFontConfiguration::create(std::string_view FNTfile)
BMFontConfiguration* BMFontConfiguration::create(const std::string& FNTfile)
{
BMFontConfiguration* ret = new BMFontConfiguration();
if (ret->initWithFNTfile(FNTfile))
@ -96,7 +96,7 @@ BMFontConfiguration* BMFontConfiguration::create(std::string_view FNTfile)
return nullptr;
}
bool BMFontConfiguration::initWithFNTfile(std::string_view FNTfile)
bool BMFontConfiguration::initWithFNTfile(const std::string& FNTfile)
{
_characterSet = this->parseConfigFile(FNTfile);
@ -141,7 +141,7 @@ void BMFontConfiguration::purgeFontDefDictionary()
_fontDefDictionary.clear();
}
std::set<unsigned int>* BMFontConfiguration::parseConfigFile(std::string_view controlFile)
std::set<unsigned int>* BMFontConfiguration::parseConfigFile(const std::string& controlFile)
{
std::string data = FileUtils::getInstance()->getStringFromFile(controlFile);
if (data.empty())
@ -156,7 +156,7 @@ std::set<unsigned int>* BMFontConfiguration::parseConfigFile(std::string_view co
}
if (data[0] == 0)
{
CCLOG("cocos2d: Error parsing FNTfile %s", controlFile.data());
CCLOG("cocos2d: Error parsing FNTfile %s", controlFile.c_str());
return nullptr;
}
auto contents = data.c_str();
@ -223,7 +223,7 @@ std::set<unsigned int>* BMFontConfiguration::parseConfigFile(std::string_view co
std::set<unsigned int>* BMFontConfiguration::parseBinaryConfigFile(unsigned char* pData,
uint32_t size,
std::string_view controlFile)
const std::string& controlFile)
{
/* based on http://www.angelcode.com/products/bmfont/doc/file_format.html file format */
@ -399,7 +399,7 @@ std::set<unsigned int>* BMFontConfiguration::parseBinaryConfigFile(unsigned char
return validCharsString;
}
void BMFontConfiguration::parseImageFileName(const char* line, std::string_view fntFile)
void BMFontConfiguration::parseImageFileName(const char* line, const std::string& fntFile)
{
//////////////////////////////////////////////////////////////////////////
// line to parse:
@ -528,7 +528,7 @@ void BMFontConfiguration::parseKerningEntry(const char* line)
_kerningDictionary[key] = amount;
}
FontFNT* FontFNT::create(std::string_view fntFilePath, const Rect& imageRect, bool imageRotated)
FontFNT* FontFNT::create(const std::string& fntFilePath, const Rect& imageRect, bool imageRotated)
{
const auto newConf = FNTConfigLoadFile(fntFilePath);
if (!newConf)
@ -545,7 +545,7 @@ FontFNT* FontFNT::create(std::string_view fntFilePath, const Rect& imageRect, bo
return tempFont;
}
FontFNT* FontFNT::create(std::string_view fntFilePath, std::string_view subTextureKey)
FontFNT* FontFNT::create(const std::string& fntFilePath, const std::string& subTextureKey)
{
const auto newConf = FNTConfigLoadFile(fntFilePath);
if (!newConf)
@ -567,7 +567,7 @@ FontFNT* FontFNT::create(std::string_view fntFilePath, std::string_view subTextu
return tempFont;
}
FontFNT* FontFNT::create(std::string_view fntFilePath)
FontFNT* FontFNT::create(const std::string& fntFilePath)
{
const auto newConf = FNTConfigLoadFile(fntFilePath);
if (!newConf)
@ -590,7 +590,7 @@ FontFNT* FontFNT::create(std::string_view fntFilePath)
return tempFont;
}
FontFNT* FontFNT::create(std::string_view fntFilePath, const Vec2& imageOffset)
FontFNT* FontFNT::create(const std::string& fntFilePath, const Vec2& imageOffset)
{
return create(fntFilePath, Rect(imageOffset.x, imageOffset.y, 0, 0), false);
}
@ -762,11 +762,11 @@ FontAtlas* FontFNT::newFontAtlas()
return tempAtlas;
}
void FontFNT::reloadBMFontResource(std::string_view fntFilePath)
void FontFNT::reloadBMFontResource(const std::string& fntFilePath)
{
if (s_configurations == nullptr)
{
s_configurations = new StringMap<BMFontConfiguration*>();
s_configurations = new Map<std::string, BMFontConfiguration*>();
}
BMFontConfiguration* ret = s_configurations->at(fntFilePath);

View File

@ -115,27 +115,27 @@ public:
std::string description() const;
/** allocates a BMFontConfiguration with a FNT file */
static BMFontConfiguration* create(std::string_view FNTfile);
static BMFontConfiguration* create(const std::string& FNTfile);
/** initializes a BitmapFontConfiguration with a FNT file */
bool initWithFNTfile(std::string_view FNTfile);
bool initWithFNTfile(const std::string& FNTfile);
std::string_view getAtlasName() { return _atlasName; }
void setAtlasName(std::string_view atlasName) { _atlasName = atlasName; }
const std::string& getAtlasName() { return _atlasName; }
void setAtlasName(const std::string& atlasName) { _atlasName = atlasName; }
std::set<unsigned int>* getCharacterSet() const;
protected:
virtual std::set<unsigned int>* parseConfigFile(std::string_view controlFile);
virtual std::set<unsigned int>* parseConfigFile(const std::string& controlFile);
virtual std::set<unsigned int>* parseBinaryConfigFile(unsigned char* pData,
uint32_t size,
std::string_view controlFile);
const std::string& controlFile);
private:
unsigned int parseCharacterDefinition(const char* line);
void parseInfoArguments(const char* line);
void parseCommonArguments(const char* line);
void parseImageFileName(const char* line, std::string_view fntFile);
void parseImageFileName(const char* line, const std::string& fntFile);
void parseKerningEntry(const char* line);
void purgeKerningDictionary();
void purgeFontDefDictionary();
@ -145,11 +145,12 @@ class CC_DLL FontFNT : public Font
{
public:
static FontFNT* create(std::string_view fntFilePath, const Rect& imageRect, bool imageRotated);
static FontFNT* create(std::string_view fntFilePath, std::string_view subTextureKey);
static FontFNT* create(std::string_view fntFilePath);
static FontFNT* create(const std::string& fntFilePath, const Rect& imageRect, bool imageRotated);
static FontFNT* create(const std::string& fntFilePath, const std::string& subTextureKey);
static FontFNT* create(const std::string& fntFilePath);
CC_DEPRECATED_ATTRIBUTE static FontFNT* create(std::string_view fntFilePath, const Vec2& imageOffset = Vec2::ZERO);
CC_DEPRECATED_ATTRIBUTE static FontFNT* create(const std::string& fntFilePath,
const Vec2& imageOffset = Vec2::ZERO);
/** Purges the cached data.
Removes from memory the cached configurations and the atlas name dictionary.
@ -163,7 +164,7 @@ public:
int getOriginalFontSize() const;
static void reloadBMFontResource(std::string_view fntFilePath);
static void reloadBMFontResource(const std::string& fntFilePath);
protected:
FontFNT(BMFontConfiguration* theContfig, const Rect& imageRect, bool imageRotated);

View File

@ -653,7 +653,7 @@ std::string_view FontFreeType::getGlyphCollection() const
return glyphCollection;
}
void FontFreeType::releaseFont(std::string_view fontName)
void FontFreeType::releaseFont(const std::string& fontName)
{
auto item = s_cacheFontData.begin();
while (s_cacheFontData.end() != item)

View File

@ -101,12 +101,12 @@ public:
int getFontAscender() const;
const char* getFontFamily() const;
std::string_view getFontName() const { return _fontName; }
const std::string& getFontName() const { return _fontName; }
virtual FontAtlas* newFontAtlas() override;
virtual int getFontMaxHeight() const override { return _lineHeight; }
static void releaseFont(std::string_view fontName);
static void releaseFont(const std::string& fontName);
static FT_Library getFTLibrary();

View File

@ -240,8 +240,8 @@ Label* Label::create()
return ret;
}
Label* Label::createWithSystemFont(std::string_view text,
std::string_view font,
Label* Label::createWithSystemFont(const std::string& text,
const std::string& font,
float fontSize,
const Vec2& dimensions /* = Vec2::ZERO */,
TextHAlignment hAlignment /* = TextHAlignment::LEFT */,
@ -259,8 +259,8 @@ Label* Label::createWithSystemFont(std::string_view text,
return ret;
}
Label* Label::createWithTTF(std::string_view text,
std::string_view fontFile,
Label* Label::createWithTTF(const std::string& text,
const std::string& fontFile,
float fontSize,
const Vec2& dimensions /* = Vec2::ZERO */,
TextHAlignment hAlignment /* = TextHAlignment::LEFT */,
@ -279,7 +279,7 @@ Label* Label::createWithTTF(std::string_view text,
}
Label* Label::createWithTTF(const TTFConfig& ttfConfig,
std::string_view text,
const std::string& text,
TextHAlignment hAlignment /* = TextHAlignment::CENTER */,
int maxLineWidth /* = 0 */)
{
@ -295,8 +295,8 @@ Label* Label::createWithTTF(const TTFConfig& ttfConfig,
return nullptr;
}
Label* Label::createWithBMFont(std::string_view bmfontPath,
std::string_view text,
Label* Label::createWithBMFont(const std::string& bmfontPath,
const std::string& text,
const TextHAlignment& hAlignment,
int maxLineWidth)
{
@ -315,8 +315,8 @@ Label* Label::createWithBMFont(std::string_view bmfontPath,
return nullptr;
}
Label* Label::createWithBMFont(std::string_view bmfontPath,
std::string_view text,
Label* Label::createWithBMFont(const std::string& bmfontPath,
const std::string& text,
const TextHAlignment& hAlignment,
int maxLineWidth,
const Rect& imageRect,
@ -337,11 +337,11 @@ Label* Label::createWithBMFont(std::string_view bmfontPath,
return nullptr;
}
Label* Label::createWithBMFont(std::string_view bmfontPath,
std::string_view text,
Label* Label::createWithBMFont(const std::string& bmfontPath,
const std::string& text,
const TextHAlignment& hAlignment,
int maxLineWidth,
std::string_view subTextureKey)
const std::string& subTextureKey)
{
auto ret = new Label(hAlignment);
@ -358,8 +358,8 @@ Label* Label::createWithBMFont(std::string_view bmfontPath,
return nullptr;
}
Label* Label::createWithBMFont(std::string_view bmfontPath,
std::string_view text,
Label* Label::createWithBMFont(const std::string& bmfontPath,
const std::string& text,
const TextHAlignment& hAlignment,
int maxLineWidth,
const Vec2& imageOffset)
@ -368,7 +368,7 @@ Label* Label::createWithBMFont(std::string_view bmfontPath,
false);
}
Label* Label::createWithCharMap(std::string_view plistFile)
Label* Label::createWithCharMap(const std::string& plistFile)
{
auto ret = new Label();
@ -396,7 +396,7 @@ Label* Label::createWithCharMap(Texture2D* texture, int itemWidth, int itemHeigh
return nullptr;
}
Label* Label::createWithCharMap(std::string_view charMapFile, int itemWidth, int itemHeight, int startCharMap)
Label* Label::createWithCharMap(const std::string& charMapFile, int itemWidth, int itemHeight, int startCharMap)
{
auto ret = new Label();
@ -410,7 +410,7 @@ Label* Label::createWithCharMap(std::string_view charMapFile, int itemWidth, int
return nullptr;
}
bool Label::setCharMap(std::string_view plistFile)
bool Label::setCharMap(const std::string& plistFile)
{
auto newAtlas = FontAtlasCache::getFontAtlasCharMap(plistFile);
@ -426,8 +426,8 @@ bool Label::setCharMap(std::string_view plistFile)
return true;
}
bool Label::initWithTTF(std::string_view text,
std::string_view fontFilePath,
bool Label::initWithTTF(const std::string& text,
const std::string& fontFilePath,
float fontSize,
const Vec2& dimensions,
TextHAlignment /*hAlignment*/,
@ -447,7 +447,7 @@ bool Label::initWithTTF(std::string_view text,
}
bool Label::initWithTTF(const TTFConfig& ttfConfig,
std::string_view text,
const std::string& text,
TextHAlignment /*hAlignment*/,
int maxLineWidth)
{
@ -476,7 +476,7 @@ bool Label::setCharMap(Texture2D* texture, int itemWidth, int itemHeight, int st
return true;
}
bool Label::setCharMap(std::string_view charMapFile, int itemWidth, int itemHeight, int startCharMap)
bool Label::setCharMap(const std::string& charMapFile, int itemWidth, int itemHeight, int startCharMap)
{
auto newAtlas = FontAtlasCache::getFontAtlasCharMap(charMapFile, itemWidth, itemHeight, startCharMap);
@ -841,7 +841,7 @@ bool Label::setTTFConfig(const TTFConfig& ttfConfig)
return setTTFConfigInternal(ttfConfig);
}
bool Label::setBMFontFilePath(std::string_view bmfontFilePath, float fontSize)
bool Label::setBMFontFilePath(const std::string& bmfontFilePath, float fontSize)
{
FontAtlas* newAtlas = FontAtlasCache::getFontAtlasFNT(bmfontFilePath);
@ -875,7 +875,10 @@ bool Label::setBMFontFilePath(std::string_view bmfontFilePath, float fontSize)
return true;
}
bool Label::setBMFontFilePath(std::string_view bmfontFilePath, const Rect& imageRect, bool imageRotated, float fontSize)
bool Label::setBMFontFilePath(const std::string& bmfontFilePath,
const Rect& imageRect,
bool imageRotated,
float fontSize)
{
FontAtlas* newAtlas = FontAtlasCache::getFontAtlasFNT(bmfontFilePath, imageRect, imageRotated);
@ -911,7 +914,7 @@ bool Label::setBMFontFilePath(std::string_view bmfontFilePath, const Rect& image
return true;
}
bool Label::setBMFontFilePath(std::string_view bmfontFilePath, std::string_view subTextureKey, float fontSize)
bool Label::setBMFontFilePath(const std::string& bmfontFilePath, const std::string& subTextureKey, float fontSize)
{
FontAtlas* newAtlas = FontAtlasCache::getFontAtlasFNT(bmfontFilePath, subTextureKey);
@ -946,7 +949,7 @@ bool Label::setBMFontFilePath(std::string_view bmfontFilePath, std::string_view
return true;
}
bool Label::setBMFontFilePath(std::string_view bmfontFilePath, const Vec2& imageOffset, float fontSize)
bool Label::setBMFontFilePath(const std::string& bmfontFilePath, const Vec2& imageOffset, float fontSize)
{
return setBMFontFilePath(bmfontFilePath, Rect(imageOffset.x, imageOffset.y, 0, 0), false);
}
@ -2102,7 +2105,7 @@ void Label::drawSelf(bool visibleByCamera, Renderer* renderer, uint32_t flags)
}
}
void Label::setSystemFontName(std::string_view systemFont)
void Label::setSystemFontName(const std::string& systemFont)
{
if (systemFont != _systemFont)
{

View File

@ -166,8 +166,8 @@ public:
*
* @return An automatically released Label object.
*/
static Label* createWithSystemFont(std::string_view text,
std::string_view font,
static Label* createWithSystemFont(const std::string& text,
const std::string& font,
float fontSize,
const Vec2& dimensions = Vec2::ZERO,
TextHAlignment hAlignment = TextHAlignment::LEFT,
@ -185,8 +185,8 @@ public:
*
* @return An automatically released Label object.
*/
static Label* createWithTTF(std::string_view text,
std::string_view fontFilePath,
static Label* createWithTTF(const std::string& text,
const std::string& fontFilePath,
float fontSize,
const Vec2& dimensions = Vec2::ZERO,
TextHAlignment hAlignment = TextHAlignment::LEFT,
@ -204,7 +204,7 @@ public:
* @see TTFConfig setTTFConfig setMaxLineWidth
*/
static Label* createWithTTF(const TTFConfig& ttfConfig,
std::string_view text,
const std::string& text,
TextHAlignment hAlignment = TextHAlignment::LEFT,
int maxLineWidth = 0);
@ -219,8 +219,8 @@ public:
* @return An automatically released Label object.
* @see setBMFontFilePath setMaxLineWidth
*/
static Label* createWithBMFont(std::string_view bmfontPath,
std::string_view text,
static Label* createWithBMFont(const std::string& bmfontPath,
const std::string& text,
const TextHAlignment& hAlignment = TextHAlignment::LEFT,
int maxLineWidth = 0);
@ -237,8 +237,8 @@ public:
* @return An automatically released Label object.
* @see setBMFontFilePath setMaxLineWidth
*/
static Label* createWithBMFont(std::string_view bmfontPath,
std::string_view text,
static Label* createWithBMFont(const std::string& bmfontPath,
const std::string& text,
const TextHAlignment& hAlignment,
int maxLineWidth,
const Rect& imageRect,
@ -256,11 +256,11 @@ public:
* @return An automatically released Label object.
* @see setBMFontFilePath setMaxLineWidth
*/
static Label* createWithBMFont(std::string_view bmfontPath,
std::string_view text,
static Label* createWithBMFont(const std::string& bmfontPath,
const std::string& text,
const TextHAlignment& hAlignment,
int maxLineWidth,
std::string_view subTextureKey);
const std::string& subTextureKey);
/**
* Allocates and initializes a Label, with a bitmap font file.
@ -274,8 +274,8 @@ public:
* @return An automatically released Label object.
* @see setBMFontFilePath setMaxLineWidth
*/
CC_DEPRECATED_ATTRIBUTE static Label* createWithBMFont(std::string_view bmfontPath,
std::string_view text,
CC_DEPRECATED_ATTRIBUTE static Label* createWithBMFont(const std::string& bmfontPath,
const std::string& text,
const TextHAlignment& hAlignment,
int maxLineWidth,
const Vec2& imageOffset);
@ -290,7 +290,7 @@ public:
*
* @return An automatically released Label object.
*/
static Label* createWithCharMap(std::string_view charMapFile, int itemWidth, int itemHeight, int startCharMap);
static Label* createWithCharMap(const std::string& charMapFile, int itemWidth, int itemHeight, int startCharMap);
/**
* Allocates and initializes a Label, with char map configuration.
@ -311,7 +311,7 @@ public:
*
* @return An automatically released Label object.
*/
static Label* createWithCharMap(std::string_view plistFile);
static Label* createWithCharMap(const std::string& plistFile);
// end of creators group
/// @}
@ -332,31 +332,33 @@ public:
virtual const TTFConfig& getTTFConfig() const { return _fontConfig; }
/** Sets a new bitmap font to Label */
virtual bool setBMFontFilePath(std::string_view bmfontFilePath, float fontSize = 0);
virtual bool setBMFontFilePath(const std::string& bmfontFilePath, float fontSize = 0);
/** Sets a new bitmap font to Label */
virtual bool setBMFontFilePath(std::string_view bmfontFilePath,
virtual bool setBMFontFilePath(const std::string& bmfontFilePath,
const Rect& imageRect,
bool imageRotated,
float fontSize = 0);
/** Sets a new bitmap font to Label */
virtual bool setBMFontFilePath(std::string_view bmfontFilePath, std::string_view subTextureKey, float fontSize = 0);
virtual bool setBMFontFilePath(const std::string& bmfontFilePath,
const std::string& subTextureKey,
float fontSize = 0);
/** Sets a new bitmap font to Label */
CC_DEPRECATED_ATTRIBUTE virtual bool setBMFontFilePath(std::string_view bmfontFilePath,
CC_DEPRECATED_ATTRIBUTE virtual bool setBMFontFilePath(const std::string& bmfontFilePath,
const Vec2& imageOffset,
float fontSize = 0);
/** Returns the bitmap font used by the Label.*/
std::string_view getBMFontFilePath() const { return _bmFontPath; }
const std::string& getBMFontFilePath() const { return _bmFontPath; }
/**
* Sets a new char map configuration to Label.
*
* @see `createWithCharMap(std::string_view,int,int,int)`
* @see `createWithCharMap(const std::string&,int,int,int)`
*/
virtual bool setCharMap(std::string_view charMapFile, int itemWidth, int itemHeight, int startCharMap);
virtual bool setCharMap(const std::string& charMapFile, int itemWidth, int itemHeight, int startCharMap);
/**
* Sets a new char map configuration to Label.
@ -368,9 +370,9 @@ public:
/**
* Sets a new char map configuration to Label.
*
* @see `createWithCharMap(std::string_view)`
* @see `createWithCharMap(const std::string&)`
*/
virtual bool setCharMap(std::string_view plistFile);
virtual bool setCharMap(const std::string& plistFile);
/**
* Sets a new system font to Label.
@ -378,10 +380,10 @@ public:
* @param font A font file or a font family name.
* @warning
*/
virtual void setSystemFontName(std::string_view font);
virtual void setSystemFontName(const std::string& font);
/** Returns the system font used by the Label.*/
virtual std::string_view getSystemFontName() const { return _systemFont; }
virtual const std::string& getSystemFontName() const { return _systemFont; }
/* Sets the system font size of Label.*/
virtual void setSystemFontSize(float fontSize);
@ -401,7 +403,7 @@ public:
virtual void setString(std::string_view text) override;
/** Return the text the Label is currently displaying.*/
virtual std::string_view getString() const override { return _utf8Text; }
virtual const std::string& getString() const override { return _utf8Text; }
/**
* Return the number of lines of text.
@ -714,15 +716,15 @@ public:
*/
virtual ~Label();
bool initWithTTF(std::string_view text,
std::string_view fontFilePath,
bool initWithTTF(const std::string& text,
const std::string& fontFilePath,
float fontSize,
const Vec2& dimensions = Vec2::ZERO,
TextHAlignment hAlignment = TextHAlignment::LEFT,
TextVAlignment vAlignment = TextVAlignment::TOP);
bool initWithTTF(const TTFConfig& ttfConfig,
std::string_view text,
const std::string& text,
TextHAlignment hAlignment = TextHAlignment::LEFT,
int maxLineWidth = 0);

View File

@ -40,8 +40,8 @@ NS_CC_BEGIN
// CCLabelAtlas - Creation & Init
LabelAtlas* LabelAtlas::create(std::string_view string,
std::string_view charMapFile,
LabelAtlas* LabelAtlas::create(const std::string& string,
const std::string& charMapFile,
int itemWidth,
int itemHeight,
int startCharMap)
@ -56,8 +56,8 @@ LabelAtlas* LabelAtlas::create(std::string_view string,
return nullptr;
}
bool LabelAtlas::initWithString(std::string_view string,
std::string_view charMapFile,
bool LabelAtlas::initWithString(const std::string& string,
const std::string& charMapFile,
int itemWidth,
int itemHeight,
int startCharMap)
@ -66,7 +66,7 @@ bool LabelAtlas::initWithString(std::string_view string,
return initWithString(string, texture, itemWidth, itemHeight, startCharMap);
}
bool LabelAtlas::initWithString(std::string_view string,
bool LabelAtlas::initWithString(const std::string& string,
Texture2D* texture,
int itemWidth,
int itemHeight,
@ -81,7 +81,7 @@ bool LabelAtlas::initWithString(std::string_view string,
return false;
}
LabelAtlas* LabelAtlas::create(std::string_view string, std::string_view fntFile)
LabelAtlas* LabelAtlas::create(const std::string& string, const std::string& fntFile)
{
LabelAtlas* ret = new LabelAtlas();
@ -97,7 +97,7 @@ LabelAtlas* LabelAtlas::create(std::string_view string, std::string_view fntFile
return ret;
}
LabelAtlas* LabelAtlas::create(std::string_view string,
LabelAtlas* LabelAtlas::create(const std::string& string,
Texture2D* texture,
int itemWidth,
int itemHeight,
@ -117,7 +117,7 @@ LabelAtlas* LabelAtlas::create(std::string_view string,
return ret;
}
bool LabelAtlas::initWithString(std::string_view theString, std::string_view fntFile)
bool LabelAtlas::initWithString(const std::string& theString, const std::string& fntFile)
{
std::string pathStr = FileUtils::getInstance()->fullPathForFilename(fntFile);
std::string relPathStr = pathStr.substr(0, pathStr.find_last_of('/')) + "/";
@ -128,8 +128,8 @@ bool LabelAtlas::initWithString(std::string_view theString, std::string_view fnt
std::string textureFilename = relPathStr + dict["textureFilename"].asString();
unsigned int width = static_cast<unsigned int>(dict["itemWidth"].asInt() / CC_CONTENT_SCALE_FACTOR());
unsigned int height = static_cast<unsigned int>(dict["itemHeight"].asInt() / CC_CONTENT_SCALE_FACTOR());
unsigned int width = dict["itemWidth"].asInt() / CC_CONTENT_SCALE_FACTOR();
unsigned int height = dict["itemHeight"].asInt() / CC_CONTENT_SCALE_FACTOR();
unsigned int startChar = dict["firstChar"].asInt();
this->initWithString(theString, textureFilename, width, height, startChar);
@ -156,8 +156,8 @@ void LabelAtlas::updateAtlasValues()
float itemHeightInPixels = _itemHeight * CC_CONTENT_SCALE_FACTOR();
if (_ignoreContentScaleFactor)
{
itemWidthInPixels = static_cast<float>(_itemWidth);
itemHeightInPixels = static_cast<float>(_itemHeight);
itemWidthInPixels = _itemWidth;
itemHeightInPixels = _itemHeight;
}
CCASSERT(n <= _textureAtlas->getCapacity(), "updateAtlasValues: Invalid String length");
@ -239,7 +239,7 @@ void LabelAtlas::setString(std::string_view label)
_quadsToDraw = len;
}
std::string_view LabelAtlas::getString() const
const std::string& LabelAtlas::getString() const
{
return _string;
}

View File

@ -58,8 +58,8 @@ class CC_DLL LabelAtlas : public AtlasNode, public LabelProtocol
public:
/** Creates the LabelAtlas with a string, a char map file(the atlas), the width and height of each element and the
* starting char of the atlas. */
static LabelAtlas* create(std::string_view string,
std::string_view charMapFile,
static LabelAtlas* create(const std::string& string,
const std::string& charMapFile,
int itemWidth,
int itemHeight,
int startCharMap);
@ -68,13 +68,13 @@ public:
* Creates the LabelAtlas with a string and a configuration file.
* @since v2.0
*/
static LabelAtlas* create(std::string_view string, std::string_view fntFile);
static LabelAtlas* create(const std::string& string, const std::string& fntFile);
/**
* Creates the LabelAtlas with a string, a texture, the width and height of each element and the starting char of
* the atlas.
*/
static LabelAtlas* create(std::string_view string,
static LabelAtlas* create(const std::string& string,
Texture2D* texture,
int itemWidth,
int itemHeight,
@ -82,8 +82,8 @@ public:
/** Initializes the LabelAtlas with a string, a char map file(the atlas), the width and height of each element and
* the starting char of the atlas. */
bool initWithString(std::string_view string,
std::string_view charMapFile,
bool initWithString(const std::string& string,
const std::string& charMapFile,
int itemWidth,
int itemHeight,
int startCharMap);
@ -92,14 +92,14 @@ public:
* Initializes the LabelAtlas with a string and a configuration file.
* @since v2.0
*/
bool initWithString(std::string_view string, std::string_view fntFile);
bool initWithString(const std::string& string, const std::string& fntFile);
/** Initializes the LabelAtlas with a string, a texture, the width and height in points of each element and the
* starting char of the atlas */
bool initWithString(std::string_view string, Texture2D* texture, int itemWidth, int itemHeight, int startCharMap);
bool initWithString(const std::string& string, Texture2D* texture, int itemWidth, int itemHeight, int startCharMap);
virtual void setString(std::string_view label) override;
virtual std::string_view getString() const override;
virtual const std::string& getString() const override;
virtual void updateAtlasValues() override;
/**

View File

@ -109,7 +109,7 @@ int Label::getFirstWordLen(const std::u32string& utf32Text, int startIndex, int
break;
}
nextLetterX += static_cast<int>(letterDef.xAdvance * _bmfontScale + _additionalKerning);
nextLetterX += letterDef.xAdvance * _bmfontScale + _additionalKerning;
len++;
}
@ -139,9 +139,9 @@ void Label::updateBMFontScale()
auto font = _fontAtlas->getFont();
if (_currentLabelType == LabelType::BMFONT)
{
FontFNT* bmFont = (FontFNT*)font;
auto originalFontSize = bmFont->getOriginalFontSize();
_bmfontScale = _bmFontSize * CC_CONTENT_SCALE_FACTOR() / originalFontSize;
FontFNT* bmFont = (FontFNT*)font;
float originalFontSize = bmFont->getOriginalFontSize();
_bmfontScale = _bmFontSize * CC_CONTENT_SCALE_FACTOR() / originalFontSize;
}
else
{
@ -242,7 +242,7 @@ bool Label::multilineTextWrap(const std::function<int(const std::u32string&, int
{
float newLetterWidth = 0.f;
if (_horizontalKernings && letterIndex < textLen - 1)
newLetterWidth = static_cast<float>(_horizontalKernings[letterIndex + 1]);
newLetterWidth = _horizontalKernings[letterIndex + 1];
newLetterWidth += letterDef.xAdvance * _bmfontScale + _additionalKerning;
nextLetterX += newLetterWidth;

View File

@ -175,7 +175,7 @@ void Menu::addChild(Node* child, int zOrder, int tag)
Layer::addChild(child, zOrder, tag);
}
void Menu::addChild(Node* child, int zOrder, std::string_view name)
void Menu::addChild(Node* child, int zOrder, const std::string& name)
{
CCASSERT(dynamic_cast<MenuItem*>(child) != nullptr, "Menu only supports MenuItem objects as children");
Layer::addChild(child, zOrder, name);

View File

@ -148,7 +148,7 @@ public:
virtual void addChild(Node* child) override;
virtual void addChild(Node* child, int zOrder) override;
virtual void addChild(Node* child, int zOrder, int tag) override;
virtual void addChild(Node* child, int zOrder, std::string_view name) override;
virtual void addChild(Node* child, int zOrder, const std::string& name) override;
virtual void onEnter() override;
virtual void onExit() override;

View File

@ -180,13 +180,13 @@ bool MenuItemLabel::initWithLabel(Node* label, const ccMenuCallback& callback)
MenuItemLabel::~MenuItemLabel() {}
void MenuItemLabel::setString(std::string_view label)
void MenuItemLabel::setString(const std::string& label)
{
dynamic_cast<LabelProtocol*>(_label)->setString(label);
this->setContentSize(_label->getContentSize());
}
std::string_view MenuItemLabel::getString() const
std::string MenuItemLabel::getString() const
{
auto label = dynamic_cast<LabelProtocol*>(_label);
return label->getString();
@ -259,8 +259,8 @@ void MenuItemLabel::setEnabled(bool enabled)
// CCMenuItemAtlasFont
//
MenuItemAtlasFont* MenuItemAtlasFont::create(std::string_view value,
std::string_view charMapFile,
MenuItemAtlasFont* MenuItemAtlasFont::create(const std::string& value,
const std::string& charMapFile,
int itemWidth,
int itemHeight,
char startCharMap)
@ -269,8 +269,8 @@ MenuItemAtlasFont* MenuItemAtlasFont::create(std::string_view value,
(const ccMenuCallback&)nullptr);
}
MenuItemAtlasFont* MenuItemAtlasFont::create(std::string_view value,
std::string_view charMapFile,
MenuItemAtlasFont* MenuItemAtlasFont::create(const std::string& value,
const std::string& charMapFile,
int itemWidth,
int itemHeight,
char startCharMap,
@ -282,8 +282,8 @@ MenuItemAtlasFont* MenuItemAtlasFont::create(std::string_view value,
return ret;
}
bool MenuItemAtlasFont::initWithString(std::string_view value,
std::string_view charMapFile,
bool MenuItemAtlasFont::initWithString(const std::string& value,
const std::string& charMapFile,
int itemWidth,
int itemHeight,
char startCharMap,
@ -312,7 +312,7 @@ int MenuItemFont::getFontSize()
return _globalFontSize;
}
void MenuItemFont::setFontName(std::string_view name)
void MenuItemFont::setFontName(const std::string& name)
{
if (_globalFontNameRelease)
{
@ -322,12 +322,12 @@ void MenuItemFont::setFontName(std::string_view name)
_globalFontNameRelease = true;
}
std::string_view MenuItemFont::getFontName()
const std::string& MenuItemFont::getFontName()
{
return _globalFontName;
}
MenuItemFont* MenuItemFont::create(std::string_view value, const ccMenuCallback& callback)
MenuItemFont* MenuItemFont::create(const std::string& value, const ccMenuCallback& callback)
{
MenuItemFont* ret = new MenuItemFont();
ret->initWithString(value, callback);
@ -335,7 +335,7 @@ MenuItemFont* MenuItemFont::create(std::string_view value, const ccMenuCallback&
return ret;
}
MenuItemFont* MenuItemFont::create(std::string_view value)
MenuItemFont* MenuItemFont::create(const std::string& value)
{
MenuItemFont* ret = new MenuItemFont();
ret->initWithString(value, (const ccMenuCallback&)nullptr);
@ -350,7 +350,7 @@ MenuItemFont::~MenuItemFont()
CCLOGINFO("In the destructor of MenuItemFont (%p).", this);
}
bool MenuItemFont::initWithString(std::string_view value, const ccMenuCallback& callback)
bool MenuItemFont::initWithString(const std::string& value, const ccMenuCallback& callback)
{
CCASSERT(!value.empty(), "Value length must be greater than 0");
@ -377,14 +377,14 @@ int MenuItemFont::getFontSizeObj() const
return _fontSize;
}
void MenuItemFont::setFontNameObj(std::string_view name)
void MenuItemFont::setFontNameObj(const std::string& name)
{
_fontName = name;
dynamic_cast<Label*>(_label)->setSystemFontName(_fontName);
this->setContentSize(dynamic_cast<Label*>(_label)->getContentSize());
}
std::string_view MenuItemFont::getFontNameObj() const
const std::string& MenuItemFont::getFontNameObj() const
{
return _fontName;
}
@ -600,21 +600,21 @@ bool MenuItemImage::init()
return initWithNormalImage("", "", "", (const ccMenuCallback&)nullptr);
}
MenuItemImage* MenuItemImage::create(std::string_view normalImage, std::string_view selectedImage)
MenuItemImage* MenuItemImage::create(const std::string& normalImage, const std::string& selectedImage)
{
return MenuItemImage::create(normalImage, selectedImage, "", (const ccMenuCallback&)nullptr);
}
MenuItemImage* MenuItemImage::create(std::string_view normalImage,
std::string_view selectedImage,
MenuItemImage* MenuItemImage::create(const std::string& normalImage,
const std::string& selectedImage,
const ccMenuCallback& callback)
{
return MenuItemImage::create(normalImage, selectedImage, "", callback);
}
MenuItemImage* MenuItemImage::create(std::string_view normalImage,
std::string_view selectedImage,
std::string_view disabledImage,
MenuItemImage* MenuItemImage::create(const std::string& normalImage,
const std::string& selectedImage,
const std::string& disabledImage,
const ccMenuCallback& callback)
{
MenuItemImage* ret = new MenuItemImage();
@ -627,9 +627,9 @@ MenuItemImage* MenuItemImage::create(std::string_view normalImage,
return nullptr;
}
MenuItemImage* MenuItemImage::create(std::string_view normalImage,
std::string_view selectedImage,
std::string_view disabledImage)
MenuItemImage* MenuItemImage::create(const std::string& normalImage,
const std::string& selectedImage,
const std::string& disabledImage)
{
MenuItemImage* ret = new MenuItemImage();
if (ret->initWithNormalImage(normalImage, selectedImage, disabledImage, (const ccMenuCallback&)nullptr))
@ -641,9 +641,9 @@ MenuItemImage* MenuItemImage::create(std::string_view normalImage,
return nullptr;
}
bool MenuItemImage::initWithNormalImage(std::string_view normalImage,
std::string_view selectedImage,
std::string_view disabledImage,
bool MenuItemImage::initWithNormalImage(const std::string& normalImage,
const std::string& selectedImage,
const std::string& disabledImage,
const ccMenuCallback& callback)
{
Node* normalSprite = nullptr;

View File

@ -137,10 +137,10 @@ public:
static MenuItemLabel* create(Node* label);
/** Sets a new string to the inner label. */
void setString(std::string_view label);
void setString(const std::string& label);
/** Get the inner string of the inner label. */
std::string_view getString() const;
std::string getString() const;
/** Gets the color that will be used when the item is disabled. */
const Color3B& getDisabledColor() const { return _disabledColor; }
@ -196,14 +196,14 @@ class CC_DLL MenuItemAtlasFont : public MenuItemLabel
{
public:
/** Creates a menu item from a string and atlas with a target/selector. */
static MenuItemAtlasFont* create(std::string_view value,
std::string_view charMapFile,
static MenuItemAtlasFont* create(const std::string& value,
const std::string& charMapFile,
int itemWidth,
int itemHeight,
char startCharMap);
/** Creates a menu item from a string and atlas. Use it with MenuItemToggle. */
static MenuItemAtlasFont* create(std::string_view value,
std::string_view charMapFile,
static MenuItemAtlasFont* create(const std::string& value,
const std::string& charMapFile,
int itemWidth,
int itemHeight,
char startCharMap,
@ -222,8 +222,8 @@ public:
virtual ~MenuItemAtlasFont() {}
/** Initializes a menu item from a string and atlas with a target/selector. */
bool initWithString(std::string_view value,
std::string_view charMapFile,
bool initWithString(const std::string& value,
const std::string& charMapFile,
int itemWidth,
int itemHeight,
char startCharMap,
@ -240,18 +240,18 @@ class CC_DLL MenuItemFont : public MenuItemLabel
{
public:
/** Creates a menu item from a string without target/selector. To be used with MenuItemToggle. */
static MenuItemFont* create(std::string_view value = "");
static MenuItemFont* create(const std::string& value = "");
/** Creates a menu item from a string with a target/selector. */
static MenuItemFont* create(std::string_view value, const ccMenuCallback& callback);
static MenuItemFont* create(const std::string& value, const ccMenuCallback& callback);
/** Set default font size. */
static void setFontSize(int size);
/** Get default font size. */
static int getFontSize();
/** Set the default font name. */
static void setFontName(std::string_view name);
static void setFontName(const std::string& name);
/** Get the default font name. */
static std::string_view getFontName();
static const std::string& getFontName();
/** Set font size.
* c++ can not overload static and non-static member functions with the same parameter types.
@ -274,13 +274,13 @@ public:
* @js setFontName
* @js NA
*/
void setFontNameObj(std::string_view name);
void setFontNameObj(const std::string& name);
/** Returns the name of the Font.
* @js getFontNameObj
* @js NA
*/
std::string_view getFontNameObj() const;
const std::string& getFontNameObj() const;
CC_CONSTRUCTOR_ACCESS :
/**
@ -294,7 +294,7 @@ public:
virtual ~MenuItemFont();
/** Initializes a menu item from a string with a target/selector. */
bool initWithString(std::string_view value, const ccMenuCallback& callback);
bool initWithString(const std::string& value, const ccMenuCallback& callback);
protected:
int _fontSize;
@ -392,19 +392,19 @@ public:
/** Creates an MenuItemImage. */
static MenuItemImage* create();
/** Creates a menu item with a normal and selected image.*/
static MenuItemImage* create(std::string_view normalImage, std::string_view selectedImage);
static MenuItemImage* create(const std::string& normalImage, const std::string& selectedImage);
/** Creates a menu item with a normal,selected and disabled image.*/
static MenuItemImage* create(std::string_view normalImage,
std::string_view selectedImage,
std::string_view disabledImage);
static MenuItemImage* create(const std::string& normalImage,
const std::string& selectedImage,
const std::string& disabledImage);
/** Creates a menu item with a normal and selected image with a callable object. */
static MenuItemImage* create(std::string_view normalImage,
std::string_view selectedImage,
static MenuItemImage* create(const std::string& normalImage,
const std::string& selectedImage,
const ccMenuCallback& callback);
/** Creates a menu item with a normal,selected and disabled image with a callable object. */
static MenuItemImage* create(std::string_view normalImage,
std::string_view selectedImage,
std::string_view disabledImage,
static MenuItemImage* create(const std::string& normalImage,
const std::string& selectedImage,
const std::string& disabledImage,
const ccMenuCallback& callback);
/** Sets the sprite frame for the normal image. */
@ -429,9 +429,9 @@ public:
bool init();
/** Initializes a menu item with a normal, selected and disabled image with a callable object. */
bool initWithNormalImage(std::string_view normalImage,
std::string_view selectedImage,
std::string_view disabledImage,
bool initWithNormalImage(const std::string& normalImage,
const std::string& selectedImage,
const std::string& disabledImage,
const ccMenuCallback& callback);
private:

View File

@ -52,7 +52,11 @@ MotionStreak::~MotionStreak()
CC_SAFE_FREE(_texCoords);
}
MotionStreak* MotionStreak::create(float fade, float minSeg, float stroke, const Color3B& color, std::string_view path)
MotionStreak* MotionStreak::create(float fade,
float minSeg,
float stroke,
const Color3B& color,
const std::string& path)
{
MotionStreak* ret = new MotionStreak();
if (ret->initWithFade(fade, minSeg, stroke, color, path))
@ -78,7 +82,7 @@ MotionStreak* MotionStreak::create(float fade, float minSeg, float stroke, const
return nullptr;
}
bool MotionStreak::initWithFade(float fade, float minSeg, float stroke, const Color3B& color, std::string_view path)
bool MotionStreak::initWithFade(float fade, float minSeg, float stroke, const Color3B& color, const std::string& path)
{
CCASSERT(!path.empty(), "Invalid filename");

View File

@ -59,7 +59,7 @@ public:
float minSeg,
float strokeWidth,
const Color3B& strokeColor,
std::string_view imagePath);
const std::string& imagePath);
/** Creates and initializes a motion streak with fade in seconds, minimum segments, stroke's width, color, texture.
*
* @param timeToFade The fade time, in seconds.
@ -163,7 +163,7 @@ public:
/** initializes a motion streak with fade in seconds, minimum segments, stroke's width, color and texture filename
*/
bool initWithFade(float fade, float minSeg, float stroke, const Color3B& color, std::string_view path);
bool initWithFade(float fade, float minSeg, float stroke, const Color3B& color, const std::string& path);
/** initializes a motion streak with fade in seconds, minimum segments, stroke's width, color and texture */
bool initWithFade(float fade, float minSeg, float stroke, const Color3B& color, Texture2D* texture);

View File

@ -56,7 +56,7 @@ THE SOFTWARE.
/*
* 4.5x faster than std::hash in release mode
*/
#define CC_HASH_NODE_NAME(name) (!name.empty() ? XXH3_64bits(name.data(), name.length()) : 0)
#define CC_HASH_NODE_NAME(name) (!name.empty() ? XXH3_64bits(name.c_str(), name.length()) : 0)
NS_CC_BEGIN
@ -695,12 +695,12 @@ void Node::setTag(int tag)
_tag = tag;
}
std::string_view Node::getName() const
const std::string& Node::getName() const
{
return _name;
}
void Node::setName(std::string_view name)
void Node::setName(const std::string& name)
{
updateParentChildrenIndexer(name);
_name = name;
@ -717,7 +717,7 @@ void Node::updateParentChildrenIndexer(int tag)
}
}
void Node::updateParentChildrenIndexer(std::string_view name)
void Node::updateParentChildrenIndexer(const std::string& name)
{
uint64_t newHash = CC_HASH_NODE_NAME(name);
auto parentChildrenIndexer = getParentChildrenIndexer();
@ -817,7 +817,7 @@ Node* Node::getChildByTag(int tag) const
return nullptr;
}
Node* Node::getChildByName(std::string_view name) const
Node* Node::getChildByName(const std::string& name) const
{
// CCASSERT(!name.empty(), "Invalid name");
auto hash = CC_HASH_NODE_NAME(name);
@ -837,7 +837,7 @@ Node* Node::getChildByName(std::string_view name) const
return nullptr;
}
void Node::enumerateChildren(std::string_view name, std::function<bool(Node*)> callback) const
void Node::enumerateChildren(const std::string& name, std::function<bool(Node*)> callback) const
{
CCASSERT(!name.empty(), "Invalid name");
CCASSERT(callback != nullptr, "Invalid callback function");
@ -865,7 +865,7 @@ void Node::enumerateChildren(std::string_view name, std::function<bool(Node*)> c
}
// Remove '//', '/..' if exist
auto newName = name.substr(subStrStartPos, subStrlength);
std::string newName = name.substr(subStrStartPos, subStrlength);
const Node* target = this;
@ -886,15 +886,15 @@ void Node::enumerateChildren(std::string_view name, std::function<bool(Node*)> c
else
{
// name is xxx
target->doEnumerate(std::string{newName}, callback);
target->doEnumerate(newName, callback);
}
}
bool Node::doEnumerateRecursive(const Node* node, std::string_view name, std::function<bool(Node*)> callback) const
bool Node::doEnumerateRecursive(const Node* node, const std::string& name, std::function<bool(Node*)> callback) const
{
bool ret = false;
if (node->doEnumerate(std::string{name}, callback))
if (node->doEnumerate(name, callback))
{
// search itself
ret = true;
@ -966,7 +966,7 @@ void Node::addChild(Node* child, int localZOrder, int tag)
addChildHelper(child, localZOrder, tag, "", true);
}
void Node::addChild(Node* child, int localZOrder, std::string_view name)
void Node::addChild(Node* child, int localZOrder, const std::string& name)
{
CCASSERT(child != nullptr, "Argument must be non-nil");
CCASSERT(child->_parent == nullptr, "child already added. It can't be added again");
@ -974,7 +974,7 @@ void Node::addChild(Node* child, int localZOrder, std::string_view name)
addChildHelper(child, localZOrder, INVALID_TAG, name, false);
}
void Node::addChildHelper(Node* child, int localZOrder, int tag, std::string_view name, bool setTag)
void Node::addChildHelper(Node* child, int localZOrder, int tag, const std::string& name, bool setTag)
{
auto assertNotSelfChild([this, child]() -> bool {
for (Node* parent(getParent()); parent != nullptr; parent = parent->getParent())
@ -1088,7 +1088,7 @@ void Node::removeChildByTag(int tag, bool cleanup /* = true */)
}
}
void Node::removeChildByName(std::string_view name, bool cleanup)
void Node::removeChildByName(const std::string& name, bool cleanup)
{
CCASSERT(!name.empty(), "Invalid name");
@ -1096,7 +1096,7 @@ void Node::removeChildByName(std::string_view name, bool cleanup)
if (child == nullptr)
{
CCLOG("cocos2d: removeChildByName(name = %s): child not found!", name.data());
CCLOG("cocos2d: removeChildByName(name = %s): child not found!", name.c_str());
}
else
{
@ -1490,7 +1490,7 @@ bool Node::isScheduled(SEL_SCHEDULE selector) const
return _scheduler->isScheduled(selector, this);
}
bool Node::isScheduled(std::string_view key) const
bool Node::isScheduled(const std::string& key) const
{
return _scheduler->isScheduled(key, this);
}
@ -1547,12 +1547,12 @@ void Node::schedule(SEL_SCHEDULE selector, float interval, unsigned int repeat,
_scheduler->schedule(selector, this, interval, repeat, delay, !_running);
}
void Node::schedule(const std::function<void(float)>& callback, std::string_view key)
void Node::schedule(const std::function<void(float)>& callback, const std::string& key)
{
_scheduler->schedule(callback, this, 0, !_running, key);
}
void Node::schedule(const std::function<void(float)>& callback, float interval, std::string_view key)
void Node::schedule(const std::function<void(float)>& callback, float interval, const std::string& key)
{
_scheduler->schedule(callback, this, interval, !_running, key);
}
@ -1561,7 +1561,7 @@ void Node::schedule(const std::function<void(float)>& callback,
float interval,
unsigned int repeat,
float delay,
std::string_view key)
const std::string& key)
{
_scheduler->schedule(callback, this, interval, repeat, delay, !_running, key);
}
@ -1571,7 +1571,7 @@ void Node::scheduleOnce(SEL_SCHEDULE selector, float delay)
this->schedule(selector, 0.0f, 0, delay);
}
void Node::scheduleOnce(const std::function<void(float)>& callback, float delay, std::string_view key)
void Node::scheduleOnce(const std::function<void(float)>& callback, float delay, const std::string& key)
{
_scheduler->schedule(callback, this, 0, 0, delay, !_running, key);
}
@ -1585,7 +1585,7 @@ void Node::unschedule(SEL_SCHEDULE selector)
_scheduler->unschedule(selector, this);
}
void Node::unschedule(std::string_view key)
void Node::unschedule(const std::string& key)
{
_scheduler->unschedule(key, this);
}
@ -1923,7 +1923,7 @@ void Node::updateTransform()
// MARK: components
Component* Node::getComponent(std::string_view name)
Component* Node::getComponent(const std::string& name)
{
if (_componentContainer)
return _componentContainer->get(name);
@ -1943,7 +1943,7 @@ bool Node::addComponent(Component* component)
return _componentContainer->add(component);
}
bool Node::removeComponent(std::string_view name)
bool Node::removeComponent(const std::string& name)
{
if (_componentContainer)
return _componentContainer->remove(name);

View File

@ -762,7 +762,7 @@ public:
* @param name A string to identify the node easily. Please refer to `setName(int)`.
*
*/
virtual void addChild(Node* child, int localZOrder, std::string_view name);
virtual void addChild(Node* child, int localZOrder, const std::string& name);
/**
* Gets a child from the container with its tag.
*
@ -796,7 +796,7 @@ public:
*
* @since v3.2
*/
virtual Node* getChildByName(std::string_view name) const;
virtual Node* getChildByName(const std::string& name) const;
/**
* Gets a child from the container with its name that can be cast to Type T.
*
@ -805,7 +805,7 @@ public:
* @return a Node with the given name that can be cast to Type T.
*/
template <typename T>
T getChildByName(std::string_view name) const
T getChildByName(const std::string& name) const
{
return static_cast<T>(getChildByName(name));
}
@ -835,7 +835,7 @@ public:
*
* @since v3.2
*/
virtual void enumerateChildren(std::string_view name, std::function<bool(Node* node)> callback) const;
virtual void enumerateChildren(const std::string& name, std::function<bool(Node* node)> callback) const;
/**
* Returns the array of the node's children.
*
@ -909,7 +909,7 @@ public:
* @param name A string that identifies a child node.
* @param cleanup True if all running actions and callbacks on the child node will be cleanup, false otherwise.
*/
virtual void removeChildByName(std::string_view name, bool cleanup = true);
virtual void removeChildByName(const std::string& name, bool cleanup = true);
/**
* Removes all children from the container with a cleanup.
*
@ -989,13 +989,13 @@ public:
*
* @since v3.2
*/
virtual std::string_view getName() const;
virtual const std::string& getName() const;
/** Changes the name that is used to identify the node easily.
* @param name A string that identifies the node.
*
* @since v3.2
*/
virtual void setName(std::string_view name);
virtual void setName(const std::string& name);
/**
* Returns a custom user data pointer.
@ -1306,7 +1306,7 @@ public:
* @js NA
* @lua NA
*/
bool isScheduled(std::string_view key) const;
bool isScheduled(const std::string& key) const;
/**
* Schedules the "update" method.
@ -1385,7 +1385,7 @@ public:
* @param key The key of the lambda function. To be used if you want to unschedule it.
* @lua NA
*/
void scheduleOnce(const std::function<void(float)>& callback, float delay, std::string_view key);
void scheduleOnce(const std::function<void(float)>& callback, float delay, const std::string& key);
/**
* Schedules a custom selector, the scheduled selector will be ticked every frame.
@ -1403,7 +1403,7 @@ public:
* @param key The key of the lambda function. To be used if you want to unschedule it.
* @lua NA
*/
void schedule(const std::function<void(float)>& callback, std::string_view key);
void schedule(const std::function<void(float)>& callback, const std::string& key);
/**
* Schedules a lambda function. The scheduled lambda function will be called every "interval" seconds
@ -1413,7 +1413,7 @@ public:
* @param key The key of the lambda function. To be used if you want to unschedule it
* @lua NA
*/
void schedule(const std::function<void(float)>& callback, float interval, std::string_view key);
void schedule(const std::function<void(float)>& callback, float interval, const std::string& key);
/**
* Schedules a lambda function.
@ -1430,7 +1430,7 @@ public:
float interval,
unsigned int repeat,
float delay,
std::string_view key);
const std::string& key);
/**
* Unschedules a custom selector.
@ -1447,7 +1447,7 @@ public:
* @param key The key of the lambda function to be unscheduled.
* @lua NA
*/
void unschedule(std::string_view key);
void unschedule(const std::string& key);
/**
* Unschedule all scheduled selectors and lambda functions: custom selectors, and the 'update' selector and lambda
@ -1633,7 +1633,7 @@ public:
* @param name A given name of component.
* @return The Component by name.
*/
Component* getComponent(std::string_view name);
Component* getComponent(const std::string& name);
/**
* Adds a component.
@ -1649,7 +1649,7 @@ public:
* @param name A given name of component.
* @return True if removed success.
*/
virtual bool removeComponent(std::string_view name);
virtual bool removeComponent(const std::string& name);
/**
* Removes a component by its pointer.
@ -1854,7 +1854,7 @@ protected:
virtual void updateColor() {}
bool doEnumerate(std::string name, std::function<bool(Node*)> callback) const;
bool doEnumerateRecursive(const Node* node, std::string_view name, std::function<bool(Node*)> callback) const;
bool doEnumerateRecursive(const Node* node, const std::string& name, std::function<bool(Node*)> callback) const;
// check whether this camera mask is visible by the current visiting camera
bool isVisitableByVisitingCamera() const;
@ -1865,10 +1865,10 @@ protected:
void updateRotation3D();
void updateParentChildrenIndexer(int tag);
void updateParentChildrenIndexer(std::string_view name);
void updateParentChildrenIndexer(const std::string& name);
private:
void addChildHelper(Node* child, int localZOrder, int tag, std::string_view name, bool setTag);
void addChildHelper(Node* child, int localZOrder, int tag, const std::string& name, bool setTag);
NodeIndexerMap_t* getParentChildrenIndexer();

View File

@ -91,7 +91,7 @@ void ParallaxNode::addChild(Node* /*child*/, int /*zOrder*/, int /*tag*/)
CCASSERT(0, "ParallaxNode: use addChild:z:parallaxRatio:positionOffset instead");
}
void ParallaxNode::addChild(Node* /*child*/, int /*zOrder*/, std::string_view /*name*/)
void ParallaxNode::addChild(Node* /*child*/, int /*zOrder*/, const std::string& /*name*/)
{
CCASSERT(0, "ParallaxNode: use addChild:z:parallaxRatio:positionOffset instead");
}

View File

@ -83,7 +83,7 @@ public:
// Overrides
//
virtual void addChild(Node* child, int zOrder, int tag) override;
virtual void addChild(Node* child, int zOrder, std::string_view name) override;
virtual void addChild(Node* child, int zOrder, const std::string& name) override;
virtual void removeChild(Node* child, bool cleanup) override;
virtual void removeAllChildrenWithCleanup(bool cleanup) override;
virtual void visit(Renderer* renderer, const Mat4& parentTransform, uint32_t parentFlags) override;

View File

@ -108,7 +108,7 @@ ParticleBatchNode* ParticleBatchNode::createWithTexture(Texture2D* tex, int capa
* creation with File Image
*/
ParticleBatchNode* ParticleBatchNode::create(std::string_view imageFile, int capacity /* = kParticleDefaultCapacity*/)
ParticleBatchNode* ParticleBatchNode::create(const std::string& imageFile, int capacity /* = kParticleDefaultCapacity*/)
{
ParticleBatchNode* p = new ParticleBatchNode();
if (p->initWithFile(imageFile, capacity))
@ -140,7 +140,7 @@ bool ParticleBatchNode::initWithTexture(Texture2D* tex, int capacity)
/*
* init with FileImage
*/
bool ParticleBatchNode::initWithFile(std::string_view fileImage, int capacity)
bool ParticleBatchNode::initWithFile(const std::string& fileImage, int capacity)
{
Texture2D* tex = _director->getTextureCache()->addImage(fileImage);
return initWithTexture(tex, capacity);
@ -193,7 +193,7 @@ void ParticleBatchNode::addChild(Node* aChild, int zOrder, int tag)
addChildByTagOrName(child, zOrder, tag, "", true);
}
void ParticleBatchNode::addChild(Node* aChild, int zOrder, std::string_view name)
void ParticleBatchNode::addChild(Node* aChild, int zOrder, const std::string& name)
{
CCASSERT(aChild != nullptr, "Argument must be non-nullptr");
CCASSERT(dynamic_cast<ParticleSystem*>(aChild) != nullptr,
@ -208,7 +208,7 @@ void ParticleBatchNode::addChild(Node* aChild, int zOrder, std::string_view name
void ParticleBatchNode::addChildByTagOrName(ParticleSystem* child,
int zOrder,
int tag,
std::string_view name,
const std::string& name,
bool setTag)
{
// If this is the 1st children, then copy blending function
@ -251,7 +251,7 @@ void ParticleBatchNode::addChildByTagOrName(ParticleSystem* child,
// faster
// FIXME: or possibly using vertexZ for reordering, that would be fastest
// this helper is almost equivalent to Node's addChild, but doesn't make use of the lazy sorting
int ParticleBatchNode::addChildHelper(ParticleSystem* child, int z, int aTag, std::string_view name, bool setTag)
int ParticleBatchNode::addChildHelper(ParticleSystem* child, int z, int aTag, const std::string& name, bool setTag)
{
CCASSERT(child != nullptr, "Argument must be non-nil");
CCASSERT(child->getParent() == nullptr, "child already added. It can't be added again");

View File

@ -87,7 +87,7 @@ public:
* @param capacity A capacity of particles.
* @return An autoreleased ParticleBatchNode object.
*/
static ParticleBatchNode* create(std::string_view fileImage, int capacity = kParticleDefaultCapacity);
static ParticleBatchNode* create(const std::string& fileImage, int capacity = kParticleDefaultCapacity);
/** Inserts a child into the ParticleBatchNode.
*
@ -127,7 +127,7 @@ public:
using Node::addChild;
virtual void addChild(Node* child, int zOrder, int tag) override;
virtual void addChild(Node* child, int zOrder, std::string_view name) override;
virtual void addChild(Node* child, int zOrder, const std::string& name) override;
virtual void removeChild(Node* child, bool cleanup) override;
virtual void reorderChild(Node* child, int zOrder) override;
virtual void draw(Renderer* renderer, const Mat4& transform, uint32_t flags) override;
@ -163,15 +163,15 @@ public:
/** initializes the particle system with the name of a file on disk (for a list of supported formats look at the
* Texture2D class), a capacity of particles */
bool initWithFile(std::string_view fileImage, int capacity);
bool initWithFile(const std::string& fileImage, int capacity);
private:
void updateAllAtlasIndexes();
void increaseAtlasCapacityTo(ssize_t quantity);
int searchNewPositionInChildrenForZ(int z);
void getCurrentIndex(int* oldIndex, int* newIndex, Node* child, int z);
int addChildHelper(ParticleSystem* child, int z, int aTag, std::string_view name, bool setTag);
void addChildByTagOrName(ParticleSystem* child, int z, int tag, std::string_view name, bool setTag);
int addChildHelper(ParticleSystem* child, int z, int aTag, const std::string& name, bool setTag);
void addChildByTagOrName(ParticleSystem* child, int z, int tag, const std::string& name, bool setTag);
void updateBlendFunc();
void updateProgramStateTexture();

View File

@ -191,6 +191,11 @@ void ParticleData::release()
Vector<ParticleSystem*> ParticleSystem::__allInstances;
float ParticleSystem::__totalParticleCountFactor = 1.0f;
inline static const cocos2d::Value& optValue(const ValueMap& dictionary, const std::string& key)
{
return dictionary.find(key) != dictionary.cend() ? dictionary.at(key) : cocos2d::Value::Null;
}
ParticleSystem::ParticleSystem()
: _isBlendAdditive(false)
, _isAutoRemoveOnFinish(false)
@ -245,7 +250,7 @@ ParticleSystem::ParticleSystem()
}
// implementation ParticleSystem
ParticleSystem* ParticleSystem::create(std::string_view plistFile)
ParticleSystem* ParticleSystem::create(const std::string& plistFile)
{
ParticleSystem* ret = new ParticleSystem();
if (ret->initWithFile(plistFile))
@ -285,7 +290,7 @@ bool ParticleSystem::init()
return initWithTotalParticles(150);
}
bool ParticleSystem::initWithFile(std::string_view plistFile)
bool ParticleSystem::initWithFile(const std::string& plistFile)
{
bool ret = false;
_plistFile = FileUtils::getInstance()->fullPathForFilename(plistFile);
@ -294,7 +299,7 @@ bool ParticleSystem::initWithFile(std::string_view plistFile)
CCASSERT(!dict.empty(), "Particles: file not found");
// FIXME: compute path from a path, should define a function somewhere to do it
auto listFilePath = plistFile;
string listFilePath = plistFile;
if (listFilePath.find('/') != string::npos)
{
listFilePath = listFilePath.substr(0, listFilePath.rfind('/') + 1);
@ -313,7 +318,7 @@ bool ParticleSystem::initWithDictionary(const ValueMap& dictionary)
return initWithDictionary(dictionary, "");
}
bool ParticleSystem::initWithDictionary(const ValueMap& dictionary, std::string_view dirname)
bool ParticleSystem::initWithDictionary(const ValueMap& dictionary, const std::string& dirname)
{
bool ret = false;
unsigned char* buffer = nullptr;
@ -482,12 +487,12 @@ bool ParticleSystem::initWithDictionary(const ValueMap& dictionary, std::string_
if (!dirname.empty() && textureDir != dirname)
{
textureName = textureName.substr(rPos + 1);
textureName.insert(0, dirname); // textureName = dirname + textureName;
textureName = dirname + textureName;
}
}
else if (!dirname.empty() && !textureName.empty())
{
textureName.insert(0, dirname); // textureName = dirname + textureName;
textureName = dirname + textureName;
}
Texture2D* tex = nullptr;

View File

@ -237,7 +237,7 @@ public:
* @param plistFile Particle plist file name.
* @return An autoreleased ParticleSystem object.
*/
static ParticleSystem* create(std::string_view plistFile);
static ParticleSystem* create(const std::string& plistFile);
/** Create a system with a fixed number of particles.
*
@ -761,7 +761,7 @@ public:
*/
virtual const BlendFunc& getBlendFunc() const override;
std::string_view getResourceFile() const { return _plistFile; }
const std::string& getResourceFile() const { return _plistFile; }
/// @{
/// @name implement Playable Protocol
@ -793,7 +793,7 @@ public:
http://particledesigner.71squared.com/
@since v0.99.3
*/
bool initWithFile(std::string_view plistFile);
bool initWithFile(const std::string& plistFile);
/** initializes a QuadParticleSystem from a Dictionary.
@since v0.99.3
@ -803,7 +803,7 @@ public:
/** initializes a particle system from a NSDictionary and the path from where to load the png
@since v2.1
*/
bool initWithDictionary(const ValueMap& dictionary, std::string_view dirname);
bool initWithDictionary(const ValueMap& dictionary, const std::string& dirname);
//! Initializes a system with a fixed number of particles
virtual bool initWithTotalParticles(int numberOfParticles);

View File

@ -91,7 +91,7 @@ ParticleSystemQuad::~ParticleSystemQuad()
// implementation ParticleSystemQuad
ParticleSystemQuad* ParticleSystemQuad::create(std::string_view filename)
ParticleSystemQuad* ParticleSystemQuad::create(const std::string& filename)
{
ParticleSystemQuad* ret = new ParticleSystemQuad();
if (ret->initWithFile(filename))

View File

@ -75,7 +75,7 @@ public:
* @param filename Particle plist file name.
* @return An autoreleased ParticleSystemQuad object.
*/
static ParticleSystemQuad* create(std::string_view filename);
static ParticleSystemQuad* create(const std::string& filename);
/** Creates a Particle Emitter with a dictionary.
*
* @param dictionary Particle dictionary.

View File

@ -18,7 +18,7 @@ using namespace std;
NS_CC_BEGIN
void PlistSpriteSheetLoader::load(std::string_view filePath, SpriteFrameCache& cache)
void PlistSpriteSheetLoader::load(const std::string& filePath, SpriteFrameCache& cache)
{
CCASSERT(!filePath.empty(), "plist filename should not be nullptr");
@ -26,7 +26,7 @@ void PlistSpriteSheetLoader::load(std::string_view filePath, SpriteFrameCache& c
if (fullPath.empty())
{
// return if plist file doesn't exist
CCLOG("cocos2d: SpriteFrameCache: can not find %s", filePath.data());
CCLOG("cocos2d: SpriteFrameCache: can not find %s", filePath.c_str());
return;
}
@ -66,7 +66,7 @@ void PlistSpriteSheetLoader::load(std::string_view filePath, SpriteFrameCache& c
addSpriteFramesWithDictionary(dict, texturePath, filePath, cache);
}
void PlistSpriteSheetLoader::load(std::string_view filePath, Texture2D* texture, SpriteFrameCache& cache)
void PlistSpriteSheetLoader::load(const std::string& filePath, Texture2D* texture, SpriteFrameCache& cache)
{
const auto fullPath = FileUtils::getInstance()->fullPathForFilename(filePath);
auto dict = FileUtils::getInstance()->getValueMapFromFile(fullPath);
@ -74,7 +74,9 @@ void PlistSpriteSheetLoader::load(std::string_view filePath, Texture2D* texture,
addSpriteFramesWithDictionary(dict, texture, filePath, cache);
}
void PlistSpriteSheetLoader::load(std::string_view filePath, std::string_view textureFileName, SpriteFrameCache& cache)
void PlistSpriteSheetLoader::load(const std::string& filePath,
const std::string& textureFileName,
SpriteFrameCache& cache)
{
CCASSERT(!textureFileName.empty(), "texture name should not be null");
const auto fullPath = FileUtils::getInstance()->fullPathForFilename(filePath);
@ -96,7 +98,7 @@ void PlistSpriteSheetLoader::load(const Data& content, Texture2D* texture, Sprit
addSpriteFramesWithDictionary(dict, texture, "by#addSpriteFramesWithFileContent()", cache);
}
void PlistSpriteSheetLoader::reload(std::string_view filePath, SpriteFrameCache& cache)
void PlistSpriteSheetLoader::reload(const std::string& filePath, SpriteFrameCache& cache)
{
const auto fullPath = FileUtils::getInstance()->fullPathForFilename(filePath);
auto dict = FileUtils::getInstance()->getValueMapFromFile(fullPath);
@ -149,7 +151,7 @@ void PlistSpriteSheetLoader::reload(std::string_view filePath, SpriteFrameCache&
void PlistSpriteSheetLoader::addSpriteFramesWithDictionary(ValueMap& dictionary,
Texture2D* texture,
std::string_view plist,
const std::string& plist,
SpriteFrameCache& cache)
{
/*
@ -176,15 +178,15 @@ void PlistSpriteSheetLoader::addSpriteFramesWithDictionary(ValueMap& dictionary,
Vec2 textureSize;
// get the format
auto metaItr = dictionary.find("metadata"sv);
auto metaItr = dictionary.find("metadata");
if (metaItr != dictionary.end())
{
auto& metadataDict = metaItr->second.asValueMap();
format = optValue(metadataDict, "format"sv).asInt();
format = metadataDict["format"].asInt();
if (metadataDict.find("size"sv) != metadataDict.end())
if (metadataDict.find("size") != metadataDict.end())
{
textureSize = SizeFromString(optValue(metadataDict, "size"sv).asString());
textureSize = SizeFromString(metadataDict["size"].asString());
}
}
@ -208,14 +210,14 @@ void PlistSpriteSheetLoader::addSpriteFramesWithDictionary(ValueMap& dictionary,
if (format == 0)
{
auto x = optValue(frameDict, "x"sv).asFloat();
auto y = optValue(frameDict, "y"sv).asFloat();
auto w = optValue(frameDict, "width"sv).asFloat();
auto h = optValue(frameDict, "height"sv).asFloat();
auto ox = optValue(frameDict, "offsetX"sv).asFloat();
auto oy = optValue(frameDict, "offsetY"sv).asFloat();
auto ow = optValue(frameDict, "originalWidth"sv).asInt();
auto oh = optValue(frameDict, "originalHeight"sv).asInt();
auto x = frameDict["x"].asFloat();
auto y = frameDict["y"].asFloat();
auto w = frameDict["width"].asFloat();
auto h = frameDict["height"].asFloat();
auto ox = frameDict["offsetX"].asFloat();
auto oy = frameDict["offsetY"].asFloat();
auto ow = frameDict["originalWidth"].asInt();
auto oh = frameDict["originalHeight"].asInt();
// check ow/oh
if (!ow || !oh)
{
@ -232,17 +234,17 @@ void PlistSpriteSheetLoader::addSpriteFramesWithDictionary(ValueMap& dictionary,
}
else if (format == 1 || format == 2)
{
auto frame = RectFromString(optValue(frameDict, "frame"sv).asString());
auto frame = RectFromString(frameDict["frame"].asString());
auto rotated = false;
// rotation
if (format == 2)
{
rotated = optValue(frameDict, "rotated"sv).asBool();
rotated = frameDict["rotated"].asBool();
}
auto offset = PointFromString(optValue(frameDict, "offset"sv).asString());
auto sourceSize = SizeFromString(optValue(frameDict, "sourceSize"sv).asString());
auto offset = PointFromString(frameDict["offset"].asString());
auto sourceSize = SizeFromString(frameDict["sourceSize"].asString());
// create frame
spriteFrame = SpriteFrame::createWithTexture(texture, frame, rotated, offset, sourceSize);
@ -250,14 +252,14 @@ void PlistSpriteSheetLoader::addSpriteFramesWithDictionary(ValueMap& dictionary,
else if (format == 3)
{
// get values
auto spriteSize = SizeFromString(optValue(frameDict, "spriteSize"sv).asString());
auto spriteOffset = PointFromString(optValue(frameDict, "spriteOffset"sv).asString());
auto spriteSourceSize = SizeFromString(optValue(frameDict, "spriteSourceSize"sv).asString());
auto textureRect = RectFromString(optValue(frameDict, "textureRect"sv).asString());
auto textureRotated = optValue(frameDict, "textureRotated"sv).asBool();
auto spriteSize = SizeFromString(frameDict["spriteSize"].asString());
auto spriteOffset = PointFromString(frameDict["spriteOffset"].asString());
auto spriteSourceSize = SizeFromString(frameDict["spriteSourceSize"].asString());
auto textureRect = RectFromString(frameDict["textureRect"].asString());
auto textureRotated = frameDict["textureRotated"].asBool();
// get aliases
auto& aliases = optValue(frameDict, "aliases"sv).asValueVector();
auto& aliases = frameDict["aliases"].asValueVector();
for (const auto& value : aliases)
{
@ -280,9 +282,9 @@ void PlistSpriteSheetLoader::addSpriteFramesWithDictionary(ValueMap& dictionary,
if (frameDict.find("vertices") != frameDict.end())
{
using cocos2d::utils::parseIntegerList;
auto vertices = parseIntegerList(optValue(frameDict, "vertices"sv).asString());
auto verticesUV = parseIntegerList(optValue(frameDict, "verticesUV"sv).asString());
auto indices = parseIntegerList(optValue(frameDict, "triangles"sv).asString());
auto vertices = parseIntegerList(frameDict["vertices"].asString());
auto verticesUV = parseIntegerList(frameDict["verticesUV"].asString());
auto indices = parseIntegerList(frameDict["triangles"].asString());
PolygonInfo info;
initializePolygonInfo(textureSize, spriteSourceSize, vertices, verticesUV, indices, info);
@ -290,7 +292,7 @@ void PlistSpriteSheetLoader::addSpriteFramesWithDictionary(ValueMap& dictionary,
}
if (frameDict.find("anchor") != frameDict.end())
{
spriteFrame->setAnchorPoint(PointFromString(optValue(frameDict, "anchor"sv).asString()));
spriteFrame->setAnchorPoint(PointFromString(frameDict["anchor"].asString()));
}
}
@ -321,8 +323,8 @@ void PlistSpriteSheetLoader::addSpriteFramesWithDictionary(ValueMap& dictionary,
}
void PlistSpriteSheetLoader::addSpriteFramesWithDictionary(ValueMap& dict,
std::string_view texturePath,
std::string_view plist,
const std::string& texturePath,
const std::string& plist,
SpriteFrameCache& cache)
{
std::string pixelFormatName;
@ -376,7 +378,7 @@ void PlistSpriteSheetLoader::addSpriteFramesWithDictionary(ValueMap& dict,
void PlistSpriteSheetLoader::reloadSpriteFramesWithDictionary(ValueMap& dict,
Texture2D* texture,
std::string_view plist,
const std::string& plist,
SpriteFrameCache& cache)
{
auto& framesDict = dict["frames"].asValueMap();
@ -399,8 +401,8 @@ void PlistSpriteSheetLoader::reloadSpriteFramesWithDictionary(ValueMap& dict,
for (auto& iter : framesDict)
{
const ValueMap& frameDict = iter.second.asValueMap();
std::string_view spriteFrameName = iter.first;
ValueMap& frameDict = iter.second.asValueMap();
std::string spriteFrameName = iter.first;
cache.eraseFrame(spriteFrameName);
@ -409,14 +411,14 @@ void PlistSpriteSheetLoader::reloadSpriteFramesWithDictionary(ValueMap& dict,
if (format == 0)
{
const auto x = optValue(frameDict, "x"sv).asFloat();
const auto y = optValue(frameDict, "y"sv).asFloat();
const auto w = optValue(frameDict, "width"sv).asFloat();
const auto h = optValue(frameDict, "height"sv).asFloat();
const auto ox = optValue(frameDict, "offsetX"sv).asFloat();
const auto oy = optValue(frameDict, "offsetY"sv).asFloat();
auto ow = optValue(frameDict, "originalWidth"sv).asInt();
auto oh = optValue(frameDict, "originalHeight"sv).asInt();
const auto x = frameDict["x"].asFloat();
const auto y = frameDict["y"].asFloat();
const auto w = frameDict["width"].asFloat();
const auto h = frameDict["height"].asFloat();
const auto ox = frameDict["offsetX"].asFloat();
const auto oy = frameDict["offsetY"].asFloat();
auto ow = frameDict["originalWidth"].asInt();
auto oh = frameDict["originalHeight"].asInt();
// check ow/oh
if (!ow || !oh)
{
@ -433,17 +435,17 @@ void PlistSpriteSheetLoader::reloadSpriteFramesWithDictionary(ValueMap& dict,
}
else if (format == 1 || format == 2)
{
auto frame = RectFromString(optValue(frameDict, "frame"sv).asString());
auto frame = RectFromString(frameDict["frame"].asString());
auto rotated = false;
// rotation
if (format == 2)
{
rotated = optValue(frameDict, "rotated"sv).asBool();
rotated = frameDict["rotated"].asBool();
}
auto offset = PointFromString(optValue(frameDict, "offset"sv).asString());
auto sourceSize = SizeFromString(optValue(frameDict, "sourceSize"sv).asString());
auto offset = PointFromString(frameDict["offset"].asString());
auto sourceSize = SizeFromString(frameDict["sourceSize"].asString());
// create frame
spriteFrame = SpriteFrame::createWithTexture(texture, frame, rotated, offset, sourceSize);
@ -451,14 +453,14 @@ void PlistSpriteSheetLoader::reloadSpriteFramesWithDictionary(ValueMap& dict,
else if (format == 3)
{
// get values
const auto spriteSize = SizeFromString(optValue(frameDict, "spriteSize"sv).asString());
auto spriteOffset = PointFromString(optValue(frameDict, "spriteOffset"sv).asString());
auto spriteSourceSize = SizeFromString(optValue(frameDict, "spriteSourceSize"sv).asString());
const auto textureRect = RectFromString(optValue(frameDict, "textureRect"sv).asString());
const auto textureRotated = optValue(frameDict, "textureRotated"sv).asBool();
const auto spriteSize = SizeFromString(frameDict["spriteSize"].asString());
auto spriteOffset = PointFromString(frameDict["spriteOffset"].asString());
auto spriteSourceSize = SizeFromString(frameDict["spriteSourceSize"].asString());
const auto textureRect = RectFromString(frameDict["textureRect"].asString());
const auto textureRotated = frameDict["textureRotated"].asBool();
// get aliases
const ValueVector& aliases = optValue(frameDict, "aliases"sv).asValueVector();
ValueVector& aliases = frameDict["aliases"].asValueVector();
for (const auto& value : aliases)
{

View File

@ -14,30 +14,30 @@ public:
static constexpr uint32_t FORMAT = SpriteSheetFormat::PLIST;
uint32_t getFormat() override { return FORMAT; }
void load(std::string_view filePath, SpriteFrameCache& cache) override;
void load(std::string_view filePath, Texture2D* texture, SpriteFrameCache& cache) override;
void load(std::string_view filePath, std::string_view textureFileName, SpriteFrameCache& cache) override;
void load(const std::string& filePath, SpriteFrameCache& cache) override;
void load(const std::string& filePath, Texture2D* texture, SpriteFrameCache& cache) override;
void load(const std::string& filePath, const std::string& textureFileName, SpriteFrameCache& cache) override;
void load(const Data& content, Texture2D* texture, SpriteFrameCache& cache) override;
void reload(std::string_view filePath, SpriteFrameCache& cache) override;
void reload(const std::string& filePath, SpriteFrameCache& cache) override;
protected:
/*Adds multiple Sprite Frames with a dictionary. The texture will be associated with the created sprite frames.
*/
void addSpriteFramesWithDictionary(ValueMap& dictionary,
Texture2D* texture,
std::string_view plist,
const std::string& plist,
SpriteFrameCache& cache);
/*Adds multiple Sprite Frames with a dictionary. The texture will be associated with the created sprite frames.
*/
void addSpriteFramesWithDictionary(ValueMap& dict,
std::string_view texturePath,
std::string_view plist,
const std::string& texturePath,
const std::string& plist,
SpriteFrameCache& cache);
void reloadSpriteFramesWithDictionary(ValueMap& dict,
Texture2D* texture,
std::string_view plist,
const std::string& plist,
SpriteFrameCache& cache);
};

View File

@ -357,7 +357,9 @@ void RenderTexture::visit(Renderer* renderer, const Mat4& parentTransform, uint3
// setOrderOfArrival(0);
}
bool RenderTexture::saveToFileAsNonPMA(std::string_view filename, bool isRGBA, SaveFileCallbackType callback)
bool RenderTexture::saveToFileAsNonPMA(const std::string& filename,
bool isRGBA,
std::function<void(RenderTexture*, const std::string&)> callback)
{
std::string basename(filename);
std::transform(basename.begin(), basename.end(), basename.begin(), ::tolower);
@ -380,7 +382,9 @@ bool RenderTexture::saveToFileAsNonPMA(std::string_view filename, bool isRGBA, S
return saveToFileAsNonPMA(filename, Image::Format::JPG, false, callback);
}
bool RenderTexture::saveToFile(std::string_view filename, bool isRGBA, SaveFileCallbackType callback)
bool RenderTexture::saveToFile(const std::string& filename,
bool isRGBA,
std::function<void(RenderTexture*, const std::string&)> callback)
{
std::string basename(filename);
std::transform(basename.begin(), basename.end(), basename.begin(), ::tolower);
@ -403,10 +407,10 @@ bool RenderTexture::saveToFile(std::string_view filename, bool isRGBA, SaveFileC
return saveToFile(filename, Image::Format::JPG, false, callback);
}
bool RenderTexture::saveToFileAsNonPMA(std::string_view fileName,
bool RenderTexture::saveToFileAsNonPMA(const std::string& fileName,
Image::Format format,
bool isRGBA,
SaveFileCallbackType callback)
std::function<void(RenderTexture*, const std::string&)> callback)
{
CCASSERT(format == Image::Format::JPG || format == Image::Format::PNG,
"the image can only be saved as JPG or PNG format");
@ -415,7 +419,7 @@ bool RenderTexture::saveToFileAsNonPMA(std::string_view fileName,
_saveFileCallback = callback;
std::string fullpath = FileUtils::getInstance()->getWritablePath().append(fileName);
std::string fullpath = FileUtils::getInstance()->getWritablePath() + fileName;
_saveToFileCommand.init(_globalZOrder);
_saveToFileCommand.func = CC_CALLBACK_0(RenderTexture::onSaveToFile, this, fullpath, isRGBA, true);
@ -423,10 +427,10 @@ bool RenderTexture::saveToFileAsNonPMA(std::string_view fileName,
return true;
}
bool RenderTexture::saveToFile(std::string_view fileName,
bool RenderTexture::saveToFile(const std::string& fileName,
Image::Format format,
bool isRGBA,
std::function<void(RenderTexture*, std::string_view)> callback)
std::function<void(RenderTexture*, const std::string&)> callback)
{
CCASSERT(format == Image::Format::JPG || format == Image::Format::PNG,
"the image can only be saved as JPG or PNG format");
@ -435,7 +439,7 @@ bool RenderTexture::saveToFile(std::string_view fileName,
_saveFileCallback = callback;
std::string fullpath = FileUtils::getInstance()->getWritablePath().append(fileName);
std::string fullpath = FileUtils::getInstance()->getWritablePath() + fileName;
_saveToFileCommand.init(_globalZOrder);
_saveToFileCommand.func = CC_CALLBACK_0(RenderTexture::onSaveToFile, this, fullpath, isRGBA, false);
@ -443,7 +447,7 @@ bool RenderTexture::saveToFile(std::string_view fileName,
return true;
}
void RenderTexture::onSaveToFile(std::string_view filename, bool isRGBA, bool forceNonPMA)
void RenderTexture::onSaveToFile(const std::string& filename, bool isRGBA, bool forceNonPMA)
{
auto callbackFunc = [&, filename, isRGBA, forceNonPMA](RefPtr<Image> image) {
if (image)

View File

@ -61,7 +61,6 @@ class EventCustom;
class CC_DLL RenderTexture : public Node
{
public:
using SaveFileCallbackType = std::function<void(RenderTexture*, std::string_view)>;
/** Initializes a RenderTexture object with width and height in Points and a pixel format( only RGB and RGBA formats
* are valid ) and depthStencil format.
*
@ -172,7 +171,9 @@ public:
* @param callback When the file is save finished,it will callback this function.
* @return Returns true if the operation is successful.
*/
bool saveToFileAsNonPMA(std::string_view filename, bool isRGBA = true, SaveFileCallbackType = nullptr);
bool saveToFileAsNonPMA(const std::string& filename,
bool isRGBA = true,
std::function<void(RenderTexture*, const std::string&)> callback = nullptr);
/** Saves the texture into a file using JPEG format. The file will be saved in the Documents folder.
* Returns true if the operation is successful.
@ -182,7 +183,9 @@ public:
* @param callback When the file is save finished,it will callback this function.
* @return Returns true if the operation is successful.
*/
bool saveToFile(std::string_view filename, bool isRGBA = true, SaveFileCallbackType = nullptr);
bool saveToFile(const std::string& filename,
bool isRGBA = true,
std::function<void(RenderTexture*, const std::string&)> callback = nullptr);
/** saves the texture into a file in non-PMA. The format could be JPG or PNG. The file will be saved in the
Documents folder. Returns true if the operation is successful.
@ -198,10 +201,10 @@ public:
* @param callback When the file is save finished,it will callback this function.
* @return Returns true if the operation is successful.
*/
bool saveToFileAsNonPMA(std::string_view fileName,
bool saveToFileAsNonPMA(const std::string& fileName,
Image::Format format,
bool isRGBA,
SaveFileCallbackType callback);
std::function<void(RenderTexture*, const std::string&)> callback);
/** saves the texture into a file. The format could be JPG or PNG. The file will be saved in the Documents folder.
Returns true if the operation is successful.
@ -217,10 +220,10 @@ public:
* @param callback When the file is save finished,it will callback this function.
* @return Returns true if the operation is successful.
*/
bool saveToFile(std::string_view filename,
bool saveToFile(const std::string& filename,
Image::Format format,
bool isRGBA = true,
SaveFileCallbackType callback = nullptr);
bool isRGBA = true,
std::function<void(RenderTexture*, const std::string&)> callback = nullptr);
/** Listen "come to background" message, and save render texture.
* It only has effect on Android.
@ -364,7 +367,7 @@ protected:
void onEnd();
void clearColorAttachment();
void onSaveToFile(std::string_view fileName, bool isRGBA = true, bool forceNonPMA = false);
void onSaveToFile(const std::string& fileName, bool isRGBA = true, bool forceNonPMA = false);
bool _keepMatrix = false;
Rect _rtTextureRect;
@ -408,7 +411,7 @@ protected:
and the command and callback will be executed twice.
*/
CallbackCommand _saveToFileCommand;
std::function<void(RenderTexture*, std::string_view)> _saveFileCallback = nullptr;
std::function<void(RenderTexture*, const std::string&)> _saveFileCallback = nullptr;
Mat4 _oldTransMatrix, _oldProjMatrix;
Mat4 _transformMatrix, _projectionMatrix;

View File

@ -142,7 +142,7 @@ protected:
std::vector<Camera*> _cameras; // weak ref to Camera
Camera* _defaultCamera = nullptr; // weak ref, default camera created by scene, _cameras[0], Caution that the
// default camera can not be added to _cameras before onEnter is called
bool _cameraOrderDirty = true; // order is dirty, need sort
bool _cameraOrderDirty = true; // order is dirty, need sort
EventListenerCustom* _event;
std::vector<BaseLight*> _lights;

View File

@ -72,7 +72,7 @@ Sprite* Sprite::createWithTexture(Texture2D* texture, const Rect& rect, bool rot
return nullptr;
}
Sprite* Sprite::create(std::string_view filename)
Sprite* Sprite::create(const std::string& filename)
{
Sprite* sprite = new Sprite();
if (sprite->initWithFile(filename))
@ -96,7 +96,7 @@ Sprite* Sprite::create(const PolygonInfo& info)
return nullptr;
}
Sprite* Sprite::create(std::string_view filename, const Rect& rect)
Sprite* Sprite::create(const std::string& filename, const Rect& rect)
{
Sprite* sprite = new Sprite();
if (sprite->initWithFile(filename, rect))
@ -120,13 +120,13 @@ Sprite* Sprite::createWithSpriteFrame(SpriteFrame* spriteFrame)
return nullptr;
}
Sprite* Sprite::createWithSpriteFrameName(std::string_view spriteFrameName)
Sprite* Sprite::createWithSpriteFrameName(const std::string& spriteFrameName)
{
SpriteFrame* frame = SpriteFrameCache::getInstance()->getSpriteFrameByName(spriteFrameName);
#if COCOS2D_DEBUG > 0
char msg[256] = {0};
sprintf(msg, "Invalid spriteFrameName: %s", spriteFrameName.data());
sprintf(msg, "Invalid spriteFrameName: %s", spriteFrameName.c_str());
CCASSERT(frame != nullptr, msg);
#endif
@ -167,7 +167,7 @@ bool Sprite::initWithTexture(Texture2D* texture, const Rect& rect)
return initWithTexture(texture, rect, false);
}
bool Sprite::initWithFile(std::string_view filename)
bool Sprite::initWithFile(const std::string& filename)
{
if (filename.empty())
{
@ -191,7 +191,7 @@ bool Sprite::initWithFile(std::string_view filename)
return false;
}
bool Sprite::initWithFile(std::string_view filename, const Rect& rect)
bool Sprite::initWithFile(const std::string& filename, const Rect& rect)
{
CCASSERT(!filename.empty(), "Invalid filename");
if (filename.empty())
@ -209,7 +209,7 @@ bool Sprite::initWithFile(std::string_view filename, const Rect& rect)
return false;
}
bool Sprite::initWithSpriteFrameName(std::string_view spriteFrameName)
bool Sprite::initWithSpriteFrameName(const std::string& spriteFrameName)
{
CCASSERT(!spriteFrameName.empty(), "Invalid spriteFrameName");
if (spriteFrameName.empty())
@ -332,7 +332,7 @@ static unsigned char cc_2x2_white_image[] = {
#define CC_2x2_WHITE_IMAGE_KEY "/cc_2x2_white_image"
// MARK: texture
void Sprite::setTexture(std::string_view filename)
void Sprite::setTexture(const std::string& filename)
{
Texture2D* texture = _director->getTextureCache()->addImage(filename);
setTexture(texture);
@ -1132,7 +1132,7 @@ void Sprite::addChild(Node* child, int zOrder, int tag)
Node::addChild(child, zOrder, tag);
}
void Sprite::addChild(Node* child, int zOrder, std::string_view name)
void Sprite::addChild(Node* child, int zOrder, const std::string& name)
{
CCASSERT(child != nullptr, "Argument must be non-nullptr");
if (child == nullptr)
@ -1539,7 +1539,7 @@ bool Sprite::isOpacityModifyRGB() const
// MARK: Frames
void Sprite::setSpriteFrame(std::string_view spriteFrameName)
void Sprite::setSpriteFrame(const std::string& spriteFrameName)
{
CCASSERT(!spriteFrameName.empty(), "spriteFrameName must not be empty");
if (spriteFrameName.empty())
@ -1590,7 +1590,7 @@ void Sprite::setSpriteFrame(SpriteFrame* spriteFrame)
setCenterRect(spriteFrame->getCenterRect());
}
void Sprite::setDisplayFrameWithAnimationName(std::string_view animationName, unsigned int frameIndex)
void Sprite::setDisplayFrameWithAnimationName(const std::string& animationName, unsigned int frameIndex)
{
CCASSERT(!animationName.empty(), "CCSprite#setDisplayFrameWithAnimationName. animationName must not be nullptr");
if (animationName.empty())

View File

@ -129,7 +129,7 @@ public:
* @param filename A path to image file, e.g., "scene1/monster.png".
* @return An autoreleased sprite object.
*/
static Sprite* create(std::string_view filename);
static Sprite* create(const std::string& filename);
/**
* Creates a polygon sprite with a polygon info.
@ -149,7 +149,7 @@ public:
* @param rect A subrect of the image file.
* @return An autoreleased sprite object.
*/
static Sprite* create(std::string_view filename, const Rect& rect);
static Sprite* create(const std::string& filename, const Rect& rect);
/**
* Creates a sprite with a Texture2D object.
@ -191,7 +191,7 @@ public:
* @param spriteFrameName The name of sprite frame.
* @return An autoreleased sprite object.
*/
static Sprite* createWithSpriteFrameName(std::string_view spriteFrameName);
static Sprite* createWithSpriteFrameName(const std::string& spriteFrameName);
// end of creators group
/// @}
@ -233,7 +233,7 @@ public:
* @memberof Sprite
* It will call `setTextureRect()` with the texture's content size.
*/
virtual void setTexture(std::string_view filename);
virtual void setTexture(const std::string& filename);
/** @overload
*
@ -304,7 +304,7 @@ public:
/** @{
* Sets a new SpriteFrame to the Sprite.
*/
virtual void setSpriteFrame(std::string_view spriteFrameName);
virtual void setSpriteFrame(const std::string& spriteFrameName);
virtual void setSpriteFrame(SpriteFrame* newFrame);
/** @} */
@ -326,7 +326,7 @@ public:
* Changes the display frame with animation name and index.
* The animation name will be get from the AnimationCache.
*/
virtual void setDisplayFrameWithAnimationName(std::string_view animationName, unsigned int frameIndex);
virtual void setDisplayFrameWithAnimationName(const std::string& animationName, unsigned int frameIndex);
/// @}
/// @{
@ -370,7 +370,7 @@ public:
virtual void reorderChild(Node* child, int zOrder) override;
using Node::addChild;
virtual void addChild(Node* child, int zOrder, int tag) override;
virtual void addChild(Node* child, int zOrder, std::string_view name) override;
virtual void addChild(Node* child, int zOrder, const std::string& name) override;
virtual void sortAllChildren() override;
virtual void setScale(float scale) override;
virtual void setPositionZ(float positionZ) override;
@ -513,7 +513,7 @@ public:
/// @}
int getResourceType() const { return _fileType; }
std::string_view getResourceName() const { return _fileName; }
const std::string& getResourceName() const { return _fileName; }
CC_CONSTRUCTOR_ACCESS :
/**
@ -588,7 +588,7 @@ public:
* @param spriteFrameName A key string that can fetched a valid SpriteFrame from SpriteFrameCache.
* @return True if the sprite is initialized properly, false otherwise.
*/
virtual bool initWithSpriteFrameName(std::string_view spriteFrameName);
virtual bool initWithSpriteFrameName(const std::string& spriteFrameName);
/**
* Initializes a sprite with an image filename.
@ -601,7 +601,7 @@ public:
* @return True if the sprite is initialized properly, false otherwise.
* @lua init
*/
virtual bool initWithFile(std::string_view filename);
virtual bool initWithFile(const std::string& filename);
/**
* Initializes a sprite with an image filename, and a rect.
@ -615,7 +615,7 @@ public:
* @return True if the sprite is initialized properly, false otherwise.
* @lua init
*/
virtual bool initWithFile(std::string_view filename, const Rect& rect);
virtual bool initWithFile(const std::string& filename, const Rect& rect);
virtual void setVertexLayout();

View File

@ -64,7 +64,7 @@ SpriteBatchNode* SpriteBatchNode::createWithTexture(Texture2D* tex, ssize_t capa
* creation with File Image
*/
SpriteBatchNode* SpriteBatchNode::create(std::string_view fileImage, ssize_t capacity /* = DEFAULT_CAPACITY*/)
SpriteBatchNode* SpriteBatchNode::create(const std::string& fileImage, ssize_t capacity /* = DEFAULT_CAPACITY*/)
{
SpriteBatchNode* batchNode = new SpriteBatchNode();
if (batchNode->initWithFile(fileImage, capacity))
@ -168,7 +168,7 @@ bool SpriteBatchNode::init()
/*
* init with FileImage
*/
bool SpriteBatchNode::initWithFile(std::string_view fileImage, ssize_t capacity /* = DEFAULT_CAPACITY*/)
bool SpriteBatchNode::initWithFile(const std::string& fileImage, ssize_t capacity /* = DEFAULT_CAPACITY*/)
{
Texture2D* texture2D = _director->getTextureCache()->addImage(fileImage);
return initWithTexture(texture2D, capacity);
@ -236,7 +236,7 @@ void SpriteBatchNode::addChild(Node* child, int zOrder, int tag)
appendChild(sprite);
}
void SpriteBatchNode::addChild(Node* child, int zOrder, std::string_view name)
void SpriteBatchNode::addChild(Node* child, int zOrder, const std::string& name)
{
CCASSERT(child != nullptr, "child should not be null");
CCASSERT(dynamic_cast<Sprite*>(child) != nullptr, "CCSpriteBatchNode only supports Sprites as children");

View File

@ -84,7 +84,7 @@ public:
* @param capacity The capacity of children.
* @return Return an autorelease object.
*/
static SpriteBatchNode* create(std::string_view fileImage, ssize_t capacity = DEFAULT_CAPACITY);
static SpriteBatchNode* create(const std::string& fileImage, ssize_t capacity = DEFAULT_CAPACITY);
/** Returns the TextureAtlas object.
*
@ -195,7 +195,7 @@ public:
using Node::addChild;
virtual void addChild(Node* child, int zOrder, int tag) override;
virtual void addChild(Node* child, int zOrder, std::string_view name) override;
virtual void addChild(Node* child, int zOrder, const std::string& name) override;
virtual void reorderChild(Node* child, int zOrder) override;
virtual void removeChild(Node* child, bool cleanup) override;
@ -250,7 +250,7 @@ public:
* @js init
* @lua init
*/
bool initWithFile(std::string_view fileImage, ssize_t capacity = DEFAULT_CAPACITY);
bool initWithFile(const std::string& fileImage, ssize_t capacity = DEFAULT_CAPACITY);
bool init() override;
protected:

View File

@ -35,7 +35,7 @@ NS_CC_BEGIN
// implementation of SpriteFrame
SpriteFrame* SpriteFrame::create(std::string_view filename, const Rect& rect)
SpriteFrame* SpriteFrame::create(const std::string& filename, const Rect& rect)
{
SpriteFrame* spriteFrame = new SpriteFrame();
spriteFrame->initWithTextureFilename(filename, rect);
@ -70,7 +70,7 @@ SpriteFrame* SpriteFrame::createWithTexture(Texture2D* texture,
return nullptr;
}
SpriteFrame* SpriteFrame::create(std::string_view filename,
SpriteFrame* SpriteFrame::create(const std::string& filename,
const Rect& rect,
bool rotated,
const Vec2& offset,
@ -94,7 +94,7 @@ bool SpriteFrame::initWithTexture(Texture2D* texture, const Rect& rect)
return initWithTexture(texture, rectInPixels, false, Vec2::ZERO, rectInPixels.size);
}
bool SpriteFrame::initWithTextureFilename(std::string_view filename, const Rect& rect)
bool SpriteFrame::initWithTextureFilename(const std::string& filename, const Rect& rect)
{
Rect rectInPixels = CC_RECT_POINTS_TO_PIXELS(rect);
return initWithTextureFilename(filename, rectInPixels, false, Vec2::ZERO, rectInPixels.size);
@ -126,7 +126,7 @@ bool SpriteFrame::initWithTexture(Texture2D* texture,
return true;
}
bool SpriteFrame::initWithTextureFilename(std::string_view filename,
bool SpriteFrame::initWithTextureFilename(const std::string& filename,
const Rect& rect,
bool rotated,
const Vec2& offset,

View File

@ -66,7 +66,7 @@ public:
* @param rect A specified rect.
* @return An autoreleased SpriteFrame object.
*/
static SpriteFrame* create(std::string_view filename, const Rect& rect);
static SpriteFrame* create(const std::string& filename, const Rect& rect);
/** Create a SpriteFrame with a texture filename, rect, rotated, offset and originalSize in pixels.
The originalSize is the size in pixels of the frame before being trimmed.
@ -78,7 +78,7 @@ public:
* @param originalSize A specified original size.
* @return An autoreleased SpriteFrame object.
*/
static SpriteFrame* create(std::string_view filename,
static SpriteFrame* create(const std::string& filename,
const Rect& rect,
bool rotated,
const Vec2& offset,
@ -279,7 +279,7 @@ public:
/** Initializes a SpriteFrame with a texture filename, rect in points;
It is assumed that the frame was not trimmed.
*/
bool initWithTextureFilename(std::string_view filename, const Rect& rect);
bool initWithTextureFilename(const std::string& filename, const Rect& rect);
/** Initializes a SpriteFrame with a texture, rect, rotated, offset and originalSize in pixels.
The originalSize is the size in points of the frame before being trimmed.
@ -295,7 +295,7 @@ public:
@since v1.1
*/
bool initWithTextureFilename(std::string_view filename,
bool initWithTextureFilename(const std::string& filename,
const Rect& rect,
bool rotated,
const Vec2& offset,

View File

@ -75,8 +75,8 @@ bool SpriteFrameCache::init()
SpriteFrameCache::~SpriteFrameCache() {}
void SpriteFrameCache::addSpriteFramesWithFile(std::string_view spriteSheetFileName,
std::string_view textureFileName,
void SpriteFrameCache::addSpriteFramesWithFile(const std::string& spriteSheetFileName,
const std::string& textureFileName,
uint32_t spriteSheetFormat)
{
auto* loader = getSpriteSheetLoader(spriteSheetFormat);
@ -86,7 +86,7 @@ void SpriteFrameCache::addSpriteFramesWithFile(std::string_view spriteSheetFileN
}
}
void SpriteFrameCache::addSpriteFramesWithFile(std::string_view spriteSheetFileName,
void SpriteFrameCache::addSpriteFramesWithFile(const std::string& spriteSheetFileName,
Texture2D* texture,
uint32_t spriteSheetFormat)
{
@ -97,7 +97,7 @@ void SpriteFrameCache::addSpriteFramesWithFile(std::string_view spriteSheetFileN
}
}
void SpriteFrameCache::addSpriteFramesWithFile(std::string_view spriteSheetFileName, uint32_t spriteSheetFormat)
void SpriteFrameCache::addSpriteFramesWithFile(const std::string& spriteSheetFileName, uint32_t spriteSheetFormat)
{
auto* loader = getSpriteSheetLoader(spriteSheetFormat);
if (loader)
@ -117,12 +117,12 @@ void SpriteFrameCache::addSpriteFramesWithFileContent(const Data& content,
}
}
bool SpriteFrameCache::isSpriteFramesWithFileLoaded(std::string_view plist) const
bool SpriteFrameCache::isSpriteFramesWithFileLoaded(const std::string& plist) const
{
return isSpriteSheetInUse(plist) && isPlistFull(plist);
}
void SpriteFrameCache::addSpriteFrame(SpriteFrame* frame, std::string_view frameName)
void SpriteFrameCache::addSpriteFrame(SpriteFrame* frame, const std::string& frameName)
{
CCASSERT(frame, "frame should not be nil");
@ -169,7 +169,7 @@ void SpriteFrameCache::removeUnusedSpriteFrames()
}
}
void SpriteFrameCache::removeSpriteFrameByName(std::string_view name)
void SpriteFrameCache::removeSpriteFrameByName(const std::string& name)
{
// explicit nil handling
if (name.empty())
@ -178,7 +178,7 @@ void SpriteFrameCache::removeSpriteFrameByName(std::string_view name)
eraseFrame(name);
}
void SpriteFrameCache::removeSpriteFramesFromFile(std::string_view atlasPath)
void SpriteFrameCache::removeSpriteFramesFromFile(const std::string& atlasPath)
{
// const auto fullPath = FileUtils::getInstance()->fullPathForFilename(plist);
// auto dict = FileUtils::getInstance()->getValueMapFromFile(fullPath);
@ -193,7 +193,7 @@ void SpriteFrameCache::removeSpriteFramesFromFile(std::string_view atlasPath)
removeSpriteSheet(atlasPath);
}
void SpriteFrameCache::removeSpriteFramesFromFileContent(std::string_view plist_content)
void SpriteFrameCache::removeSpriteFramesFromFileContent(const std::string& plist_content)
{
auto dict =
FileUtils::getInstance()->getValueMapFromData(plist_content.data(), static_cast<int>(plist_content.size()));
@ -241,17 +241,17 @@ void SpriteFrameCache::removeSpriteFramesFromTexture(Texture2D* texture)
eraseFrames(keysToRemove);
}
SpriteFrame* SpriteFrameCache::getSpriteFrameByName(std::string_view name)
SpriteFrame* SpriteFrameCache::getSpriteFrameByName(const std::string& name)
{
auto* frame = findFrame(name);
if (!frame)
{
CCLOG("cocos2d: SpriteFrameCache: Frame '%s' isn't found", name.data());
CCLOG("cocos2d: SpriteFrameCache: Frame '%s' isn't found", name.c_str());
}
return frame;
}
bool SpriteFrameCache::reloadTexture(std::string_view spriteSheetFileName)
bool SpriteFrameCache::reloadTexture(const std::string& spriteSheetFileName)
{
CCASSERT(!spriteSheetFileName.empty(), "plist filename should not be nullptr");
@ -283,18 +283,16 @@ bool SpriteFrameCache::reloadTexture(std::string_view spriteSheetFileName)
}
void SpriteFrameCache::insertFrame(const std::shared_ptr<SpriteSheet>& spriteSheet,
std::string_view frameName,
const std::string& frameName,
SpriteFrame* spriteFrame)
{
spriteSheet->frames.emplace(frameName);
spriteSheet->frames.insert(frameName);
_spriteFrames.insert(frameName, spriteFrame); // add SpriteFrame
_spriteSheets[spriteSheet->path] = spriteSheet;
hlookup::set_item(_spriteFrameToSpriteSheetMap, frameName,
spriteSheet); // _spriteFrameToSpriteSheetMap[frameName] = spriteSheet; // insert
// index frameName->plist
_spriteSheets[spriteSheet->path] = spriteSheet;
_spriteFrameToSpriteSheetMap[frameName] = spriteSheet; // insert index frameName->plist
}
bool SpriteFrameCache::eraseFrame(std::string_view frameName)
bool SpriteFrameCache::eraseFrame(const std::string& frameName)
{
_spriteFrames.erase(frameName); // drop SpriteFrame
const auto itFrame = _spriteFrameToSpriteSheetMap.find(frameName);
@ -332,7 +330,7 @@ bool SpriteFrameCache::eraseFrames(const std::vector<std::string>& frames)
return ret;
}
bool SpriteFrameCache::removeSpriteSheet(std::string_view spriteSheetFileName)
bool SpriteFrameCache::removeSpriteSheet(const std::string& spriteSheetFileName)
{
auto it = _spriteSheets.find(spriteSheetFileName);
if (it == _spriteSheets.end())
@ -358,18 +356,18 @@ void SpriteFrameCache::clear()
_spriteFrames.clear();
}
bool SpriteFrameCache::hasFrame(std::string_view frame) const
bool SpriteFrameCache::hasFrame(const std::string& frame) const
{
return _spriteFrameToSpriteSheetMap.find(frame) != _spriteFrameToSpriteSheetMap.end();
}
bool SpriteFrameCache::isSpriteSheetInUse(std::string_view spriteSheetFileName) const
bool SpriteFrameCache::isSpriteSheetInUse(const std::string& spriteSheetFileName) const
{
const auto spriteSheetItr = _spriteSheets.find(spriteSheetFileName);
return spriteSheetItr != _spriteSheets.end() && !spriteSheetItr->second->frames.empty();
}
SpriteFrame* SpriteFrameCache::findFrame(std::string_view frame)
SpriteFrame* SpriteFrameCache::findFrame(const std::string& frame)
{
return _spriteFrames.at(frame);
}
@ -379,7 +377,7 @@ void SpriteFrameCache::addSpriteFrameCapInset(SpriteFrame* spriteFrame, const Re
texture->addSpriteFrameCapInset(spriteFrame, capInsets);
}
StringMap<SpriteFrame*>& SpriteFrameCache::getSpriteFrames()
Map<std::string, SpriteFrame*>& SpriteFrameCache::getSpriteFrames()
{
return _spriteFrames;
}

View File

@ -117,7 +117,7 @@ public:
/** Adds multiple Sprite Frames from a plist file.
* A texture will be loaded automatically. The texture name will composed by replacing the .plist suffix with .png.
* If you want to use another texture, you should use the addSpriteFramesWithFile(std::string_view plist, const
* If you want to use another texture, you should use the addSpriteFramesWithFile(const std::string& plist, const
* std::string& textureFileName) method.
* @js addSpriteFrames
* @lua addSpriteFrames
@ -125,7 +125,7 @@ public:
* @param spriteSheetFileName file name.
* @param spriteSheetFormat
*/
void addSpriteFramesWithFile(std::string_view spriteSheetFileName,
void addSpriteFramesWithFile(const std::string& spriteSheetFileName,
uint32_t spriteSheetFormat = SpriteSheetFormat::PLIST);
/** Adds multiple Sprite Frames from a plist file. The texture will be associated with the created sprite frames.
@ -137,8 +137,8 @@ public:
* @param textureFileName Texture file name.
* @param spriteSheetFormat
*/
void addSpriteFramesWithFile(std::string_view spriteSheetFileName,
std::string_view textureFileName,
void addSpriteFramesWithFile(const std::string& spriteSheetFileName,
const std::string& textureFileName,
uint32_t spriteSheetFormat = SpriteSheetFormat::PLIST);
/** Adds multiple Sprite Frames from a plist file. The texture will be associated with the created sprite frames.
@ -149,7 +149,7 @@ public:
* @param texture Texture pointer.
* @param spriteSheetFormat
*/
void addSpriteFramesWithFile(std::string_view spriteSheetFileName,
void addSpriteFramesWithFile(const std::string& spriteSheetFileName,
Texture2D* texture,
uint32_t spriteSheetFormat = SpriteSheetFormat::PLIST);
@ -172,7 +172,7 @@ public:
* @param frame A certain sprite frame.
* @param frameName The name of the sprite frame.
*/
void addSpriteFrame(SpriteFrame* frame, std::string_view frameName);
void addSpriteFrame(SpriteFrame* frame, const std::string& frameName);
/** Check if multiple Sprite Frames from a plist file have been loaded.
* @js NA
@ -181,7 +181,7 @@ public:
* @param plist Plist file name.
* @return True if the file is loaded.
*/
bool isSpriteFramesWithFileLoaded(std::string_view plist) const;
bool isSpriteFramesWithFileLoaded(const std::string& plist) const;
/** Purges the dictionary of loaded sprite frames.
* Call this method if you receive the "Memory Warning".
@ -202,7 +202,7 @@ public:
*
* @param name The name of the sprite frame that needs to removed.
*/
void removeSpriteFrameByName(std::string_view name);
void removeSpriteFrameByName(const std::string& name);
/** Removes multiple Sprite Frames from a plist file.
* Sprite Frames stored in this file will be removed.
@ -211,7 +211,7 @@ public:
*
* @param plist The name of the plist that needs to removed.
*/
void removeSpriteFramesFromFile(std::string_view plist);
void removeSpriteFramesFromFile(const std::string& plist);
/** Removes multiple Sprite Frames from a plist file content.
* Sprite Frames stored in this file will be removed.
@ -220,7 +220,7 @@ public:
* @param plist_content The string of the plist content that needs to removed.
* @js NA
*/
void removeSpriteFramesFromFileContent(std::string_view plist_content);
void removeSpriteFramesFromFileContent(const std::string& plist_content);
/** Removes all Sprite Frames associated with the specified textures.
* It is convenient to call this method when a specific texture needs to be removed.
@ -239,22 +239,22 @@ public:
* @param name A certain sprite frame name.
* @return The sprite frame.
*/
SpriteFrame* getSpriteFrameByName(std::string_view name);
SpriteFrame* getSpriteFrameByName(const std::string& name);
bool reloadTexture(std::string_view spriteSheetFileName);
bool reloadTexture(const std::string& spriteSheetFileName);
SpriteFrame* findFrame(std::string_view frame);
SpriteFrame* findFrame(const std::string& frame);
/** Record SpriteFrame with plist and frame name, add frame name
* and plist to index
*/
void insertFrame(const std::shared_ptr<SpriteSheet>& spriteSheet,
std::string_view frameName,
const std::string& frameName,
SpriteFrame* frameObj);
/** Delete frame from cache, rebuild index
*/
bool eraseFrame(std::string_view frameName);
bool eraseFrame(const std::string& frameName);
void addSpriteFrameCapInset(SpriteFrame* spriteFrame, const Rect& capInsets, Texture2D* texture);
@ -277,35 +277,30 @@ protected:
bool eraseFrames(const std::vector<std::string>& frame);
/** Delete frame from index and SpriteFrame is kept.
*/
bool removeSpriteSheet(std::string_view spriteSheetFileName);
bool removeSpriteSheet(const std::string& spriteSheetFileName);
/** Clear index and all SpriteFrames.
*/
void clear();
inline bool hasFrame(std::string_view frame) const;
inline bool isSpriteSheetInUse(std::string_view spriteSheetFileName) const;
inline bool hasFrame(const std::string& frame) const;
inline bool isSpriteSheetInUse(const std::string& spriteSheetFileName) const;
inline StringMap<SpriteFrame*>& getSpriteFrames();
inline Map<std::string, SpriteFrame*>& getSpriteFrames();
void markPlistFull(std::string_view spriteSheetFileName, bool full)
void markPlistFull(const std::string& spriteSheetFileName, bool full)
{
// _spriteSheets[spriteSheetFileName]->full = full;
auto it = _spriteSheets.find(spriteSheetFileName);
if (it != _spriteSheets.end())
{
it.value()->full = full;
}
_spriteSheets[spriteSheetFileName]->full = full;
}
bool isPlistFull(std::string_view spriteSheetFileName) const
bool isPlistFull(const std::string& spriteSheetFileName) const
{
auto it = _spriteSheets.find(spriteSheetFileName);
auto&& it = _spriteSheets.find(spriteSheetFileName);
return it == _spriteSheets.end() ? false : it->second->full;
}
private:
StringMap<SpriteFrame*> _spriteFrames;
hlookup::string_map<std::shared_ptr<SpriteSheet>> _spriteSheets;
hlookup::string_map<std::shared_ptr<SpriteSheet>> _spriteFrameToSpriteSheetMap;
Map<std::string, SpriteFrame*> _spriteFrames;
std::unordered_map<std::string, std::shared_ptr<SpriteSheet>> _spriteSheets;
std::unordered_map<std::string, std::shared_ptr<SpriteSheet>> _spriteFrameToSpriteSheetMap;
std::map<uint32_t, std::shared_ptr<ISpriteSheetLoader>> _spriteSheetLoaders;
};

View File

@ -65,20 +65,20 @@ class SpriteSheet
public:
std::string path;
uint32_t format;
hlookup::string_set frames;
std::set<std::string> frames;
bool full = false;
};
class ISpriteSheetLoader
{
public:
virtual ~ISpriteSheetLoader() = default;
virtual uint32_t getFormat() = 0;
virtual void load(std::string_view filePath, SpriteFrameCache& cache) = 0;
virtual void load(std::string_view filePath, Texture2D* texture, SpriteFrameCache& cache) = 0;
virtual void load(std::string_view filePath, std::string_view textureFileName, SpriteFrameCache& cache) = 0;
virtual void load(const Data& content, Texture2D* texture, SpriteFrameCache& cache) = 0;
virtual void reload(std::string_view filePath, SpriteFrameCache& cache) = 0;
virtual ~ISpriteSheetLoader() = default;
virtual uint32_t getFormat() = 0;
virtual void load(const std::string& filePath, SpriteFrameCache& cache) = 0;
virtual void load(const std::string& filePath, Texture2D* texture, SpriteFrameCache& cache) = 0;
virtual void load(const std::string& filePath, const std::string& textureFileName, SpriteFrameCache& cache) = 0;
virtual void load(const Data& content, Texture2D* texture, SpriteFrameCache& cache) = 0;
virtual void reload(const std::string& filePath, SpriteFrameCache& cache) = 0;
};
class SpriteSheetLoader : public ISpriteSheetLoader
@ -92,12 +92,12 @@ public:
const std::vector<int>& triangleIndices,
PolygonInfo& polygonInfo);
uint32_t getFormat() override = 0;
void load(std::string_view filePath, SpriteFrameCache& cache) override = 0;
void load(std::string_view filePath, Texture2D* texture, SpriteFrameCache& cache) override = 0;
void load(std::string_view filePath, std::string_view textureFileName, SpriteFrameCache& cache) override = 0;
void load(const Data& content, Texture2D* texture, SpriteFrameCache& cache) override = 0;
void reload(std::string_view filePath, SpriteFrameCache& cache) override = 0;
uint32_t getFormat() override = 0;
void load(const std::string& filePath, SpriteFrameCache& cache) override = 0;
void load(const std::string& filePath, Texture2D* texture, SpriteFrameCache& cache) override = 0;
void load(const std::string& filePath, const std::string& textureFileName, SpriteFrameCache& cache) override = 0;
void load(const Data& content, Texture2D* texture, SpriteFrameCache& cache) override = 0;
void reload(const std::string& filePath, SpriteFrameCache& cache) override = 0;
};
// end of _2d group

View File

@ -40,7 +40,7 @@ TMXObjectGroup::~TMXObjectGroup()
CCLOGINFO("deallocing TMXObjectGroup: %p", this);
}
ValueMap TMXObjectGroup::getObject(std::string_view objectName) const
ValueMap TMXObjectGroup::getObject(const std::string& objectName) const
{
if (!_objects.empty())
{
@ -59,7 +59,7 @@ ValueMap TMXObjectGroup::getObject(std::string_view objectName) const
return ValueMap();
}
Value TMXObjectGroup::getProperty(std::string_view propertyName) const
Value TMXObjectGroup::getProperty(const std::string& propertyName) const
{
if (_properties.find(propertyName) != _properties.end())
return _properties.at(propertyName);

View File

@ -60,13 +60,13 @@ public:
*
* @return The group name.
*/
std::string_view getGroupName() const { return _groupName; }
const std::string& getGroupName() const { return _groupName; }
/** Set the group name.
*
* @param groupName A string,it is used to set the group name.
*/
void setGroupName(std::string_view groupName) { _groupName = groupName; }
void setGroupName(const std::string& groupName) { _groupName = groupName; }
/** Return the value for the specific property name.
*
@ -74,14 +74,14 @@ public:
* @return Return the value for the specific property name.
* @js NA
*/
Value getProperty(std::string_view propertyName) const;
Value getProperty(const std::string& propertyName) const;
/** Return the dictionary for the specific object name.
* It will return the 1st object found on the array for the given name.
*
* @return Return the dictionary for the specific object name.
*/
ValueMap getObject(std::string_view objectName) const;
ValueMap getObject(const std::string& objectName) const;
/** Gets the offset position of child objects.
*

View File

@ -92,7 +92,7 @@ Rect TMXTilesetInfo::getRectForGID(uint32_t gid)
// implementation TMXMapInfo
TMXMapInfo* TMXMapInfo::create(std::string_view tmxFile)
TMXMapInfo* TMXMapInfo::create(const std::string& tmxFile)
{
TMXMapInfo* ret = new TMXMapInfo();
if (ret->initWithTMXFile(tmxFile))
@ -104,7 +104,7 @@ TMXMapInfo* TMXMapInfo::create(std::string_view tmxFile)
return nullptr;
}
TMXMapInfo* TMXMapInfo::createWithXML(std::string_view tmxString, std::string_view resourcePath)
TMXMapInfo* TMXMapInfo::createWithXML(const std::string& tmxString, const std::string& resourcePath)
{
TMXMapInfo* ret = new TMXMapInfo();
if (ret->initWithXML(tmxString, resourcePath))
@ -116,7 +116,7 @@ TMXMapInfo* TMXMapInfo::createWithXML(std::string_view tmxString, std::string_vi
return nullptr;
}
void TMXMapInfo::internalInit(std::string_view tmxFileName, std::string_view resourcePath)
void TMXMapInfo::internalInit(const std::string& tmxFileName, const std::string& resourcePath)
{
if (!tmxFileName.empty())
{
@ -138,13 +138,13 @@ void TMXMapInfo::internalInit(std::string_view tmxFileName, std::string_view res
_currentFirstGID = -1;
}
bool TMXMapInfo::initWithXML(std::string_view tmxString, std::string_view resourcePath)
bool TMXMapInfo::initWithXML(const std::string& tmxString, const std::string& resourcePath)
{
internalInit("", resourcePath);
return parseXMLString(tmxString);
}
bool TMXMapInfo::initWithTMXFile(std::string_view tmxFile)
bool TMXMapInfo::initWithTMXFile(const std::string& tmxFile)
{
internalInit(tmxFile, "");
return parseXMLFile(_TMXFileName);
@ -171,7 +171,7 @@ TMXMapInfo::~TMXMapInfo()
CCLOGINFO("deallocing TMXMapInfo: %p", this);
}
bool TMXMapInfo::parseXMLString(std::string_view xmlString)
bool TMXMapInfo::parseXMLString(const std::string& xmlString)
{
size_t len = xmlString.size();
if (len <= 0)
@ -186,10 +186,10 @@ bool TMXMapInfo::parseXMLString(std::string_view xmlString)
parser.setDelegator(this);
return parser.parse(xmlString.data(), len);
return parser.parse(xmlString.c_str(), len);
}
bool TMXMapInfo::parseXMLFile(std::string_view xmlFilename)
bool TMXMapInfo::parseXMLFile(const std::string& xmlFilename)
{
SAXParser parser;
@ -265,7 +265,7 @@ void TMXMapInfo::startElement(void* /*ctx*/, const char* name, const char** atts
tmxMapInfo->setStaggerIndex(TMXStaggerIndex_Even);
}
auto hexSideLength = attributeDict["hexsidelength"].asInt();
float hexSideLength = attributeDict["hexsidelength"].asFloat();
tmxMapInfo->setHexSideLength(hexSideLength);
Vec2 s;
@ -348,7 +348,7 @@ void TMXMapInfo::startElement(void* /*ctx*/, const char* name, const char** atts
TMXLayerInfo* layer = tmxMapInfo->getLayers().back();
Vec2 layerSize = layer->_layerSize;
uint32_t gid = static_cast<uint32_t>(attributeDict["gid"].asUnsignedInt());
int tilesAmount = static_cast<int>(layerSize.width * layerSize.height);
int tilesAmount = layerSize.width * layerSize.height;
if (_xmlTileIndex < tilesAmount)
{
@ -443,7 +443,7 @@ void TMXMapInfo::startElement(void* /*ctx*/, const char* name, const char** atts
TMXLayerInfo* layer = tmxMapInfo->getLayers().back();
Vec2 layerSize = layer->_layerSize;
int tilesAmount = static_cast<int>(layerSize.width * layerSize.height);
int tilesAmount = layerSize.width * layerSize.height;
uint32_t* tiles = (uint32_t*)malloc(tilesAmount * sizeof(uint32_t));
// set all value to 0
@ -688,10 +688,10 @@ void TMXMapInfo::endElement(void* /*ctx*/, const char* name)
TMXLayerInfo* layer = tmxMapInfo->getLayers().back();
auto currentString = tmxMapInfo->getCurrentString();
std::string currentString = tmxMapInfo->getCurrentString();
unsigned char* buffer;
auto len =
base64Decode((unsigned char*)currentString.data(), (unsigned int)currentString.length(), &buffer);
base64Decode((unsigned char*)currentString.c_str(), (unsigned int)currentString.length(), &buffer);
if (!buffer)
{
CCLOG("cocos2d: TiledMap: decode data error");
@ -733,11 +733,10 @@ void TMXMapInfo::endElement(void* /*ctx*/, const char* name)
TMXLayerInfo* layer = tmxMapInfo->getLayers().back();
tmxMapInfo->setStoringCharacters(false);
auto currentString = tmxMapInfo->getCurrentString();
std::string currentString = tmxMapInfo->getCurrentString();
vector<string> gidTokens;
std::stringstream filestr;
filestr << currentString;
istringstream filestr(currentString);
string sRow;
while (getline(filestr, sRow, '\n'))
{
@ -811,7 +810,7 @@ void TMXMapInfo::textHandler(void* /*ctx*/, const char* ch, size_t len)
if (tmxMapInfo->isStoringCharacters())
{
std::string currentString{tmxMapInfo->getCurrentString()};
std::string currentString = tmxMapInfo->getCurrentString();
currentString += text;
tmxMapInfo->setCurrentString(currentString);
}

View File

@ -250,9 +250,9 @@ class CC_DLL TMXMapInfo : public Ref, public SAXDelegator
{
public:
/** creates a TMX Format with a tmx file */
static TMXMapInfo* create(std::string_view tmxFile);
static TMXMapInfo* create(const std::string& tmxFile);
/** creates a TMX Format with an XML string and a TMX resource path */
static TMXMapInfo* createWithXML(std::string_view tmxString, std::string_view resourcePath);
static TMXMapInfo* createWithXML(const std::string& tmxString, const std::string& resourcePath);
/**
* @js ctor
@ -265,13 +265,13 @@ public:
virtual ~TMXMapInfo();
/** initializes a TMX format with a tmx file */
bool initWithTMXFile(std::string_view tmxFile);
bool initWithTMXFile(const std::string& tmxFile);
/** initializes a TMX format with an XML string and a TMX resource path */
bool initWithXML(std::string_view tmxString, std::string_view resourcePath);
bool initWithXML(const std::string& tmxString, const std::string& resourcePath);
/** initializes parsing of an XML file, either a tmx (Map) file or tsx (Tileset) file */
bool parseXMLFile(std::string_view xmlFilename);
bool parseXMLFile(const std::string& xmlFilename);
/* initializes parsing of an XML string, either a tmx (Map) string or tsx (Tileset) string */
bool parseXMLString(std::string_view xmlString);
bool parseXMLString(const std::string& xmlString);
ValueMapIntKey& getTileProperties() { return _tileProperties; };
void setTileProperties(const ValueMapIntKey& tileProperties) { _tileProperties = tileProperties; }
@ -353,14 +353,14 @@ public:
*/
void textHandler(void* ctx, const char* ch, size_t len) override;
std::string_view getCurrentString() const { return _currentString; }
void setCurrentString(std::string_view currentString) { _currentString = currentString; }
std::string_view getTMXFileName() const { return _TMXFileName; }
void setTMXFileName(std::string_view fileName) { _TMXFileName = fileName; }
std::string_view getExternalTilesetFileName() const { return _externalTilesetFilename; }
const std::string& getCurrentString() const { return _currentString; }
void setCurrentString(const std::string& currentString) { _currentString = currentString; }
const std::string& getTMXFileName() const { return _TMXFileName; }
void setTMXFileName(const std::string& fileName) { _TMXFileName = fileName; }
const std::string& getExternalTilesetFileName() const { return _externalTilesetFilename; }
protected:
void internalInit(std::string_view tmxFileName, std::string_view resourcePath);
void internalInit(const std::string& tmxFileName, const std::string& resourcePath);
/// map orientation
int _orientation;

View File

@ -109,10 +109,10 @@ TextFieldTTF::~TextFieldTTF() {}
// static constructor
//////////////////////////////////////////////////////////////////////////
TextFieldTTF* TextFieldTTF::textFieldWithPlaceHolder(std::string_view placeholder,
TextFieldTTF* TextFieldTTF::textFieldWithPlaceHolder(const std::string& placeholder,
const Vec2& dimensions,
TextHAlignment alignment,
std::string_view fontName,
const std::string& fontName,
float fontSize)
{
TextFieldTTF* ret = new TextFieldTTF();
@ -129,8 +129,8 @@ TextFieldTTF* TextFieldTTF::textFieldWithPlaceHolder(std::string_view placeholde
return nullptr;
}
TextFieldTTF* TextFieldTTF::textFieldWithPlaceHolder(std::string_view placeholder,
std::string_view fontName,
TextFieldTTF* TextFieldTTF::textFieldWithPlaceHolder(const std::string& placeholder,
const std::string& fontName,
float fontSize)
{
TextFieldTTF* ret = new TextFieldTTF();
@ -151,10 +151,10 @@ TextFieldTTF* TextFieldTTF::textFieldWithPlaceHolder(std::string_view placeholde
// initialize
//////////////////////////////////////////////////////////////////////////
bool TextFieldTTF::initWithPlaceHolder(std::string_view placeholder,
bool TextFieldTTF::initWithPlaceHolder(const std::string& placeholder,
const Vec2& dimensions,
TextHAlignment alignment,
std::string_view fontName,
const std::string& fontName,
float fontSize)
{
setDimensions(dimensions.width, dimensions.height);
@ -162,7 +162,7 @@ bool TextFieldTTF::initWithPlaceHolder(std::string_view placeholder,
return initWithPlaceHolder(placeholder, fontName, fontSize);
}
bool TextFieldTTF::initWithPlaceHolder(std::string_view placeholder, std::string_view fontName, float fontSize)
bool TextFieldTTF::initWithPlaceHolder(const std::string& placeholder, const std::string& fontName, float fontSize)
{
_placeHolder = placeholder;
@ -366,7 +366,7 @@ void TextFieldTTF::deleteBackward()
}
}
std::string_view TextFieldTTF::getContentText()
const std::string& TextFieldTTF::getContentText()
{
return _inputText;
}
@ -573,9 +573,9 @@ void TextFieldTTF::setString(std::string_view text)
_charCount = charCount;
}
void TextFieldTTF::appendString(std::string_view text)
void TextFieldTTF::appendString(const std::string& text)
{
insertText(text.data(), text.length());
insertText(text.c_str(), text.length());
}
void TextFieldTTF::makeStringSupportCursor(std::string& displayText)
@ -677,13 +677,13 @@ void TextFieldTTF::controlKey(EventKeyboard::KeyCode keyCode)
}
}
std::string_view TextFieldTTF::getString() const
const std::string& TextFieldTTF::getString() const
{
return _inputText;
}
// place holder text property
void TextFieldTTF::setPlaceHolder(std::string_view text)
void TextFieldTTF::setPlaceHolder(const std::string& text)
{
_placeHolder = text;
if (_inputText.empty() && !_isAttachWithIME)
@ -693,7 +693,7 @@ void TextFieldTTF::setPlaceHolder(std::string_view text)
}
}
std::string_view TextFieldTTF::getPlaceHolder() const
const std::string& TextFieldTTF::getPlaceHolder() const
{
return _placeHolder;
}
@ -733,7 +733,7 @@ void TextFieldTTF::setSecureTextEntry(bool value)
}
}
void TextFieldTTF::setPasswordTextStyle(std::string_view text)
void TextFieldTTF::setPasswordTextStyle(const std::string& text)
{
if (text.length() < 1)
{
@ -747,7 +747,7 @@ void TextFieldTTF::setPasswordTextStyle(std::string_view text)
}
}
std::string_view TextFieldTTF::getPasswordTextStyle() const
const std::string& TextFieldTTF::getPasswordTextStyle() const
{
return _passwordStyleText;
}

View File

@ -98,28 +98,28 @@ public:
/** Creates a TextFieldTTF from a fontname, alignment, dimension and font size.
* @js NA
*/
static TextFieldTTF* textFieldWithPlaceHolder(std::string_view placeholder,
static TextFieldTTF* textFieldWithPlaceHolder(const std::string& placeholder,
const Vec2& dimensions,
TextHAlignment alignment,
std::string_view fontName,
const std::string& fontName,
float fontSize);
/** Creates a TextFieldTTF from a fontname and font size.
* @js NA
*/
static TextFieldTTF* textFieldWithPlaceHolder(std::string_view placeholder,
std::string_view fontName,
static TextFieldTTF* textFieldWithPlaceHolder(const std::string& placeholder,
const std::string& fontName,
float fontSize);
/** Initializes the TextFieldTTF with a font name, alignment, dimension and font size. */
bool initWithPlaceHolder(std::string_view placeholder,
bool initWithPlaceHolder(const std::string& placeholder,
const Vec2& dimensions,
TextHAlignment alignment,
std::string_view fontName,
const std::string& fontName,
float fontSize);
/** Initializes the TextFieldTTF with a font name and font size. */
bool initWithPlaceHolder(std::string_view placeholder, std::string_view fontName, float fontSize);
bool initWithPlaceHolder(const std::string& placeholder, const std::string& fontName, float fontSize);
/**
*@brief Open keyboard and receive input text.
@ -183,26 +183,26 @@ public:
* Append to input text of TextField.
*@param text The append text of TextField.
*/
virtual void appendString(std::string_view text);
virtual void appendString(const std::string& text);
/**
* Query the input text of TextField.
*@return Get the input text of TextField.
*/
virtual std::string_view getString() const override;
virtual const std::string& getString() const override;
/**
* Change placeholder text.
* place holder text displayed when there is no text in the text field.
*@param text The placeholder string.
*/
virtual void setPlaceHolder(std::string_view text);
virtual void setPlaceHolder(const std::string& text);
/**
* Query the placeholder string.
*@return The placeholder string.
*/
virtual std::string_view getPlaceHolder() const;
virtual const std::string& getPlaceHolder() const;
/**
* Set enable secure text entry representation.
@ -211,8 +211,8 @@ public:
* @js NA
*/
virtual void setSecureTextEntry(bool value);
virtual void setPasswordTextStyle(std::string_view text);
std::string_view getPasswordTextStyle() const;
virtual void setPasswordTextStyle(const std::string& text);
const std::string& getPasswordTextStyle() const;
/**
* Query whether the currently display mode is secure text entry or not.
@ -260,7 +260,7 @@ protected:
virtual void didDetachWithIME() override;
virtual void insertText(const char* text, size_t len) override;
virtual void deleteBackward() override;
virtual std::string_view getContentText() override;
virtual const std::string& getContentText() override;
virtual void controlKey(EventKeyboard::KeyCode keyCode) override;
TextFieldDelegate* _delegate;

View File

@ -36,7 +36,7 @@ NS_CC_BEGIN
// implementation TileMapAtlas
TileMapAtlas* TileMapAtlas::create(std::string_view tile, std::string_view mapFile, int tileWidth, int tileHeight)
TileMapAtlas* TileMapAtlas::create(const std::string& tile, const std::string& mapFile, int tileWidth, int tileHeight)
{
TileMapAtlas* ret = new TileMapAtlas();
if (ret->initWithTileFile(tile, mapFile, tileWidth, tileHeight))
@ -48,7 +48,7 @@ TileMapAtlas* TileMapAtlas::create(std::string_view tile, std::string_view mapFi
return nullptr;
}
bool TileMapAtlas::initWithTileFile(std::string_view tile, std::string_view mapFile, int tileWidth, int tileHeight)
bool TileMapAtlas::initWithTileFile(const std::string& tile, const std::string& mapFile, int tileWidth, int tileHeight)
{
this->loadTGAfile(mapFile);
this->calculateItemsToRender();
@ -100,7 +100,7 @@ void TileMapAtlas::calculateItemsToRender()
}
}
void TileMapAtlas::loadTGAfile(std::string_view file)
void TileMapAtlas::loadTGAfile(const std::string& file)
{
std::string fullPath = FileUtils::getInstance()->fullPathForFilename(file);

View File

@ -59,7 +59,7 @@ public:
/** creates a TileMap with a tile file (atlas) with a map file and the width and height of each tile in points.
The tile file will be loaded using the TextureMgr.
*/
static TileMapAtlas* create(std::string_view tile, std::string_view mapFile, int tileWidth, int tileHeight);
static TileMapAtlas* create(const std::string& tile, const std::string& mapFile, int tileWidth, int tileHeight);
/**
* @js ctor
*/
@ -73,7 +73,7 @@ public:
/** initializes a TileMap with a tile file (atlas) with a map file and the width and height of each tile in points.
The file will be loaded using the TextureMgr.
*/
bool initWithTileFile(std::string_view tile, std::string_view mapFile, int tileWidth, int tileHeight);
bool initWithTileFile(const std::string& tile, const std::string& mapFile, int tileWidth, int tileHeight);
/**
* Returns a tile from position x,y.
*For the moment only channel R is used
@ -100,7 +100,7 @@ public:
void setTGAInfo(struct sImageTGA* TGAInfo) { _TGAInfo = TGAInfo; }
protected:
void loadTGAfile(std::string_view file);
void loadTGAfile(const std::string& file);
void calculateItemsToRender();
void updateAtlasValueAt(const Vec2& pos, const Color3B& value, int index);
void updateAtlasValues();

View File

@ -128,9 +128,9 @@ Animate3D* Animate3D::reverse() const
return animate;
}
Node* findChildByNameRecursively(Node* node, std::string_view childName)
Node* findChildByNameRecursively(Node* node, const std::string& childName)
{
std::string_view name = node->getName();
const std::string& name = node->getName();
if (name == childName)
return node;
@ -162,11 +162,11 @@ void Animate3D::startWithTarget(Node* target)
{
if (_animation)
{
auto& boneCurves = _animation->getBoneCurves();
const std::unordered_map<std::string, Animation3D::Curve*>& boneCurves = _animation->getBoneCurves();
for (const auto& iter : boneCurves)
{
std::string_view boneName = iter.first;
auto skin = sprite->getSkeleton();
const std::string& boneName = iter.first;
auto skin = sprite->getSkeleton();
if (skin)
{
auto bone = skin->getBoneByName(boneName);
@ -200,11 +200,11 @@ void Animate3D::startWithTarget(Node* target)
}
else
{
auto& boneCurves = _animation->getBoneCurves();
const std::unordered_map<std::string, Animation3D::Curve*>& boneCurves = _animation->getBoneCurves();
for (const auto& iter : boneCurves)
{
std::string_view boneName = iter.first;
Node* node = nullptr;
const std::string& boneName = iter.first;
Node* node = nullptr;
if (target->getName() == boneName)
node = target;
else

View File

@ -29,11 +29,11 @@
NS_CC_BEGIN
Animation3D* Animation3D::create(std::string_view fileName, std::string_view animationName)
Animation3D* Animation3D::create(const std::string& fileName, const std::string& animationName)
{
std::string fullPath = FileUtils::getInstance()->fullPathForFilename(fileName);
fullPath.append("#").append(animationName);
auto animation = Animation3DCache::getInstance()->getAnimation(fullPath);
std::string key = fullPath + "#" + animationName;
auto animation = Animation3DCache::getInstance()->getAnimation(key);
if (animation != nullptr)
return animation;
@ -50,7 +50,7 @@ Animation3D* Animation3D::create(std::string_view fileName, std::string_view ani
return animation;
}
bool Animation3D::initWithFile(std::string_view filename, std::string_view animationName)
bool Animation3D::initWithFile(const std::string& filename, const std::string& animationName)
{
std::string fullPath = FileUtils::getInstance()->fullPathForFilename(filename);
@ -59,8 +59,8 @@ bool Animation3D::initWithFile(std::string_view filename, std::string_view anima
Animation3DData animationdata;
if (bundle->load(fullPath) && bundle->loadAnimationData(animationName, &animationdata) && init(animationdata))
{
fullPath.append("#").append(animationName);
Animation3DCache::getInstance()->addAnimation(fullPath, this);
std::string key = fullPath + "#" + animationName;
Animation3DCache::getInstance()->addAnimation(key, this);
Bundle3D::destroyBundle(bundle);
return true;
}
@ -70,7 +70,7 @@ bool Animation3D::initWithFile(std::string_view filename, std::string_view anima
return false;
}
Animation3D::Curve* Animation3D::getBoneCurveByName(std::string_view name) const
Animation3D::Curve* Animation3D::getBoneCurveByName(const std::string& name) const
{
auto it = _boneCurves.find(name);
if (it != _boneCurves.end())
@ -199,7 +199,7 @@ void Animation3DCache::destroyInstance()
CC_SAFE_DELETE(_cacheInstance);
}
Animation3D* Animation3DCache::getAnimation(std::string_view key)
Animation3D* Animation3DCache::getAnimation(const std::string& key)
{
auto it = _animations.find(key);
if (it != _animations.end())
@ -207,14 +207,14 @@ Animation3D* Animation3DCache::getAnimation(std::string_view key)
return nullptr;
}
void Animation3DCache::addAnimation(std::string_view key, Animation3D* animation)
void Animation3DCache::addAnimation(const std::string& key, Animation3D* animation)
{
const auto& it = _animations.find(key);
if (it != _animations.end())
{
return; // already have this key
}
_animations.emplace(key, animation); //_animations[key] = animation;
_animations[key] = animation;
animation->retain();
}

View File

@ -69,7 +69,7 @@ public:
};
/**read all animation or only the animation with given animationName? animationName == "" read the first.*/
static Animation3D* create(std::string_view filename, std::string_view animationName = "");
static Animation3D* create(const std::string& filename, const std::string& animationName = "");
/**get duration*/
float getDuration() const { return _duration; }
@ -79,10 +79,10 @@ public:
*
* @lua NA
*/
Curve* getBoneCurveByName(std::string_view name) const;
Curve* getBoneCurveByName(const std::string& name) const;
/**get the bone Curves set*/
const hlookup::string_map<Curve*>& getBoneCurves() const { return _boneCurves; }
const std::unordered_map<std::string, Curve*>& getBoneCurves() const { return _boneCurves; }
CC_CONSTRUCTOR_ACCESS : Animation3D();
virtual ~Animation3D();
@ -90,10 +90,10 @@ public:
bool init(const Animation3DData& data);
/**init Animation3D with file name and animation name*/
bool initWithFile(std::string_view filename, std::string_view animationName);
bool initWithFile(const std::string& filename, const std::string& animationName);
protected:
hlookup::string_map<Curve*> _boneCurves; // bone curves map, key bone name, value AnimationCurve
std::unordered_map<std::string, Curve*> _boneCurves; // bone curves map, key bone name, value AnimationCurve
float _duration; // animation duration
};
@ -109,10 +109,10 @@ public:
static void destroyInstance();
/**get animation by key*/
Animation3D* getAnimation(std::string_view key);
Animation3D* getAnimation(const std::string& key);
/**add animation to cache*/
void addAnimation(std::string_view key, Animation3D* animation);
void addAnimation(const std::string& key, Animation3D* animation);
/**remove all animation*/
void removeAllAnimations();
@ -125,7 +125,7 @@ protected:
static Animation3DCache* _cacheInstance; // cache instance
hlookup::string_map<Animation3D*> _animations; // cached animations
std::unordered_map<std::string, Animation3D*> _animations; // cached animations
};
// end of 3d group

View File

@ -53,7 +53,7 @@ BillBoard* BillBoard::createWithTexture(Texture2D* texture, Mode mode)
return nullptr;
}
BillBoard* BillBoard::create(std::string_view filename, Mode mode)
BillBoard* BillBoard::create(const std::string& filename, Mode mode)
{
BillBoard* billboard = new BillBoard();
if (billboard->initWithFile(filename))
@ -66,7 +66,7 @@ BillBoard* BillBoard::create(std::string_view filename, Mode mode)
return nullptr;
}
BillBoard* BillBoard::create(std::string_view filename, const Rect& rect, Mode mode)
BillBoard* BillBoard::create(const std::string& filename, const Rect& rect, Mode mode)
{
BillBoard* billboard = new BillBoard();
if (billboard->initWithFile(filename, rect))

View File

@ -63,7 +63,7 @@ public:
* @param filename A path to image file, e.g., "scene1/monster.png"
* @return An autoreleased BillBoard object.
*/
static BillBoard* create(std::string_view filename, Mode mode = Mode::VIEW_POINT_ORIENTED);
static BillBoard* create(const std::string& filename, Mode mode = Mode::VIEW_POINT_ORIENTED);
/**
* Creates a BillBoard with an image filename and a rect.
@ -72,7 +72,7 @@ public:
* @param rect A subrect of the image file
* @return An autoreleased BillBoard object
*/
static BillBoard* create(std::string_view filename, const Rect& rect, Mode mode = Mode::VIEW_POINT_ORIENTED);
static BillBoard* create(const std::string& filename, const Rect& rect, Mode mode = Mode::VIEW_POINT_ORIENTED);
/**
* Creates a BillBoard with a Texture2D object.

View File

@ -169,7 +169,7 @@ void Bundle3D::clear()
}
}
bool Bundle3D::load(std::string_view path)
bool Bundle3D::load(const std::string& path)
{
if (path.empty())
return false;
@ -193,7 +193,7 @@ bool Bundle3D::load(std::string_view path)
}
else
{
CCLOG("warning: %s is invalid file formate", path.data());
CCLOG("warning: %s is invalid file formate", path.c_str());
}
ret ? (_path = path) : (_path = "");
@ -204,7 +204,7 @@ bool Bundle3D::load(std::string_view path)
bool Bundle3D::loadObj(MeshDatas& meshdatas,
MaterialDatas& materialdatas,
NodeDatas& nodedatas,
std::string_view fullPath,
const std::string& fullPath,
const char* mtl_basepath)
{
meshdatas.resetData();
@ -219,7 +219,7 @@ bool Bundle3D::loadObj(MeshDatas& meshdatas,
std::vector<tinyobj::shape_t> shapes;
std::vector<tinyobj::material_t> materials;
auto ret = tinyobj::LoadObj(shapes, materials, fullPath.data(), mtlPath.c_str());
auto ret = tinyobj::LoadObj(shapes, materials, fullPath.c_str(), mtlPath.c_str());
if (ret.empty())
{
// fill data
@ -329,11 +329,11 @@ bool Bundle3D::loadObj(MeshDatas& meshdatas,
return true;
}
CCLOG("warning: load %s file error: %s", fullPath.data(), ret.c_str());
CCLOG("warning: load %s file error: %s", fullPath.c_str(), ret.c_str());
return false;
}
bool Bundle3D::loadSkinData(std::string_view /*id*/, SkinData* skindata)
bool Bundle3D::loadSkinData(const std::string& /*id*/, SkinData* skindata)
{
skindata->resetData();
@ -347,7 +347,7 @@ bool Bundle3D::loadSkinData(std::string_view /*id*/, SkinData* skindata)
}
}
bool Bundle3D::loadAnimationData(std::string_view id, Animation3DData* animationdata)
bool Bundle3D::loadAnimationData(const std::string& id, Animation3DData* animationdata)
{
animationdata->resetData();
@ -1062,7 +1062,7 @@ bool Bundle3D::loadMaterialsJson(MaterialDatas& materialdatas)
}
return true;
}
bool Bundle3D::loadJson(std::string_view path)
bool Bundle3D::loadJson(const std::string& path)
{
clear();
@ -1084,7 +1084,7 @@ bool Bundle3D::loadJson(std::string_view path)
return true;
}
bool Bundle3D::loadBinary(std::string_view path)
bool Bundle3D::loadBinary(const std::string& path)
{
clear();
@ -1094,7 +1094,7 @@ bool Bundle3D::loadBinary(std::string_view path)
if (_binaryBuffer.isNull())
{
clear();
CCLOG("warning: Failed to read file: %s", path.data());
CCLOG("warning: Failed to read file: %s", path.c_str());
return false;
}
@ -1107,7 +1107,7 @@ bool Bundle3D::loadBinary(std::string_view path)
if (_binaryReader.read(sig, 1, 4) != 4 || memcmp(sig, identifier, 4) != 0)
{
clear();
CCLOG("warning: Invalid identifier: %s", path.data());
CCLOG("warning: Invalid identifier: %s", path.c_str());
return false;
}
@ -1127,7 +1127,7 @@ bool Bundle3D::loadBinary(std::string_view path)
if (_binaryReader.read(&_referenceCount, 4, 1) != 1)
{
clear();
CCLOG("warning: Failed to read ref table size '%s'.", path.data());
CCLOG("warning: Failed to read ref table size '%s'.", path.c_str());
return false;
}
@ -1141,7 +1141,7 @@ bool Bundle3D::loadBinary(std::string_view path)
_binaryReader.read(&_references[i].offset, 4, 1) != 1)
{
clear();
CCLOG("warning: Failed to read ref number %u for bundle '%s'.", i, path.data());
CCLOG("warning: Failed to read ref number %u for bundle '%s'.", i, path.c_str());
CC_SAFE_DELETE_ARRAY(_references);
return false;
}
@ -1460,7 +1460,7 @@ bool loadMaterialDataJson_0_2(MaterialData* /*materialdata*/)
return true;
}
bool Bundle3D::loadAnimationDataJson(std::string_view id, Animation3DData* animationdata)
bool Bundle3D::loadAnimationDataJson(const std::string& id, Animation3DData* animationdata)
{
std::string anim = "";
if (_version == "1.2" || _version == "0.2")
@ -1549,7 +1549,7 @@ bool Bundle3D::loadAnimationDataJson(std::string_view id, Animation3DData* anima
return true;
}
bool Bundle3D::loadAnimationDataBinary(std::string_view id, Animation3DData* animationdata)
bool Bundle3D::loadAnimationDataBinary(const std::string& id, Animation3DData* animationdata)
{
if (_version == "0.1" || _version == "0.2" || _version == "0.3" || _version == "0.4")
@ -1560,9 +1560,9 @@ bool Bundle3D::loadAnimationDataBinary(std::string_view id, Animation3DData* ani
else
{
// if id is not a null string, we need to add a suffix of "animation" for seeding.
std::string id_{id};
if (!id.empty())
id_.append("animation");
std::string id_ = id;
if (id != "")
id_ = id + "animation";
if (!seekToFirstType(BUNDLE_TYPE_ANIMATIONS, id_))
return false;
@ -1998,7 +1998,7 @@ NodeData* Bundle3D::parseNodesRecursivelyBinary(bool& skeleton, bool singleSprit
return nodedata;
}
backend::VertexFormat Bundle3D::parseGLDataType(std::string_view str, int size)
backend::VertexFormat Bundle3D::parseGLDataType(const std::string& str, int size)
{
backend::VertexFormat ret = backend::VertexFormat::INT;
if (str == "GL_BYTE")
@ -2097,7 +2097,7 @@ backend::VertexFormat Bundle3D::parseGLDataType(std::string_view str, int size)
return ret;
}
backend::SamplerAddressMode Bundle3D::parseSamplerAddressMode(std::string_view str)
backend::SamplerAddressMode Bundle3D::parseSamplerAddressMode(const std::string& str)
{
if (str == "REPEAT")
@ -2115,7 +2115,7 @@ backend::SamplerAddressMode Bundle3D::parseSamplerAddressMode(std::string_view s
}
}
NTextureData::Usage Bundle3D::parseGLTextureType(std::string_view str)
NTextureData::Usage Bundle3D::parseGLTextureType(const std::string& str)
{
if (str == "AMBIENT")
{
@ -2163,7 +2163,7 @@ NTextureData::Usage Bundle3D::parseGLTextureType(std::string_view str)
return NTextureData::Usage::Unknown;
}
}
shaderinfos::VertexKey Bundle3D::parseGLProgramAttribute(std::string_view str)
shaderinfos::VertexKey Bundle3D::parseGLProgramAttribute(const std::string& str)
{
if (str == "VERTEX_ATTRIB_POSITION")
{
@ -2233,14 +2233,14 @@ shaderinfos::VertexKey Bundle3D::parseGLProgramAttribute(std::string_view str)
}
}
void Bundle3D::getModelRelativePath(std::string_view path)
void Bundle3D::getModelRelativePath(const std::string& path)
{
ssize_t index = path.find_last_of('/');
std::string fullModelPath;
_modelPath = path.substr(0, index + 1);
}
Reference* Bundle3D::seekToFirstType(unsigned int type, std::string_view id)
Reference* Bundle3D::seekToFirstType(unsigned int type, const std::string& id)
{
// for each Reference
for (unsigned int i = 0; i < _referenceCount; ++i)
@ -2266,7 +2266,7 @@ Reference* Bundle3D::seekToFirstType(unsigned int type, std::string_view id)
return nullptr;
}
std::vector<Vec3> Bundle3D::getTrianglesList(std::string_view path)
std::vector<Vec3> Bundle3D::getTrianglesList(const std::string& path)
{
std::vector<Vec3> trianglesList;

View File

@ -64,32 +64,32 @@ public:
* get define data type
* @param str The type in string
*/
static backend::VertexFormat parseGLDataType(std::string_view str, int size);
static backend::VertexFormat parseGLDataType(const std::string& str, int size);
/**
* get define data type
* @param str The type in string
*/
static backend::SamplerAddressMode parseSamplerAddressMode(std::string_view str);
static backend::SamplerAddressMode parseSamplerAddressMode(const std::string& str);
/**
* load a file. You must load a file first, then call loadMeshData, loadSkinData, and so on
* @param path File to be loaded
* @return result of load
*/
virtual bool load(std::string_view path);
virtual bool load(const std::string& path);
/**
* load skin data from bundle
* @param id The ID of the skin, load the first Skin in the bundle if it is empty
*/
virtual bool loadSkinData(std::string_view id, SkinData* skindata);
virtual bool loadSkinData(const std::string& id, SkinData* skindata);
/**
* load material data from bundle
* @param id The ID of the animation, load the first animation in the bundle if it is empty
*/
virtual bool loadAnimationData(std::string_view id, Animation3DData* animationdata);
virtual bool loadAnimationData(const std::string& id, Animation3DData* animationdata);
// since 3.3, to support reskin
virtual bool loadMeshDatas(MeshDatas& meshdatas);
@ -102,21 +102,21 @@ public:
* load triangle list
* @param path the file path to load
*/
static std::vector<Vec3> getTrianglesList(std::string_view path);
static std::vector<Vec3> getTrianglesList(const std::string& path);
// load .obj file
static bool loadObj(MeshDatas& meshdatas,
MaterialDatas& materialdatas,
NodeDatas& nodedatas,
std::string_view fullPath,
const std::string& fullPath,
const char* mtl_basepath = nullptr);
// calculate aabb
static AABB calculateAABB(const std::vector<float>& vertex, int stride, const std::vector<unsigned short>& index);
protected:
bool loadJson(std::string_view path);
bool loadBinary(std::string_view path);
bool loadJson(const std::string& path);
bool loadBinary(const std::string& path);
bool loadMeshDatasJson(MeshDatas& meshdatas);
bool loadMeshDataJson_0_1(MeshDatas& meshdatas);
bool loadMeshDataJson_0_2(MeshDatas& meshdatas);
@ -137,8 +137,8 @@ protected:
bool loadMaterialDataJson(MaterialData* materialdata);
bool loadMaterialDataJson_0_1(MaterialData* materialdata);
bool loadMaterialDataJson_0_2(MaterialData* materialdata);
bool loadAnimationDataJson(std::string_view id, Animation3DData* animationdata);
bool loadAnimationDataBinary(std::string_view id, Animation3DData* animationdata);
bool loadAnimationDataJson(const std::string& id, Animation3DData* animationdata);
bool loadAnimationDataBinary(const std::string& id, Animation3DData* animationdata);
/**
* load nodes of json
@ -156,26 +156,26 @@ protected:
* get define data type
* @param str The type in string
*/
NTextureData::Usage parseGLTextureType(std::string_view str);
NTextureData::Usage parseGLTextureType(const std::string& str);
/**
* get vertex attribute type
* @param str The type in string
*/
shaderinfos::VertexKey parseGLProgramAttribute(std::string_view str);
shaderinfos::VertexKey parseGLProgramAttribute(const std::string& str);
/*
* get model path
* @param str Full path of model file
*/
void getModelRelativePath(std::string_view path);
void getModelRelativePath(const std::string& path);
/*
* set the read position in buffer to the target type
* @param The data type
* @param The data id
*/
Reference* seekToFirstType(unsigned int type, std::string_view id = "");
Reference* seekToFirstType(unsigned int type, const std::string& id = "");
CC_CONSTRUCTOR_ACCESS : Bundle3D();
virtual ~Bundle3D();

View File

@ -220,21 +220,21 @@ struct SkinData
rootBoneIndex = -1;
}
void addSkinBoneNames(std::string_view name)
void addSkinBoneNames(const std::string& name)
{
auto it = std::find(skinBoneNames.begin(), skinBoneNames.end(), name);
if (it == skinBoneNames.end())
skinBoneNames.push_back(std::string{name});
skinBoneNames.push_back(name);
}
void addNodeBoneNames(std::string_view name)
void addNodeBoneNames(const std::string& name)
{
auto it = std::find(nodeBoneNames.begin(), nodeBoneNames.end(), name);
if (it == nodeBoneNames.end())
nodeBoneNames.push_back(std::string{name});
nodeBoneNames.push_back(name);
}
int getSkinBoneNameIndex(std::string_view name) const
int getSkinBoneNameIndex(const std::string& name) const
{
int i = 0;
for (const auto& iter : skinBoneNames)
@ -246,7 +246,7 @@ struct SkinData
return -1;
}
int getBoneNameIndex(std::string_view name) const
int getBoneNameIndex(const std::string& name) const
{
int i = 0;
for (const auto& iter : skinBoneNames)
@ -323,7 +323,7 @@ struct MaterialDatas
{
std::vector<NMaterialData> materials;
void resetData() { materials.clear(); }
const NMaterialData* getMaterialData(std::string_view materialid) const
const NMaterialData* getMaterialData(const std::string& materialid) const
{
for (const auto& it : materials)
{

View File

@ -228,7 +228,7 @@ Mesh* Mesh::create(const std::vector<float>& vertices,
return create("", indexData);
}
Mesh* Mesh::create(std::string_view name, MeshIndexData* indexData, MeshSkin* skin)
Mesh* Mesh::create(const std::string& name, MeshIndexData* indexData, MeshSkin* skin)
{
auto state = new Mesh();
state->autorelease();
@ -255,7 +255,7 @@ bool Mesh::isVisible() const
return _visible;
}
void Mesh::setTexture(std::string_view texPath)
void Mesh::setTexture(const std::string& texPath)
{
_texFile = texPath;
auto tex = Director::getInstance()->getTextureCache()->addImage(texPath);
@ -307,7 +307,7 @@ void Mesh::setTexture(Texture2D* tex, NTextureData::Usage usage, bool cacheFileN
}
}
void Mesh::setTexture(std::string_view texPath, NTextureData::Usage usage)
void Mesh::setTexture(const std::string& texPath, NTextureData::Usage usage)
{
auto tex = Director::getInstance()->getTextureCache()->addImage(texPath);
setTexture(tex, usage);
@ -350,7 +350,7 @@ void Mesh::setMaterial(Material* material)
if (_material->getTechnique()->getName().compare(technique->getName()) == 0)
{
auto program = pass->getProgramState()->getProgram();
auto attributes = program->getActiveAttributes();
auto& attributes = program->getActiveAttributes();
auto meshVertexData = _meshIndexData->getMeshVertexData();
auto attributeCount = meshVertexData->getMeshVertexAttribCount();
CCASSERT(attributes.size() <= attributeCount, "missing attribute data");

View File

@ -83,7 +83,7 @@ public:
* create mesh
* @lua NA
*/
static Mesh* create(std::string_view name, MeshIndexData* indexData, MeshSkin* skin = nullptr);
static Mesh* create(const std::string& name, MeshIndexData* indexData, MeshSkin* skin = nullptr);
/**
* get vertex buffer
@ -109,7 +109,7 @@ public:
* call setTexture(texPath, NTextureData::Usage::Diffuse)
* @param texPath texture path
*/
void setTexture(std::string_view texPath);
void setTexture(const std::string& texPath);
/**
* set texture (diffuse), which is responsible for the main appearance. It is also means main texture, you can also
* call setTexture(texPath, NTextureData::Usage::Diffuse)
@ -128,7 +128,7 @@ public:
* @param texPath texture path
* @param usage Usage of this texture
*/
void setTexture(std::string_view texPath, NTextureData::Usage usage);
void setTexture(const std::string& texPath, NTextureData::Usage usage);
/**
* Get texture (diffuse), which is responsible for the main appearance. It is also means main texture, you can also
* call getTexture(NTextureData::Usage::Diffuse)
@ -168,7 +168,7 @@ public:
backend::ProgramState* getProgramState() const;
/**name getter */
std::string_view getName() const { return _name; }
const std::string& getName() const { return _name; }
void setBlendFunc(const BlendFunc& blendFunc);
const BlendFunc& getBlendFunc() const;
@ -225,7 +225,7 @@ public:
/**Mesh index data setter*/
void setMeshIndexData(MeshIndexData* indexdata);
/**name setter*/
void setName(std::string_view name) { _name = name; }
void setName(const std::string& name) { _name = name; }
/**
* calculate the AABB of the mesh

View File

@ -75,7 +75,7 @@ Bone3D* MeshSkin::getBoneByIndex(unsigned int index) const
return nullptr;
}
Bone3D* MeshSkin::getBoneByName(std::string_view id) const
Bone3D* MeshSkin::getBoneByName(const std::string& id) const
{
// search from skin bones
for (const auto& it : _skinBones)

View File

@ -54,7 +54,7 @@ class CC_DLL MeshSkin : public Ref
public:
/**create a new meshskin if do not want to share meshskin*/
static MeshSkin* create(Skeleton3D* skeleton, std::string_view filename, std::string_view name);
static MeshSkin* create(Skeleton3D* skeleton, const std::string& filename, const std::string& name);
static MeshSkin* create(Skeleton3D* skeleton,
const std::vector<std::string>& boneNames,
@ -65,7 +65,7 @@ public:
/**get bone*/
Bone3D* getBoneByIndex(unsigned int index) const;
Bone3D* getBoneByName(std::string_view id) const;
Bone3D* getBoneByName(const std::string& id) const;
/**get bone index*/
int getBoneIndex(Bone3D* bone) const;

View File

@ -49,7 +49,7 @@ using namespace std;
NS_CC_BEGIN
/////////////////////////////////////////////////////////////////////////////////////////////////////////////
MeshIndexData* MeshIndexData::create(std::string_view id,
MeshIndexData* MeshIndexData::create(const std::string& id,
MeshVertexData* vertexData,
backend::Buffer* indexbuffer,
const AABB& aabb)
@ -160,7 +160,7 @@ MeshVertexData* MeshVertexData::create(const MeshData& meshdata)
return vertexdata;
}
MeshIndexData* MeshVertexData::getMeshIndexDataById(std::string_view id) const
MeshIndexData* MeshVertexData::getMeshIndexDataById(const std::string& id) const
{
for (auto it : _indexs)
{

View File

@ -55,7 +55,7 @@ class CC_DLL MeshIndexData : public Ref
{
public:
/** create */
static MeshIndexData* create(std::string_view id,
static MeshIndexData* create(const std::string& id,
MeshVertexData* vertexData,
backend::Buffer* indexbuffer,
const AABB& aabb);
@ -74,8 +74,8 @@ public:
const AABB& getAABB() const { return _aabb; }
/** id setter and getter */
void setId(std::string_view id) { _id = id; }
std::string_view getId() const { return _id; }
void setId(const std::string& id) { _id = id; }
const std::string& getId() const { return _id; }
/**primitive type setter & getter*/
MeshCommand::PrimitiveType getPrimitiveType() const { return _primitiveType; }
@ -128,7 +128,7 @@ public:
/** get index data by index */
MeshIndexData* getMeshIndexDataByIndex(int index) const { return _indexs.at(index); }
/** get index data by id */
MeshIndexData* getMeshIndexDataById(std::string_view id) const;
MeshIndexData* getMeshIndexDataById(const std::string& id) const;
ssize_t getSizePerVertex() const { return _sizePerVertex; }

View File

@ -61,7 +61,7 @@ MotionStreak3D* MotionStreak3D::create(float fade,
float minSeg,
float stroke,
const Color3B& color,
std::string_view path)
const std::string& path)
{
MotionStreak3D* ret = new MotionStreak3D();
if (ret && ret->initWithFade(fade, minSeg, stroke, color, path))
@ -87,7 +87,7 @@ MotionStreak3D* MotionStreak3D::create(float fade, float minSeg, float stroke, c
return nullptr;
}
bool MotionStreak3D::initWithFade(float fade, float minSeg, float stroke, const Color3B& color, std::string_view path)
bool MotionStreak3D::initWithFade(float fade, float minSeg, float stroke, const Color3B& color, const std::string& path)
{
CCASSERT(!path.empty(), "Invalid filename");

View File

@ -57,7 +57,11 @@ public:
* @param path The texture file name of stoke.
* @return An autoreleased MotionStreak3D object.
*/
static MotionStreak3D* create(float fade, float minSeg, float stroke, const Color3B& color, std::string_view path);
static MotionStreak3D* create(float fade,
float minSeg,
float stroke,
const Color3B& color,
const std::string& path);
/** Creates and initializes a motion streak with fade in seconds, minimum segments, stroke's width, color, texture.
*
* @param fade The fade time, in seconds.
@ -160,7 +164,7 @@ public:
/** initializes a motion streak with fade in seconds, minimum segments, stroke's width, color and texture filename
*/
bool initWithFade(float fade, float minSeg, float stroke, const Color3B& color, std::string_view path);
bool initWithFade(float fade, float minSeg, float stroke, const Color3B& color, const std::string& path);
/** initializes a motion streak with fade in seconds, minimum segments, stroke's width, color and texture */
bool initWithFade(float fade, float minSeg, float stroke, const Color3B& color, Texture2D* texture);

Some files were not shown because too many files have changed in this diff Show More