Merge pull request #14766 from chengstory/Update3.10ReleaseNote

[ci skip]Update cocos2d-x 3.10 Release note.
This commit is contained in:
pandamicro 2015-12-31 15:27:14 +08:00
commit 13b3611a1c
1 changed files with 173 additions and 208 deletions

View File

@ -2,7 +2,8 @@
<!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE --> <!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->
**Table of Contents** *generated with [DocToc](https://github.com/thlorenz/doctoc)* **Table of Contents** *generated with [DocToc](https://github.com/thlorenz/doctoc)*
- [Cocos2d-x 3.9 Release Notes](#cocos2d-x-39-release-notes) - [Cocos2d-x 3.10 Release Notes](#cocos2d-x-
- -release-notes)
- [Misc Information](#misc-information) - [Misc Information](#misc-information)
- [Requirements](#requirements) - [Requirements](#requirements)
- [Runtime Requirements](#runtime-requirements) - [Runtime Requirements](#runtime-requirements)
@ -14,18 +15,18 @@
- [Windows](#windows) - [Windows](#windows)
- [Linux](#linux) - [Linux](#linux)
- [How to start a new game](#how-to-start-a-new-game) - [How to start a new game](#how-to-start-a-new-game)
- [v3.9](#v39) - [v3.10](#v310)
- [Highlights features, improvements and API updates of v3.9](#highlights-features-improvements-and-api-updates-of-v39) - [Highlights features, improvements and API updates of v3.10](#highlights-features-improvements-and-api-updates-of-v310)
- [The main features in detail of Cocos2d-x v3.9:](#the-main-features-in-detail-of-cocos2d-x-v39) - [The main features in detail of Cocos2d-x v3.10:](#the-main-features-in-detail-of-cocos2d-x-v310)
- [3D Module](#3d-module) - [UI System](#ui-system)
- [2D Module](#2d-module) - [AudioEngine](#audioengine)
- [Others](#others) - [Others](#others)
- [Other changes](#other-changes) - [Other changes](#other-changes)
- [NEW APIS](#new-apis) - [NEW APIS](#new-apis)
<!-- END doctoc generated TOC please keep comment here to allow auto update --> <!-- END doctoc generated TOC please keep comment here to allow auto update -->
# Cocos2d-x 3.9 Release Notes # # Cocos2d-x 3.10 Release Notes #
# Misc Information # Misc Information
@ -146,287 +147,251 @@ Use Cocos Console to create a new game:
cocos new -l cpp|js|lua MyNewGame cocos new -l cpp|js|lua MyNewGame
``` ```
# v3.9 # v3.10
## Highlights features, improvements and API updates of v3.9 ## Highlights features, improvements and API updates of v3.10
We are happy to announce the release of Cocos2d-x v3.9. Following are the highlighted features, improvements and API updates in this version. We are happy to announce the release of Cocos2d-x v3.10. Following are the highlighted features, improvements and API updates in this version.
1. 3D Module: 1. UI System:
- Added 3D MotionStreak to support streak effect. - Reimplemented Scale9Sprite and improve the scale9sprite performance and reduce memory consumption.
- Refined Sprite3D to support material system. - Changed PageView to derived from ListView, PageView can be added any widget as child.
2. 2D Module: - Added three overflow type to new label: CLAMPSHRINKRESIZE_HEIGHT.
- Added frame callback function and animation callback function. 2. JSModule:
- Added script component system. - Improved JS bindings with more secured memory management, and enhance the stability of the engine, streamline all JSB code with the [GC coding style of SpiderMonkey](https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey/GC_Rooting_Guide).
- Reconstruction of 2D physics with Component.
- Improved EditBox implemention on iOS and Win32 platform.
- Removed dependence of libcurl on AssetsManager, AssetsManagerEx and Downloader (iOS & Android).
- Improved particle performance.
3. Others:
- Supported Action inheritance, update function overwriting in JSB.
- Improved ScrollView performance in Web engine.
- Improved Scale9Sprite performance in Web engine.
- Decoupled Sprite's setTexture and updateColor in Web engine.
- Added support for debugging and release on real devices with Xcode7 and iOS9.
## The main features in detail of Cocos2d-x v3.9: ## The main features in detail of Cocos2d-x v3.10:
### 3D Module ### UI System
1. 3D MotionStreak 1. Reimplemented Scale9Sprite and improve the scale9sprite performance and reduce memory consumption.
In this version, 3D MotionStreak is added to support streak effect. Check the testcase: [Sprite3DTest](https://github.com/cocos2d/cocos2d-x/blob/v3/tests/cpp-tests/Classes/Sprite3DTest/Sprite3DTest.cpp#L2472) to see how to use it. Reimplemented ui::Scale9Sprite, now the Slice sprite uses 16 vertices and 54 indices instead of the old 9 sprites way, The memory consumption is much lower than the previous implementation, and it is also more efficient.
2. Sprite3D In SIMPLE mode, the 4 borders are all 0 and the whole sprite will scale horizontally and vertically. In this mode only 1 quad is used for rendering, for example:
Added Sprite3D material class. It will be easy and convenient to create internal material. auto blocks = ui::Scale9Sprite::createWithSpriteFrameName("blocks9c.png");
//When setting to SIMPLE, only 4 vertexes is used to rendering.
blocks->setRenderingType(Scale9Sprite::RenderingType::SIMPLE);
### 2D Module In SLICE mode, it will use 18 triangles to rendering the slice 9 sprite. If the 4 borders are 0, there still be 18 triangles computed. So choose your RenderingType wisely, for example:
1. Frame callback function and animation callback function auto sprite = ui::Scale9Sprite::createWithSpriteFrameName("blocks9c.png");
//When setting to SLICE, 16 vertexes will be used to rendering.
sprite->setRenderingType(Scale9Sprite::RenderingType::SLICE);
Three interfaces are added in ActionTimelineData class, which are addFrameEndCallFunc, removeFrameEndCall and clearFrameEndCalls. It will be easy to add or remove specific frame event. 2. Changed PageView to derived from ListView, PageView can add any type of widget as child.
2. Script Component PageView was derived from Layout and it implemented the features of scrolling and item arrangement from scratch. But the features are already there in ListView. So remove those duplicated implementations from PageView and make it inherit from ListView.
Script component is used to extend c++ Nodes. You can add a script component to a Node, then the script component will receive onEnter,onExit and update events. For example: By consequence, PageView becomes simpler and easier to maintain because it considers only paging implementation. for example:
```c++ // Create the page view
// create a sprite and add a lua component auto player = Size size(240, 130);
Sprite::create("player.png"); PageView* pageView = PageView::create();
pageView->setDirection(PageView::Direction::HORIZONTAL);
pageView->setContentSize(size);
Size backgroundSize = background->getContentSize();
//"removeAllPages" is changed to "removeAllItems"
pageView->removeAllItems();
pageView->setIndicatorEnabled(true);
auto luaComponent = ComponentLua::create("player.lua"); int pageCount = 4;
player->addComponent(luaComponent); for (int i = 0; i < pageCount; ++i)
``` {
Layout* layout = Layout::create();
layout->setContentSize(size);
```lua ImageView* imageView = ImageView::create("cocosui/scrollviewbg.png");
// player.lua imageView->setScale9Enabled(true);
local player = { imageView->setContentSize(size);
onEnter = function(self) imageView->setPosition(Vec2(layout->getContentSize().width / 2.0f, layout->getContentSize().height / 2.0f));
-- do some things in onEnter layout->addChild(imageView);
end
onExit = function(slef) Text* label = Text::create(StringUtils::format("page %d",(i+1)), "fonts/Marker Felt.ttf", 30);
-- do some things in onExit label->setColor(Color3B(192, 192, 192));
end label->setPosition(Vec2(layout->getContentSize().width / 2.0f, layout->getContentSize().height / 2.0f));
layout->addChild(label);
update = function(self) //"insertPage" is changed to "insertCustomItem"
-- do some things every frame pageView->insertCustomItem(layout, i);
end
} }
//"removePageAtIndex" is changed to "removeItem"
pageView->removeItem(0);
//"scrollToPage" is changed to "scrollToItem"
pageView->scrollToItem(pageCount - 2);
-- it is needed to return player to let c++ nodes know it More detail usage please refer to: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIPageViewTest/UIPageViewTest.cpp.
return player
```
Javascript can work as the same way, just use ComponentJS instead of ComponentLua.
There are some differences between lua component and Javascript component:
Should return the object in lua component, in Javascript, you only have to extend cc.ComponentJS, and ensure the result of the last statement is the class of Component.
Lua component can only be used in lua projects, Javascript component can only be used in Javascript projects.
More detail usage please refer to: `tests/lua-tests/src/ComponentTest` and `tests/js-tests/src/ComponentTest`
3. 2D Physics 3. Added three overflow type to new label: CLAMP, SHRINK, RESIZE_HEIGHT.
Before v3.9, there are many physics related codes in Node, such as Node::setPhysicsBody(). Since v3.9, we move these codes into physics component. Overflow type is used to control label overflow result, In SHRINK mode, the font size will change dynamically to adapt the content size. In CLAMP mode, when label content goes out of the bounding box, it will be clipped, In RESIZE_HEIGHT mode, you can only change the width of label and the height is changed automatically. For example:
After using physics component, the way to use physics is changed. Before v3.9, you can use physics like this: //Change the label's Overflow type
label->setOverflow(Label::Overflow::RESIZE_HEIGHT);
``` More detail usage please refer to: tests/cpp-tests/Classes/LabelTest/LabelTestNew.cpp.
auto node = Node::create();
node->setPhysicsBody(PhysicsBody::createEdgeBox(...));
```
Since v3.9 you should use like this: Limitations:
```
auto node = Node::create();
node->addComponent(PhysicsBody::createEdgeBox(...));
```
4. EditBox implemention on iOS and Win32 platform
- Specify the maximum number of characters in the dialog box.
- Support password input.
- Games will continue when the dialogue box pops up.
- Sync the content in dialogue box.
5. Remove dependence of curl on AssetsManager, AssetsManagerEx and Downloader (iOS & Android)
From v3.9, iOS and Android version will not depend on libcurl, which make
the game package smaller and solve some bugs caused by libcurl. Stability has
been improved with the updated iOS and Android system.
6. Improved particle performance.
### Others
1. Supported Action inheritance, update function overwriting in JSB
In previous version of JSB, developers cannot inherit Action class in JS script, such as Action / ActionInterval / ActionInstant, for their update function will not be called. In v3.9, developers can create subclass of Action and make extensions. More detail usage please refer to the textcase in ActionTest / ActionCustomTest.
2. ScrollView performance on Web engine
ScrollView and ListView are the popular UI controls in Web engine. Their
performance is not perfect in previous versions, especially when there are multiple sub-controls. In v3.9, we have improved its rendering performance. They only act on the contents displayed on the current screen. Test
date shows that, comparing with v3.8, rendering efficiency of v3.9 have been improved for twice to four times in different devices and browsers.
3. Scale9Sprite performance on Web engine
In this version, we have changed the way to construct 9-slice sprite. The engine uses 9 rendering commands instead of the 9 nodes in previous versions. This helps to reduce memory usage and improve rendering performance.
4. Decoupled Sprite's setTexture and updateColor in Web engine.
- Organized the rendering logic in Sprite. UpdateColor is accomplished by texture instead of the Sprite.
- Fixed a bug about image with alpha channel that when the image is set to black, there is color difference between previous and current version.
- Improved texture update logic to reduce texture updates when changing colors.
- Improved the logic about the rendering function in SpriteCanvasRenderCmd.
- Removed some duplicate codes about updateColor.
5. Support for debugging and release on real devices with Xcode7 and iOS9
In v3.8.1, we have made it possible to debug on Xcode7. However, there was a bug with iOS9 real device debuging, and in v3.9, we have fixed the bug.
currently only TTF and BMFont support all the valid Overflow type. Char Map font supports all the Overflow type except for SHRINK, because we can't measure its font size. System font only support Overflow::Normal and Overflow::RESIZE_HEIGHT.
## Other changes ## Other changes
[NEW] RichText supported new line element.
[NEW] Label: Added line spacing/leading feature to Label. [NEW] UIText::clone supports clone the text effect.
[NEW] ListView: Added APIs to scroll to specific item in list. [NEW] UI: Added methods to query label effect state.
[NEW] ListView: Added APIs to get an item in specific position like center, leftmost, rightmost, topmost and bottommost. [REFINE] IOS: Added virtual keyword for some render related function.
[NEW] ListView: Added a feature for magnetic scrolling. [REFINE] UI: Fixed boring deprecated warning in HttpRequest.
[NEW] Animate: Added ActionTimeline::setAnimationEndCallBack and ActionTimeline::addFrameEndCallFunc. [REFINE] Network: Fixed Downloader bug on iOS & Android platform.
[NEW] Animate: Added CSLoader::createNodeWithVisibleSize, CSLoader::createNodeWithVisibleSize and moved "ui::Helper::DoLayout" into them. [REFINE] Studio: Fixed deprecation warning in SkeletonRenderer.
[NEW] Stuio: Added support for Cocos Studio Light3D. [REFINE] JS: Added js test case for fix, improve template.
[NEW] Platform: Added the missing CURL support to the Windows 10 UWP version. [REFINE] Network: Permit http access to cocos2d-x.org in test projects on iOS.
[NEW] Platform: Added UIEditBox support on linux platform. [REFINE] Network: Crash when removing a remotely downloaded image from texture
cache in js-binding.
[REFINE] 3D: Added non-null checks in PUScriptCompiler::visit before dereferencing. [REFINE] Win10: WinRT project update version to v3.10.
[REFINE] 3D: Refined SkyboxBrush by making the shader parameter take effect at once. [REFINE] Console: Added quiet option for Cocos Toolkit.
[REFINE] Label: Changed label font size type to float to support high precision when font size is small. [REFINE] JS: New GC model for js-binding.
[REFINE] ListView: Fixed an issue that list view's Magnetic::CENTER is not working well when non-bounceable. [REFINE] Doc: Fixed typos in documentation and comments.
[REFINE] ListView: Added feature of jumping to a specific item in list view. [REFINE] UI: Updated controlButton size calculate with new Scale9Sprite logic.
[REFINE] Sprite: Added a "unsupport image format!" log when creating a sprite in CCImage.cpp. [REFINE] Win10: Added missing _USRJSSTATIC preprocessor define for ARM builds.
[REFINE] ScrollView: Merge logics of Scroll View for scroll by inertia and auto scroll into one. [REFINE] JS: Added ccvector_to / ccmap_to converted to new js-binding API.
[REFINE] Animate: Moved initialization of image to an appropriate location, because it always called twice in [REFINE] UI: Slider misprint fix.
SpriteFrameCache::addSpriteFramesWithFile().
[REFINE] Simulator: Changed the size of startFlag to 13. [FIX] Core: Fixed premultiplyAlpha for mipmaps and compressed textures.
[REFINE] Simulator: Show Node and Skeleton in the middle of the simulator. [FIX] UI: Fixed Scale9sprite rendering error when content size smaller than the sum of leftInset and rightInset.
[REFINE] Simulator: Removed screen direction check in simulator to avoid render error. [FIX] Win32: Fixed EditBox crash when removing an EditBox in a scheduler.
[REFINE] Pysics: Refined components to improve physics performance. [FIX] Android: Fixed cannot add view to mFrameLayout when extends Cocos2dxActivity.
[REFINE] UI: Refined ComponentContainer to improve performance. [FIX] 2D: Fixed actionNode set at wrong position bug.
[REFINE] UI: EventListenerMouse will dispatch EventMouse events. [FIX] 3D: Fixed the movement of PUParticle lags one frame.
[REFINE] OpenGL: Added check for glfwCreateWindow. [FIX] UI: Fixed the wront argument of setPlaceholderFontName in EditBox.
[REFINE] Platform: Fixed a crash on xiaomi2 if Cocos2d-x is built as a dynamic library. [FIX] UI: Fixed EditBox editBoxEditingDidEnd may use the original text after change the text of EditBox in user script.
[REFINE] Platform: Updated libcococs2d name to v3.9 on WinRT platforms. [FIX] Audio: Fixed `FinishCallback` never be called in Windows.
[REFINE] Platform: Added some support for mouse on WinRT. Include: Show/Hide mouse cursor; Mouse event [FIX] UI: Fixed Layout stencil clipping nested with Clipping Node rendering issue.
implemented similar Desktop version; Left button send mouse event and touch; Support other mouse button and scroll
wheel.
[REFINE] Platform: Correct the convertion between unicode and utf8 on WinRT. [FIX] UI: Keyboard doesn't hide when click the screen outside of EditBox on iOS platform.
[REFINE] Platform: Improved EditBox implement on Win32 platform. [FIX] UI: Fixed a fatal bug in EditBox implement on Windows platform.
[REFINE] JS: Add jsb.fileUtils.writeDataToFile(). [FIX] UI: Fixed edit box setPlaceholderFontName and scale font size issue.
[REFINE] JS: Set js templates Mac target platform from null to 10.7. [FIX] Core: Fixed memory leak when initWithImage() failed.
[REFINE] JS: Removed the static define of variable in headfile of ScriptingCore. [FIX] Network: CCDownloader on iOS is broken in v3.9 js-binding.
[REFINE] Lua: Added AssetsManagerEx constants UPDATE_FAILED and ERROR_DECOMPRESS in Lua. [FIX] JS: Bindings fixes for Menu, Sprite and Label.
[REFINE] Lua / JS: Refined lua/js binding tool. [FIX] Studio: Removed weak reference in ActionNode.
[REFINE] I/O: Refined AssetsManagerEx unzipping by using async. [FIX] UI: shouldStartLoading method should return value to js in js-binding.
[REFINE] Web: Improved logic of jsb_boot.js to sync with the web engine behavior. [FIX] UI: Fixed scrollview render error.
[REFINE] Web: Sync with CCBoot for web. [FIX] JS: Fixed win32 js project crash issue.
[REFINE] Build: Fixed various compiler warnings on Xcode 7. [FIX] UI: Button touch doesn't work with scale9 enabled.
[REFINE] Build: Fixed Wformat-security warning on Xcode. [FIX] JS: Fixed evalString doesn't return result issue.
[REFINE] Build: Fixed a compile error in __LayerRGBA. [FIX] JS: Fixed ComponentJS proxy management issue in JSB.
[REFINE] Tool: Added tools for generating documents automatically. [FIX] Android: Fixed include in cocos network module.
[REFINE] Doc: Clean up the code of setRect() function. [FIX] Network: Fixed web socket crash.
[REFINE] Doc: Fixed a minor typo and renamed INTIAL_CAPS_ALL_CHARACTERS to INITIAL_CAPS_ALL_CHARACTERS [FIX] UI: Fixed TextField missing default password style text setting.
in UIEditBox.
[TEST] S9SpriteTest: Scale9Sprite fade actions with cascade opacity.
[TEST] Web: Removed default focus block from UIFocusTestVertical.
[TEST] Lua: Fixed pageViewTest Horizontal scroll won't work in Lua-test.
You can also take a look at the [full changelog](https://github.com/cocos2d/cocos2d-x/blob/v3/CHANGELOG). You can also take a look at the [full changelog](https://github.com/cocos2d/cocos2d-x/blob/v3/CHANGELOG).
## NEW APIS ## NEW APIS
1. JSB Module 1. RichText
Added jsb.fileUtils.writeDataToFile Added RichElementNewLine class to create new RichText Element.
2. Sprite3D For more information: [https://github.com/cocos2d/cocos2d-x/pull/14033](https://github.com/cocos2d/cocos2d-x/pull/14033 "https://github.com/cocos2d/cocos2d-x/pull/14033")
Added Sprite3Dmaterial class to make it easy to create innate material. 2. PageViewIndicator
3. ActionTimelineData Added PageViewIndicator class to create PageViewIndicator.
Three interfaces are added in ActionTimelineData class, which are addFrameEndCallFunc, removeFrameEndCall and clearFrameEndCalls. For more information: [https://github.com/cocos2d/cocos2d-x/blob/v3/cocos/ui/UIPageViewIndicator.h](https://github.com/cocos2d/cocos2d-x/blob/v3/cocos/ui/UIPageViewIndicator.h "https://github.com/cocos2d/cocos2d-x/blob/v3/cocos/ui/UIPageViewIndicator.h")
4. ActionTimeline::removeFrameEndCallFunc 3. PageView
5. Improvements for ListView Changed PageView to derived from ListView.
For more information: [https://github.com/cocos2d/cocos2d-x/pull/14252](https://github.com/cocos2d/cocos2d-x/pull/14252 "https://github.com/cocos2d/cocos2d-x/pull/14252")
- Add APIs to scroll to specific item in list. 4. ApplicationProtocol
- Add APIs to get an item in specific position like center, leftmost, rightmost, topmost and bottommost.
- Add a feature for magnetic scrolling.
For more information: https://github.com/cocos2d/cocos2d-x/pull/13723 Added the API getVersion.
6. Node
Added the missing API getChildByTag 5. PolygonInfo
7. Label Added the API setTriangles.
Added setLineSpacing, getLineSpacing 6. Scale9Sprite
8. CSLoader Added setRenderingType, getRenderingType.
Added createNodeWithVisibleSize, createNodeWithVisibleSize 9. FontFNT
9. ComponentContainer
Removed isEmpty Added setFontSize, getOriginalFontSize.
10. Sprite 10. Label
Added setBMFontSize, getBMFontSize, enableWrap, isWrapEnabled, setOverflow, getOverflow, initWithTTF, isShadowEnabled, getShadowOffset, getShadowBlurRadius, getShadowColor, getOutlineSize, getLabelEffectType, getEffectColor.
11. AudioEngineImpl
Added AudioEngineImpl to implement FMOD.
12. Lua Module
Added luaval_to_node, node_to_luaval.
13. JS Module
Added js_cocos2dx_ComponentJS_create
14. ui::Text
Added isShadowEnabled, getShadowOffset, getShadowBlurRadius, getShadowColor, getOutlineSize, getLabelEffectType, getEffectColor.
15. UITextTest_Clone
Added UITextTest_Clone class.
Removed debugDraw(bool on)