duilib进阶教程 -- 改进List控件_优化支持多选拉伸 (2)

上篇博客写完,以为改进List达到了项目要求,可后来发现诱发了其他的问题,如滚动条部分功能失效,还有程序在运行一段时间后进入了无响应状态。

后来在以下三个方向进行了探索:

1 主要改进还是在DrawItemText 函数中,试图解决由此引起的Bug

结果:不能解决掉,但证明duilib是可以实现的,只是思路和方法还没有找对。

       DrawItemText 本来的作用是重绘Text文本,在这里调用setpos,会引起其父控件重绘,父控件重绘又会调用DoPaint,有循环调用,程序很容易崩掉。思路不对。

2 重写DoPaint函数

结果:只能对其一级子控件进行背景,文本的重绘,没有诱发其他Bug ,但很难实现一级子控件及它的子控件一起重绘。

        思路: 由于CListContainerElementUI继承于CContainerUI,原来只是在最后调用了父类的DoPaint,根据CContainerUI::DoPaint(hDC, rcPaint);源码进行修改,每列的宽度可以得到,所以子控件的可以根据头部的宽度重绘。

3 重写SetPos函数

结果:这次终于完美解决,上张图,呵呵!

       思路:以前两种方案,仍旧掉在CListTextElementUI实现思路的坑里。整理思路CListContainerElementUI中的每一列可以是一个简单控件,也可以是一个容器控件,所以只是在DoPaint里做文章,无法满足要求。SetPos既然可以实现容器控件的位置,宽高的改变,那为什么不重写SetPos呢,拿来CContainerUI的SetPos,进行重写。

上代码

 

void CListContainerElementUI::SetPos(RECT rc)
{
if( m_pOwner == NULL ) return;
TListInfoUI* pInfo = m_pOwner->GetListInfo();
int iChangeIndex=0;
LONG cx = 0;
for( int i = 0; i < pInfo->nColumns; i++ )
{
CControlUI* pControl = GetItemAt(i);
if(!pControl) break;
RECT rcOldItem = pControl->GetPos();
if(pInfo->rcColumn[i].right-rcOldItem.right!=0){
iChangeIndex =i;
cx=pInfo->rcColumn[i].right-rcOldItem.right;
break;

}


}
RECT rcNew = {rc.left,rc.top,rc.right+cx,rc.bottom};
CControlUI::SetPos(rcNew);
if( m_items.IsEmpty() ) return;
rcNew.left += m_rcInset.left;
rcNew.top += m_rcInset.top;
rcNew.right -= m_rcInset.right;
rcNew.bottom -= m_rcInset.bottom;


for( int it = 0; it < m_items.GetSize(); it++ ) {
CControlUI* pControl = static_cast<CControlUI*>(m_items[it]);
if( !pControl->IsVisible() ) continue;
if( pControl->IsFloat() ) {
if(it>=iChangeIndex){
RECT rcItem = { pInfo->rcColumn[it].left, m_rcItem.top, pInfo->rcColumn[it].right, m_rcItem.bottom };
pControl->SetPos(rcItem);
}
}
else {
pControl->SetPos(rcNew); // 所有非float子控件放大到整个客户区
}
}
}

 

总结:这么点功能,折腾了好几日,修改的代码并不多,究其原因:1、对Duilib的源码没理解透,原来只是那控件来用,这次是扩展控件 2、思路没有发散出去。不过通过这几天的折腾,对好多东西又有了深刻的认识。

欢迎指点,等有时间把Demo上传到csdn上。

其实早就上传到csdn了,支持未把地址贴出了,看到有很多留了言,贴出来吧,虽然有点晚了,看到还有很多人在研究这个。

https://download.csdn.net/download/xdrt81y/6909699

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 58
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 58
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值