使用QGridLayout布局实现翻页效果

使用QGridLayout布局实现翻页效果

好长时间没有写博客了,今天抽点时间做点笔记。前端时间刚好有这个需求,对QGridLayout布局实现翻页效果,效果是这样的?

这里写图片描述

上图中是一个点餐系统的菜谱演示效果图。其中使用的布局就是QGridLayout,它的每一个元素都是一个自定义的widget,自定义的widget里边实现了菜谱照片和价格以及名称的显示。

网格布局的实现

还是直接看代码,代码一看就会懂的。

    //创建菜谱列表,并进行网格布局
    for (int i = 0; i < PER_PAGE_COUNT; i++)
    {
        AbstractMenuWidget *w = new AbstractMenuWidget(m_iconList.at(i),
                                                       m_textList.at(i),
                                                       m_priceList.at(i));
        m_menu_list.append(w);
        connect(w,SIGNAL(signalAddMenu()),m_PSignalMapper,SLOT(map()));
        m_PSignalMapper->setMapping(w,m_textList.at(i));
        m_pMainLayout->addWidget(w,i/PER_ROW_COUNT,i%PER_COLUMN_COUNT);
    }

翻页效果的实现

其实在做翻页之前也想过要换其他方式去实现的。真不知道该怎么解决,想过重新删除m_pMainLayout,在翻页的时候重新初始化,但是发现菜谱的布局会发生变化,和自己想想的不太一致,随后一想,这是肯定的,前后两连个不是一个布局了肯定会乱的。最后想到的是在翻页之前删除m_pMainLayout所指向的布局中的元素,然后重新添加,虽然办法有点笨,不过还好是实现了。

删除部分的关键代码如下所示:

//清除layout中的内容
void MenuWidget::removeLayout()
{
    while (m_pMainLayout->count() > 0)
    {
        QWidget *w = m_pMainLayout->itemAt(0)->widget();
        m_pMainLayout->removeWidget(w);
        delete w;
    }
}

上面的代码用在按钮点击切换的时候调用即可。

完整的系统样式是这样的

这里写图片描述

由于服务器那边没有开启所以好多功能都不能操作。

技术在于交流、分享……
博客地址:http://blog.csdn.net/u013704336\
Email:kevinlq0912@163.com
QQ:936563422
  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值