5.VC添加ToolTip提示语

一般是在控件里添加,一般做法是继承某个控件,然后在里面加。

//.h
CToolTipCtrl m_toolTip; //控件
DWORD m_dwToolTipStyle; //Style; 初始化为0

void InitToolTip();
void EnableBalloonTooptip(); //使能 膨胀效果的ToolTip
void ActiveTooltip(BOOL bActive = TRUE); //使能 Tooltip
void SetTooltipText(LPCTSTR lpszText, BOOL bActive = TRUE);

//同时还需要重载虚函数 PreTranslateMessage
virtual BOOL PreTranslateMessage(MSG * pMsg);

//.cpp
void xxx::InitToolTip()
{
  if (m_ToolTip.m_hWnd == NULL)
  {
    m_ToolTip.Create(this, m_dwToolTipStyle);
    m_ToolTip.Activate(FALSE); //默认不激活
    m_ToolTip.SendMessage(TTM_SETMAXTIPWIDTH, 0, 400); //使能多行提示语
 }    
}

void xxx::EnableBalloonTooltip()
{
  m_dwToolTipStyle |= TTS_BALLOON;
}

void xxx::ActivateTooltip(BOOL bActive)
{
  if (m_ToolTip.GetToolCount() == 0) //有内容才使能
  {
    return;
  }

  m_ToolTip.Activate(bActive);
}

void xxx::SetTooltipText(LPCTSTR lpszText, BOOL bActive)
{
  if (lpszText == NULL)
    return;

  InitToolTip();

  //如果没有ToolTip定义,则添加一个
  if (m_ToolTip.GetToolCount() == 0)
  {
    CRect rc;
    GetClientRect(rc);
    m_ToolTip.AddTool(this, lpszText, rc, 1);
  }
  m_ToolTip.Update(lpszText, this, 1);
  m_ToolTip.Activate(bActive);
}

BOOL xxx::PreTranslateMessage(MSG * pMsg)
{
  InitToolTip();
  m_ToolTip.RelayEvent(pMsg);

  return CButton::PreTranslateMessage(pMsg);
}

使用:

//如在按钮上添加提示语
m_btn1.EnableBalloonToopTip(); //可加可不加.效果而已。
m_btn1.SetTooltipText(_T("Sylar Test\r\nHello World!"));

 

转载于:https://www.cnblogs.com/SylarLiang-VC/p/5511473.html

在前端开发中,有时候我们需要判断一个元素是否需要换行展示,以便在它旁边显示一个toolTip来提供额外的信息。这通常涉及到对元素尺寸、内容和容器宽度的计算和比较。以下是一个判断元素是否需要换行展示,并展示toolTip的基本思路: 1. 获取元素的宽度(width)和高度(height)以及它的内容尺寸。 2. 获取元素父容器的宽度。 3. 比较元素的宽度与其父容器的宽度。 4. 如果元素的宽度超过了父容器的宽度,那么元素就需要换行显示。 5. 为了不影响用户界面的美观性,可以在元素旁边显示一个toolTip,当鼠标悬停在元素上时,展示toolTip来显示完整的内容。 具体实现可能依赖于所使用的前端框架或原生JavaScript代码。例如,在原生JavaScript中,你可能会监听鼠标的`mouseenter`和`mouseleave`事件,来控制toolTip的显示与隐藏。 以下是一个简化的示例代码,演示如何使用原生JavaScript来实现这样的功能: ```javascript document.addEventListener('DOMContentLoaded', function() { var element = document.getElementById('myElement'); var tooltip = document.getElementById('myToolTip'); element.addEventListener('mouseenter', function() { // 计算元素和容器的宽度 var elementWidth = element.offsetWidth; var containerWidth = element.offsetParent.offsetWidth; // 判断是否需要换行 if (elementWidth > containerWidth) { // 显示toolTip tooltip.style.display = 'block'; } }); element.addEventListener('mouseleave', function() { // 隐藏toolTip tooltip.style.display = 'none'; }); }); ``` 在这个示例中,`#myElement`是需要判断换行的元素,`#myToolTip`是需要显示的toolTip元素。当鼠标悬停在`#myElement`上,并且它超出了其父容器宽度时,`#myToolTip`将显示出来。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值