鼠标悬停在按钮上延时响应OnMouseHover、OnMouseMove和OnMouseLeave

本文介绍如何在MFC程序中创建一个按钮,并通过鼠标悬停事件实现在按钮上停留一秒后自动打开指定网址的功能。具体步骤包括:创建MFC程序、添加按钮、定制按钮类、设置按钮变量、添加并实现OnMouseHover等消息处理函数。

1.建立MFC程序

2.添加按钮,IDC_BUTTON1

3.添加类,直接右键控件时无法添加CButton的派生类的,如果想添加的话,只能选中项目根,右键添加类,MFC类-->MFC类向导-->选择继承CButton。

4.添加变量,选中按钮,右键添加变量,mbt1,类型为CBtn//没有这个变量是不行的,我试了n次都没有成功,缺少这个没有反应

5.打开类向导,在类CBtn下添加消息OnMouseHover、OnMouseMove和OnMouseLeave

6.在btn.h中public下添加bool m_bTracking;

在btn.cpp中在类的构造函数中添加m_bTracking=0;//初始化,添加的消息对应如下,实现的功能是当光标在按钮上悬停1后打开网页:

void CBtn::OnMouseHover(UINT nFlags, CPoint point)
{
// TODO: 在此添加消息处理程序代码和/或调用默认值
ShellExecute(0, NULL, _T("http://hao.360.cn"), NULL, NULL, SW_NORMAL);
    m_bTracking = false;
CButton::OnMouseHover(nFlags, point);
}

void CBtn::OnMouseMove(UINT nFlags, CPoint point)
{
// TODO: 在此添加消息处理程序代码和/或调用默认值
if (!m_bTracking)
    {
        TRACKMOUSEEVENT tme;
        tme.cbSize = sizeof(TRACKMOUSEEVENT);
        tme.dwFlags =TME_HOVER;//要触发的消息
        tme.hwndTrack = this->m_hWnd;
        tme.dwHoverTime = 1000;// 若不设此参数,则无法触发mouseHover
        if (::_TrackMouseEvent(&tme)) //MOUSELEAVE|MOUSEHOVER消息由此函数触发
        {
//::_TrackMouseEvent(&tme);
            m_bTracking = true;   
       }
    }
CButton::OnMouseMove(nFlags, point);
}

void CBtn::OnMouseLeave()
{
// TODO: 在此添加消息处理程序代码和/或调用默认值
m_bTracking = false;
CButton::OnMouseLeave();
}

参考http://blog.chinaunix.net/uid-26275986-id-3877610.html

在 Vue.js 2.x 中,你可以利用 Vue 的响应式特性以及 CSS 的 `:hover` 伪类来实现这个功能。这里是一个简单的示例,假设你有一个包含两个组件的结构,一个父组件(`ParentComponent.vue`)拥有一个子组件(`ChildComponent.vue`),子组件的某个 div 需要在父组件的 div 上鼠标悬停时显示: **ParentComponent.vue** ```html <template> <div class="parent-div"> <child-component :show-child-on-hover="hoverState"></child-component> </div> </template> <script> import ChildComponent from './ChildComponent.vue'; export default { components: { ChildComponent }, data() { return { hoverState: false, }; }, methods: { onMouseHover() { this.hoverState = true; }, onMouseLeave() { this.hoverState = false; }, }, mounted() { // 添加鼠标悬停事件监听 document.addEventListener('mouseover', this.onMouseHover); // 添加鼠标离开事件监听 document.addEventListener('mouseleave', this.onMouseLeave); }, beforeDestroy() { // 移除事件监听,防止内存泄漏 document.removeEventListener('mouseover', this.onMouseHover); document.removeEventListener('mouseleave', this.onMouseLeave); }, }; </script> ``` **ChildComponent.vue** ```html <template> <div v-if="parent.hoverState" class="child-div"> <!-- 子元素内容 --> </div> </template> <script> export default { props: ['showChildOnHover'], }; </script> ``` 在这个例子中,当用户将鼠标悬停在 `.parent-div` 上时,`onMouseHover` 方法会被触发,更新 `hoverState` 为 `true`,进而显示子组件的 `.child-div`。反之,当鼠标离开 `.parent-div` 时,`onMouseLeave` 方法会使 `hoverState` 回到 `false`,隐藏 `.child-div`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值