android 仿qq修改头像,Qt:小项目仿QQ修改头像界面,技术点记录

最近写了一个修改头像功能的UI,布局参考了QQ目前的修改头像界面。如下图

b473eab996188b6e4a717259f14eeaf3.png

这里主要说明一下两个地方的技术:1.头像图片上层的遮罩层,圆形外部为灰色,内部为全透明;2.上传图片宽高比例可以通过鼠标拖拽移动图片显示并通过滑动条进行图片大小放缩

遮罩层说明

遮罩层的处理主要在于怎么在一个透明灰色窗口上擦除出一个透明的圆形。之前使用了QPainter::CompositionMode里面的QPainter::CompositionMode_Clear擦除模式,但是试验后结果是,对于顶层窗口(没有父窗口)的效果是OK的,但是针对这里以显示图片的滚动区域窗口为父窗口的遮罩层,擦除只会变成完全的黑色。

重新考虑之后想到了ClipPath,剪切的绘图路径,通过在QPainterPath里增加路径获取一个剪切路径,再设置给QPainter,即可达到需要的效果,关键代码如下

m_pDivWidget->resize(ui.scrollArea->size());

QPainterPath path;

path.addRect(m_pDivWidget->geometry());

path.addEllipse(m_pDivWidget->geometry().adjusted(2, 2, -2, -2));

QPainter p(m_pDivWidget);

p.setRenderHint(QPainter::Antialiasing);

p.setBrush(QColor(100, 100, 100, 200));

p.setClipPath(path);

p.drawRect(m_pDivWidget->geometry());

如果不想子类化QWidget,可以在父窗口里注册过滤事件,捕获遮罩层的绘图事件来重绘遮罩层QEvent::Paint == event->type()。

拖拽滚动窗口

其实简单说就是拖拽来模拟滚动条拖拽的效果,拖拽的距离和滚动区域内展示窗口的大小比例,再结合滚动条的当前值可以算出滚动条应该更新的值。代码如下

DragScrollArea::DragScrollArea(QWidget *parent)

: QScrollArea(parent)

{

//首先,关闭显示所有滚动条

setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);

setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff);

}

DragScrollArea::~DragScrollArea()

{

}

bool DragScrollArea::event(QEvent* event)

{

if (widget())//没有滚动窗口的时候,不处理

{

static QPoint pos;//记录拖拽位置

if (QEvent::MouseButtonPress == event->type())

{

//开始拖拽

QMouseEvent* mouseEvent = static_cast(event);

pos = mouseEvent->pos();

}

else if (QEvent::MouseMove == event->type())

{

QMouseEvent* mouseEvent = static_cast(event);

if (Qt::LeftButton & mouseEvent->buttons())

{

//计算偏移量

pos = mouseEvent->pos() - pos;

//根据偏移量算出当前滚动条更新的值

horizontalScrollBar()->setValue(horizontalScrollBar()->value() - pos.x()*horizontalScrollBar()->maximum() / widget()->width());

verticalScrollBar()->setValue(verticalScrollBar()->value() - pos.y()*verticalScrollBar()->maximum() / widget()->height());

pos = mouseEvent->pos();

}

}

}

return QScrollArea::event(event);

}

最终效果如图

529e7241e80bac44345de05155b6c849.png

项目代码地址,界面重新做了简单调整

https://github.com/KaiMingPrince/QtProject/tree/master/ChangeHeader

Qt小项目之串口助手控制LED

Qt小项目之串口助手控制LED 前言 最近刚学了一点Qt开发上位机,尝试着做个小软件练练手.查找了很多资料,做了一个简单的串口助手,可以实现串口基本发送和接收功能,支持中文显示,还可以控制STM32开 ...

仿QQ空间动态界面分享

先看看效果: 用极少的代码实现了 动态详情 及 二级评论 的 数据获取与处理 和 UI显示与交互,并且高解耦.高复用.高灵活. 动态列表界面MomentListFragment支持 下拉刷新与上拉加载 ...

android 仿QQ气泡聊天界面

1.现在的QQ,微信等一些APP的聊天界面都是气泡聊天界面,左边是接收到的消息,右边是发送的消息, 这个效果其实就是一个ListView在加载它的Item的时候,分别用了不同的布局xml文件. 2.效 ...

day75 bbs项目☞后台管理+修改头像

目录 一.后台管理之添加文章 二.修改用户头像 bbs项目总结 一.后台管理之添加文章 添加文章有两个需要注意的问题: 文章的简介切取,应该想办法获取到当前文章的文本内容后再截取字符 XSS攻击,由于 ...

巧妙的Jq仿QQ游戏导航界面学习

先贴上源代码

仿QQ好友列表界面的实现

TableView有2种style:UITableViewStylePlain 和 UITableViewStyleGrouped. 但是QQ好友列表的tableView给人的感觉似乎是2个style ...

Qt小程序仿写----FileRead程序

该程序实现如下功能:1.打开TXT文件A.txt:2.将文件路径显示到一个文本编辑框里面,文件内容显示到一个文本域里面:3.在文本域里面更改文件内容之后,保存文本域的内容到当前文件路径下. 定义了一F ...

小程序仿QQ侧滑例子

缩放:wxml

对比iOS网络组件:AFNetworking VS ASIHTTPRequest(转载)

在开发iOS应用过程中,如何高效的与服务端API进行数据交换,是一个常见问题.一般开发者都会选择一个第三方的网络组件作为服务,以提高开发效率和稳定性.这些组件把复杂的网络底层操作封装成友好的类和方法, ...

1021 Fibonacci Again (hdoj)

Problem Description There are another kind of Fibonacci numbers: F(0) = 7, F(1) = 11, F(n) = F(n-1) ...

poj3308 Paratroopers --- 最小点权覆盖->最小割

题目是一个非常明显的二分图带权匹配模型, 加入源点到nx建边,ny到汇点建边,(nx.ny)=inf建边.求最小割既得最小点权覆盖. 在本题中因为求的是乘积,所以先所有取log转换为加法,最后再乘方回 ...

【Python之路】第一篇--Linux基础命令

pwd 命令 查看”当前工作目录“的完整路径 pwd -P # 显示出实际路径,而非使用连接(link)路径:pwd显示的是连接路径 .   表示当前目录 ..  表示上级目录 /  表示根目录 ls ...

sql的一点总结<一>

sql总结 1.常见的数据库对象有哪些?表(table) 视图(view) 序列(sequence) 索引(index) 同义词(synonym)存储过程(procedure) 存储函数(functi ...

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值