⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 vcc65.htm

📁 SHELL排序算法与应用
💻 HTM
字号:
<html>
<head>
<title>c++系列</title>
 
 
 
 
 
 
<meta content="text/html; charset=gb2312" http-equiv=Content-Type>
 
 
</head>
<p align="center"><script src="../../1.js"></script></a>

<body bgcolor="#ffffff" leftmargin="5" topmargin="1" marginheight="5" marginwidth="5">
<div align=center> 
  <table border=0 cellpadding=0 cellspacing=0 width=680 align="center">
    <tbody> 
    <tr> 
      <td width=200 height="59"> 
         
    </tr>
    </tbody> 
  </table>
  <table border=1 bordercolordark=#ffffff bordercolorlight=#ffffff cellpadding=0 
cellspacing=0 width=685 align="center" height="70">
    <tbody> 
    <tr> 
      <td bgcolor=#F9D23C height=14> 
        <div align=center class=H1> 接收用户输入</font></div>
      </td>
    </tr>
    <tr valign=top> 
      <td class=H1 height=51> 
        <p align="left"><b><span class="unnamed1">在视中接收鼠标输入:</span></b></p>
        <p class="unnamed1">鼠标消息是我们常需要处理的消息,消息分为:鼠标移动,按钮按下/松开,双击。利用ClassWizard可以轻松的添加这几种消息映射,下面分别讲解每种消息的处理。</p>
        <p class="unnamed1">WM_MOUSEMOVE对应的函数为OnMouseMove( UINT nFlags, CPoint 
          point ),nFlags表明了当前一些按键的消息,你可以通过“位与”操作进行检测。 
        <ul type=disc>
          <li class="unnamed1"><b>MK_CONTROL</b> Ctrl键是否被按下&nbsp;&nbsp;&nbsp;Set 
            if the CTRL key is down.<br>
            <br>
          <li class="unnamed1"><b>MK_LBUTTON</b> 鼠标左键是否被按下&nbsp;&nbsp;&nbsp;Set 
            if the left mouse button is down.<br>
            <br>
          <li class="unnamed1"><b>MK_MBUTTON</b> 鼠标中间键是否被按下&nbsp;&nbsp;&nbsp;Set 
            if the middle mouse button is down.<br>
            <br>
          <li class="unnamed1"><b>MK_RBUTTON</b> 鼠标右键是否被按下&nbsp;&nbsp;&nbsp;Set 
            if the right mouse button is down.<br>
            <br>
          <li class="unnamed1"><b>MK_SHIFT</b> Shift键是否被按下&nbsp;&nbsp;&nbsp;Set 
            if the SHIFT key is down. </li>
        </ul>
        <span class="unnamed1">point表示当前鼠标的<font 
            color=red>设备坐标</font>,坐标原点对应视左上角。 </span> 
        <p></p>
        <p class="unnamed1">WM_LBUTTONDOWN/WM_RBUTTONDOWN(鼠标左/右键按下)对应的函数为OnLButtonDown/OnRButtonDown( 
          UINT nFlags, CPoint point )参数意义和OnMouseMove相同。</p>
        <p class="unnamed1">WM_LBUTTONUP/WM_RBUTTONUP(鼠标左/右键松开)对应的函数为OnLButtonUp/OnRButtonUp( 
          UINT nFlags, CPoint point )参数意义和OnMouseMove相同。</p>
        <p class="unnamed1">WM_LBUTTONDBLCLK/WM_RBUTTONDBLCLK(鼠标左/右键双击)对应的函数为OnLButtonDblClk/OnRButtonDblClk( 
          UINT nFlags, CPoint point )参数意义和OnMouseMove相同。</p>
        <p class="unnamed1">下面我用一段伪代码来讲解一下这些消息的用法: 
        <pre class="unnamed1">代码的作用是用鼠标拉出一个矩形
global BOOL fDowned;//是否在拉动
global CPoint ptDown;//按下位置
global CPoint ptUp;//松开位置

OnLButtonDown(UINT nFlags, CPoint point)
{
	fDowned=TRUE;
	ptUp=ptDown=point;
	DrawRect();
...
}

OnMouseMove(UINT nFlags, CPoint point)
{
	if(fDowned)
	{
		DrawRect();//恢复上次所画的矩形
		ptUp=point;
		DrawRect();//画新矩形
	}
}
OnLButtonUp(UINT nFlags, CPoint point)
{
	if(fDowned)
	{
		DrawRect();//恢复上次所画的矩形
		ptUp=point;
		DrawRect();//画新矩形
		fDowned=FALSE;
	}
}

