cocos2dx - PageView

Cocos2dx PageView 可以使用翻页的效果

 创建PageView:

Size size(150, 130);
PageView* pageView = PageView::create();
pageView->setDirection(PageView::Direction::HORIZONTAL);
pageView->setContentSize(size);
Size backgroundSize = bg->getContentSize();
pageView->setPosition(Vec2(origin.x+ 10,origin.y+50));
pageView->removeAllItems();
pageView->setIndicatorEnabled(true);
pageView->setGlobalZOrder(200);
this->addChild(pageView);

初始化数据:

int pageCount = 4;
for (int i = 0; i < pageCount; ++i)
{
    Layout* layout = Layout::create();
    layout->setContentSize(size);

    ImageView* imageView = ImageView::create("YellowSquare.png");
    imageView->setScale9Enabled(true);
    imageView->setContentSize(size);
    imageView->setPosition(Vec2(layout->getContentSize().width / 2.0f, layout->getContentSize().height / 2.0f));
    layout->addChild(imageView);

    Text* label = Text::create(StringUtils::format("page %d",(i)), "fonts/Marker Felt.ttf", 30);
    label->setColor(Color3B(192, 192, 192));
    label->setPosition(Vec2(layout->getContentSize().width / 2.0f, layout->getContentSize().height / 2.0f));
    layout->addChild(label);
    pageView->insertCustomItem(layout, i);

}
pageView->setIndicatorIndexNodesOpacity(255);

添加翻页监听:

pageView->addEventListener([this,pageView](Ref *sender, PageView::EventType type) {
    switch (type) {
        case cocos2d::ui::PageView::EventType::TURNING:
            int pageIndex = pageView->getCurrentPageIndex();
            break;
    }
});

效果图如下:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值