Cocos2d-x 3.0截屏功能集成

转载 2014年08月23日 11:29:09
3.0的截屏和2.x的截屏基本上相同,都是利用RenderTexture来处理,在渲染之前调用call函数,然后调用Cocos的场景visit函数对其进行渲染,渲染结束后调用end函数即可。只是3.0截屏需要在截完屏的下一帧才能处理RenderTexture,这点要注意。关于2.x的RenderTexture的API和demo可以参见http://blog.csdn.net/jackystudio/article/details/15498083

本文的重点在于如何将截图功能继承到Cocos2d-x 3.0引擎。



  

1.集成到Director
这里选择把截屏功能继承到Director中,让全局的导演来执行截屏功能是一个很好的主意。
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
void Director::saveScreenshot(const std::string& fileName,const std::function<void(const std::string&)>& callback)
{
    Image::Format format;
    //进行后缀判断
    if(std::string::npos != fileName.find_last_of(".")){
        auto extension = fileName.substr(fileName.find_last_of("."),fileName.length());
        if (!extension.compare(".png")) {
            format = Image::Format::PNG;
        } else if(!extension.compare(".jpg")) {
            format = Image::Format::JPG;
        } else{
            CCLOG("cocos2d: the image can only be saved as JPG or PNG format");
            return;
        }
    } else {
        CCLOG("cocos2d: the image can only be saved as JPG or PNG format");
        return ;
    }
   //获取屏幕尺寸,初始化一个空的渲染纹理对象
    auto renderTexture = RenderTexture::create(getWinSize().width, getWinSize().height, Texture2D::PixelFormat::RGBA8888);
   //清空并开始获取
    renderTexture->beginWithClear(0.0f, 0.0f, 0.0f, 0.0f);
   //遍历场景节点对象,填充纹理到RenderTexture中
    getRunningScene()->visit();
   //结束获取
    renderTexture->end();
   //保存文件
    renderTexture->saveToFile(fileName , format);
   //使用schedule在下一帧中调用callback函数
    auto fullPath = FileUtils::getInstance()->getWritablePath() + fileName;
    auto scheduleCallback = [&,fullPath,callback](float dt){
        callback(fullPath);
    };
    auto _schedule = getRunningScene()->getScheduler();
    _schedule->schedule(scheduleCallback, this, 0.0f,0,0.0f, false, "screenshot");
}

2.如何使用saveScreenshot
截屏功能使用起来也很简单,直接调用saveSecreenshot,其中第一个参数为文件名(支持png和jpg格式,不带后缀名默认为png格式),第二个参数为回调函数,你可以在回调函数中处理这个文件。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
void ScreenshotTest::saveImage(Ref *pSender){
    static int counter = 0;
     
    char png[20];
    sprintf(png, "image-%d.png", counter);
    char jpg[20];
    sprintf(jpg, "image-%d.jpg", counter);
     
   //截屏后的回调函数,这里显示在左下角
    auto callback = [&](const std::string& fullPath){
        auto sprite = Sprite::create(fullPath);
        CCASSERT(sprite!=nullptr, "Failed to create sprite.");
        addChild(sprite);
        sprite->setScale(0.3f);
        sprite->setPosition(Point(40, 40));
        sprite->setRotation(counter * 3);
        CCLOG("Image saved %s", fullPath.c_str());
    };
     
   //调用Director的截屏功能
    Director::getInstance()->saveScreenshot(png, callback);
    counter++;
}

3.源码下载
该功能已提交pull request到Cocos2d-x Github上了,有需求的童鞋们可以自己集成了。源码具体可以参见:https://github.com/cocos2d/cocos2d-x/pull/5978

Cocos2d-x 3.0截屏功能集成

Cocos2d-x 3.0截屏功能集成 偶尔e网事2014-07-10 12:06:59249 次阅读 3.0的截屏和2.x的截屏基本上相同,都是利用RenderTexture来处...
  • dj0379
  • dj0379
  • 2014年07月13日 16:02
  • 1458

【玩转cocos2d-x之三十九】Cocos2d-x 3.0截屏功能集成

3.0的截屏和2.x的截屏基本上相同,都是利用RenderTexture来处理,在渲染之前调用call函数,然后调用Cocos的场景visit函数对其进行渲染,渲染结束后调用end函数即可。只是3.0...
  • jackyvincefu
  • jackyvincefu
  • 2014年04月17日 21:24
  • 5345

比较Cocos2d-x v2.x与v3.x的截图功能

(1)Cocos2d-x 2.x Cocos2d-x 2.x没有提供截图功能,但是可以用CCRenderTexture来实现这个功能: 1 2 3 ...
  • Kaitiren
  • Kaitiren
  • 2014年09月04日 14:06
  • 3419

AS截屏的类的使用方法+示例

1.首先先引入两个swc(aether,as3corelib) http://code.google.com/p/aether/ http://code.google.com/p/as3corel...
  • xiaoxin888888
  • xiaoxin888888
  • 2011年10月18日 19:22
  • 2189

cocos2d-x 3.0 final 截屏

文章转载 http://www.cocoachina.com/bbs/read.php?tid=196339 1.集成到Director 这里选择把截屏功能继承到Director中,让全局...
  • leelyn
  • leelyn
  • 2014年07月15日 13:23
  • 415

cocos2d-x使用OpenGL获取屏幕截图

今天就来说说cocos2d-x中使用OpenGL获取屏幕截图吧,因为网上关于cocos2d-x的入门教程非常多,所以我就只写一些用cocos2d-x实现具体功能的文章跟大家分享啦~ 截图在游戏中经常会...
  • guochuanqi
  • guochuanqi
  • 2013年12月07日 20:06
  • 2980

Cocos2d-x 截图功能

(1)Cocos2d-x 2.x Cocos2d-x 2.x没有提供截图功能,但是可以用CCRenderTexture来实现这个功能: void CTestLayer::SaveScree...
  • w174504744
  • w174504744
  • 2014年09月03日 17:44
  • 3900

cocos2d-x 打开url 和 截屏功能

cocos2d-x不支持跨平台打开一个url,  所以我们分别要在 iOS 和 Android 上单写。   iOS端: 1.新建一个cocos2dx项目,在项目中创建一个.mm的文件,命名为 O...
  • hj3601947
  • hj3601947
  • 2015年09月14日 15:07
  • 436

cocos2d-x中截屏的方法、保存图片,以及使用截屏作为背景实例

cocos2d-x中截屏的方法、保存图片,以及使用截屏作为背景实例
  • qq_32319583
  • qq_32319583
  • 2016年11月29日 17:50
  • 659

比较Cocos2d-x 2.x版本与3.x版本屏幕截图的两种方式

(1)使用RenderTexture:这是在2.x版本时最常用的的截图方法。 (2)使用utils::captureScreen() :在3.2版本中新增的截图方法。 Rend...
  • LB0621
  • LB0621
  • 2016年01月19日 15:19
  • 184
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Cocos2d-x 3.0截屏功能集成
举报原因:
原因补充:

(最多只允许输入30个字)