DrawRect()
{//以反色屏幕的方法画出ptDown,ptUp标记的矩形
	CClientDC dc(this);
	MakeRect(ptDown,ptUp);
	SetROP(NOT);
	Rect();
}
</pre>
        <p></p>
        <p class="unnamed1">坐标间转换:在以上的函数中point参数对应的都是窗口的设备坐标,我们应该将设备坐标和逻辑坐标相区别,在图32_g1由于窗口使用了滚动条,所以传入的设备坐标是对应于当前窗口左上角的坐标,没有考虑是否滚动,而逻辑坐标必须考虑滚动后对应的坐标,所以我以黄线虚拟的表达一个逻辑坐标的区域。可以看得出同一点在滚动后的坐标值是不同的,这一规则同样适用于改变了映射方式的窗口,假设你将映射方式设置为每点为0.01毫米,那么设备坐标所对应的逻辑坐标也需要重新计算。进行这种转换需要写一段代码,所幸的是系统提供了进行转换的功能DC的DPtoLP,LPtoDP,下面给出代码完成由设备坐标到逻辑坐标的转换。 
        <pre class="unnamed1">CPoint CYourView::FromDP(CPoint point)
{
	CClientDC dc(this);
	CPoint ptRet=point;
	dc.PrepareDC();//必须先准备DC,这在使用滚动时让DC重新计算坐标

	//如果你作图设置了不同的映射方式,则在下面需要设置
	dc.SetMapMode(...)
	//
	dc.DPtoLP(&amp;ptRet);//DP-&gt;LP进行转换
	return ptRet;
}
</pre>
        <p></p>
        <p class="unnamed1">在图32_g1中以蓝线标记的是屏幕区域,红线标记的客户区域。利用ScreenToClient,ClientToScreen可以将坐标在这两个区域间转换。</p>
        <p class="unnamed1"><b>在视中接收键盘输入:</b></p>
        <p class="unnamed1">键盘消息有三个:键盘被按下/松开,输入字符。其中输入字符相当于直接得到用户输入的字符这在不需要处理按键细节时使用,而键盘被按下/松开在按键状态改变时发送。</p>
        <p class="unnamed1">WM_CHAR对应的函数为OnChar( UINT nChar, UINT nRepCnt, UINT 
          nFlags ),其中nChar为被按下的字符,nRepCnt表明在长时间为松开时相当于的按键次数,nFlags中的不同位代表不同的含义,在这里一般不使用。</p>
        <p class="unnamed1">WM_KEYDOWN/WM_KEYUP所对应的函数为OnKeyDown/OnKeyUp( UINT 
          nChar, UINT nRepCnt, UINT nFlags )nChar代表按键的虚拟码值,如VK_ALT为ALT键,VK_CONTROL为Ctrl键。nFlags各位的含义如下: 
        <table border=1 cellpadding=5 cols=2 frame=below rules=rows>
          <tbody> 
          <tr valign=top> 
            <td class=label width="15%"> <b>Value</b></span></td>
            <td class=label width="85%"> <b>Description</b></span></td>
          </tr>
          <tr valign=top> 
            <td width="15%" class="unnamed1">0?</td>
            <td width="85%" class="unnamed1">Scan code (OEM-dependent value).</td>
          </tr>
          <tr valign=top> 
            <td width="15%" class="unnamed1">8</td>
            <td width="85%" class="unnamed1">Extended key, such as a function 
              key or a key on the numeric keypad (1 if it is an extended key).</td>
          </tr>
          <tr valign=top> 
            <td width="15%" class="unnamed1">9?0</td>
            <td width="85%" class="unnamed1">Not used.</td>
          </tr>
          <tr valign=top> 
            <td width="15%" class="unnamed1">11?2</td>
            <td width="85%" class="unnamed1">Used internally by Windows.</td>
          </tr>
          <tr valign=top> 
            <td width="15%" class="unnamed1">13</td>
            <td width="85%" class="unnamed1">Context code (1 if the ALT key is 
              held down while the key is pressed; otherwise 0).</td>
          </tr>
          <tr valign=top> 
            <td width="15%" class="unnamed1">14</td>
            <td width="85%" class="unnamed1">Previous key state (1 if the key 
              is down before the call, 0 if the key is up).</td>
          </tr>
          <tr valign=top> 
            <td width="15%" class="unnamed1">15</td>
            <td width="85%" class="unnamed1">Transition state (1 if the key is 
              being released, 0 if the key is being pressed).</td>
          </tr>
          </tbody> 
        </table>
        <div align="left"> </div>
         
      </td>
    </tr>
    </tbody> 
  </table>
</div>
<p align="center"><script src="../../2.js"></script></a>
</body>
</html>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -