一,ALT+TAB切换时小图标的添加
Dlg类中添加变量
protected:
HICON m_hIcon; #define IDR_MAINFRAME 128
ICON IDR_MAINFRAME,IDC_STATIC,,,,
// Icon with lowest ID value placed first to ensure application icon
// remains consistent on all systems.
IDR_MAINFRAME ICON DISCARDABLE "res\\crtApp.ico" 构造函数中加载
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
初始化
SetIcon(m_hIcon, TRUE); // Set big icon ALT+TAB
SetIcon(m_hIcon, FALSE); // Set small icon 左上角小图标 使用
// Draw the icon
dc.DrawIcon(, , m_hIcon);
// The system calls this to obtain the cursor to display while the user drags
// the minimized window.
Dlg::OnQueryDragIcon()
{
return (HCURSOR) m_hIcon;
}
二 Dlg::OnInitDialog()
获取屏幕大小
int w = GetSystemMetrics(SM_CXSCREEN);
int h = GetSystemMetrics(SM_CYSCREEN);
界面透明
SetWindowPos(&wndTopMost,,,,,SWP_SHOWWINDOW); //移动界面位置
MoveWindow(,,,, TRUE); //移动界面位置
//VS2003以上版本
//SetWindowLong(GetSafeHwnd(),GWL_EXSTYLE,GetWindowLong(GetSafeHwnd (),GWL_EXSTYLE)|WS_EX_LAYERED);
//SetLayeredWindowAttributes(0,200,LWA_ALPHA);
//VS2003以下版本
SetWindowLong(GetSafeHwnd(), GWL_EXSTYLE, GetWindowLong(GetSafeHwnd(), GWL_EXSTYLE) |0x00080000);
HINSTANCE hInst = LoadLibrary(_T("User32.dll"));
if (hInst)
{
typedef BOOL (WINAPI *MyFun)(HWND,COLORREF,BYTE,DWORD);
MyFun myfun = NULL;
myfun = (MyFun)GetProcAddress(hInst, "SetLayeredWindowAttributes");
if (myfun)
myfun(GetSafeHwnd(),,,);
FreeLibrary(hInst);
}
, //竖行字体
Dlg::OnPaint()
{ CPaintDC dc(this);// device context for painting
CRect rtClient;
GetClientRect(rtClient); //获取客户区尺寸、位置信息 /////// 利用CFont::CreateFont(...)函数实现竖写汉字////////
CFont myFont; //创建字体对象
//创建逻辑字体
myFont.CreateFont(, //字体高度(旋转后的字体宽度)=56
, //字体宽度(旋转后的字体高度)=20
, //字体显示角度=270°
, //nOrientation=0
, //字体磅数=10
FALSE, //非斜体
FALSE, //无下划线
FALSE, //无删除线
DEFAULT_CHARSET, //使用缺省字符集
OUT_DEFAULT_PRECIS, //缺省输出精度
CLIP_DEFAULT_PRECIS,//缺省裁减精度
DEFAULT_QUALITY, //nQuality=缺省值
DEFAULT_PITCH, //nPitchAndFamily=缺省值
"@system"); //字体名=@system
CFont *pOldFont=dc.SelectObject(&myFont);//选入设备描述表 //在客户区适当位置输出文字
dc.TextOut(rtClient.Width()/+,, "单击返回主界面");
dc.SelectObject(pOldFont); //将myFont从设备环境中分离
myFont.DeleteObject(); //删除myFont对象
/*
/////////// 利用LOGFONT结构实现竖写汉字//////////////
LOGFONT lf; //定义字体结构
lf.lfWeight=8; //字体磅数=10
lf.lfHeight=20; //字体高度(旋转后的字体宽度)=56
lf.lfWidth=10; //字体宽度(旋转后的字体高度)=20
lf.lfUnderline=FALSE; //无下划线
lf.lfStrikeOut=FALSE; //无删除线
lf.lfItalic=FALSE; //非斜体
lf.lfEscapement=2700; //字体显示角度=270°
lf.lfCharSet=DEFAULT_CHARSET; //使用缺省字符集
strcpy(lf.lfFaceName,"@system"); //字体名=@system
CFont myLogFont; //定义字体对象
myLogFont.CreateFontIndirect(&lf); //创建逻辑字体
pOldFont=dc.SelectObject(&myLogFont);//选入设备描述表
//在客户区适当位置输出文字
// dc.TextOut(rtClient.Width()/2+5,rtClient.Height()/32, "点击返回主界面");
dc.SelectObject(pOldFont); //将myFont从设备环境中分离
myLogFont.DeleteObject(); //删除myLogFont对象
*/
...
}
三 进程信息
#include <tlhelp32.h>
long FindTargetProcess(const CString &m_strProcessName)
{
int nRet = ;
HANDLE hFind = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, );
PROCESSENTRY32 *info = new PROCESSENTRY32;
info->dwSize = sizeof(PROCESSENTRY32);
nRet = ; if (::Process32First(hFind, info) != NULL)
{
CString strName;
while (::Process32Next(hFind, info) != FALSE)
{
strName = info->szExeFile;
if (strName == m_strProcessName)
{
if (strName == "cmd.exe")
{
CString strCmd;
strCmd.Format("taskkill /f /pid %u", info- >th32ProcessID);
::system(strCmd); } HANDLE hOpenPro = OpenProcess(PROCESS_ALL_ACCESS, TRUE, info->th32ProcessID);
if (hOpenPro != NULL)
{
Sleep();
nRet = ;
::TerminateProcess(hOpenPro, );
Sleep();
}
}
}
::CloseHandle(hFind);
if (info != NULL)
{
delete info;
}
}
return nRet;
} //ExitProcess(0);
char app[] = {};
long FindTargetProcess2(const CString &m_strProcessName)
{
int nRet = ;
HANDLE hFind = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, );
PROCESSENTRY32 *info = new PROCESSENTRY32;
info->dwSize = sizeof(PROCESSENTRY32);
nRet = ;
DWORD pid = ;
if (::Process32First(hFind, info) != NULL)
{
CString strName;
while (::Process32Next(hFind, info) != FALSE)
{
strName = info->szExeFile;
if (strName == m_strProcessName)
{
pid = info->th32ProcessID;
HANDLE hOpenPro = OpenProcess(PROCESS_ALL_ACCESS, TRUE, info->th32ProcessID);
if (hOpenPro != NULL)
{
}
}
}
::CloseHandle(hFind);
if (info != NULL)
{
delete info;
}
}
return pid;
} BOOL CALLBACK EnumWindowsProc(HWND hwnd, LPARAM lParam)
{
DWORD pid = ; DWORD tid = GetWindowThreadProcessId(hwnd, &pid);
if (pid == (DWORD)lParam)
{
// printf("pid:%d\n", pid, tid);
// DWORD lid = GetCurrentThreadId();
// AttachThreadInput(tid, lid, TRUE ); int w = GetSystemMetrics(SM_CXSCREEN);
int h = GetSystemMetrics(SM_CYSCREEN);
// BOOL b = SetWindowPos (hwnd,HWND_NOTOPMOST,,,,,SWP_NOMOVE|SWP_NOSIZE); // PostMessage(hwnd, WM_SHOWWINDOW, true, SW_OTHERZOOM);
HWND hw = hwnd;
while (hw != NULL)
{
hw = GetParent(hwnd);
if (hw)
{
printf("%x ", hw);
hwnd = hw;
}
printf("\n");
}
if (!GetWindowLong(hwnd, GWL_STYLE)&WS_VISIBLE)
{
return TRUE;
}
char buf[] = {}; GetWindowText(hwnd, buf, ); CString str=buf;
if (str == app )
{
printf("%s\n", buf);
ShowWindow(hwnd,SW_RESTORE);
SetForegroundWindow(hwnd);
return FALSE;
} // SetActiveWindow(hwnd);
// bool b = SetWindowPos (hwnd,HWND_TOPMOST,,,,,SWP_NOSIZE|SWP_NOMOVE|SWP_SHOWWINDOW); //AttachThreadInput(tid, lid, FALSE ); }
return TRUE;
}
char app[] = {};
long FindTargetProcess2(const CString &m_strProcessName)
{
int nRet = ;
HANDLE hFind = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, );
PROCESSENTRY32 *info = new PROCESSENTRY32;
info->dwSize = sizeof(PROCESSENTRY32);
nRet = ;
DWORD pid = ;
if (::Process32First(hFind, info) != NULL)
{
CString strName;
while (::Process32Next(hFind, info) != FALSE)
{
strName = info->szExeFile;
if (strName == m_strProcessName)
{
pid = info->th32ProcessID;
HANDLE hOpenPro = OpenProcess(PROCESS_ALL_ACCESS, TRUE, info->th32ProcessID);
if (hOpenPro != NULL)
{
}
}
}
::CloseHandle(hFind);
if (info != NULL)
{
delete info;
}
}
return pid;
} BOOL CALLBACK EnumWindowsProc(HWND hwnd, LPARAM lParam)
{
DWORD pid = ; DWORD tid = GetWindowThreadProcessId(hwnd, &pid);
if (pid == (DWORD)lParam)
{
// printf("pid:%d\n", pid, tid);
// DWORD lid = GetCurrentThreadId();
// AttachThreadInput(tid, lid, TRUE ); int w = GetSystemMetrics(SM_CXSCREEN);
int h = GetSystemMetrics(SM_CYSCREEN);
// BOOL b = SetWindowPos (hwnd,HWND_NOTOPMOST,,,,,SWP_NOMOVE|SWP_NOSIZE); // PostMessage(hwnd, WM_SHOWWINDOW, true, SW_OTHERZOOM);
HWND hw = hwnd;
while (hw != NULL)
{
hw = GetParent(hwnd);
if (hw)
{
printf("%x ", hw);
hwnd = hw;
}
printf("\n");
}
if (!GetWindowLong(hwnd, GWL_STYLE)&WS_VISIBLE)
{
return TRUE;
}
char buf[] = {}; GetWindowText(hwnd, buf, ); CString str=buf;
if (str == app )
{
printf("%s\n", buf);
ShowWindow(hwnd,SW_RESTORE);
SetForegroundWindow(hwnd);
return FALSE;
} // SetActiveWindow(hwnd);
// bool b = SetWindowPos (hwnd,HWND_TOPMOST,,,,,SWP_NOSIZE|SWP_NOMOVE|SWP_SHOWWINDOW); //AttachThreadInput(tid, lid, FALSE ); }
return TRUE;
}
SetTimer(, , );

ALT+TAB切换时小图标的添加 界面透明 屏幕大小 竖行字体 进程信息的更多相关文章

  1. ubuntu 14.04 compiz的ALT + TAB切换程序

    安装完ubuntu,发现不能使用ALT + TAB切换应用程序,翻遍所有百度结果,没有可行,都是拷这个拷那个...真实无语...FQgoogle,看的第一个就完美解决.记录下来,方便国人少走弯路. 首 ...

  2. 解决微信小程序的wx-charts插件tab切换时的显示会出现位置移动问题-tab切换时,图表显示错乱-实现滑动tab

    解决Echarts在微信小程序tab切换时的显示会出现位置移动问题 tab切换时,图表显示错乱 <canvas class="kcanvas" canvas-id=" ...

  3. element--ui使用tab切换时如何获取当前对象的id或者其他属性

    1. 问题 当使用tab切换时,部分特殊场景需要获取当前元素的类名或者id. 2.解决思路,tab切换是绑定函数,函数会传递过去当前对象,通过当前对象获取对象属性 vue部分代码:本项目是在vue-c ...

  4. vue -vantUI tab切换时 list组件不触发load事件解决办法

    最近由于公司项目需要,用vue写了几个简单的页面.用到了vantUI List 列表 瀑布流滚动加载,用于控制长列表的展示 当列表即将滚动到底部时,会触发事件并加载更多列表项. (页面加载完成后默认会 ...

  5. easyui easyui-accordion的使用和在tab切换时没有样式

    1.easyui-accordion的使用 <div id="aa" class="easyui-accordion" style="width ...

  6. vue中echarts 在element-ui的tab 切换时 width 为100px 时的解决方式

    最近在项目中遇到了这种情况,需要在tab控件上渲染多个echart图标,然后切换查看时,发现图表的宽度不正确 原因:在页面进行加载时,隐藏的图表找不到对应的div大小,所以默认给了一个大小.所以要做的 ...

  7. echarts在tab切换时容器宽度设置为100%,只展示100px

    在 mychart.setOption(option); 后面加上 mychart.resize(); 即可

  8. 解决windows 1903 alt + tab 切换卡顿

    右击此电脑图标 选择管理 服务和应用程序 服务 禁用system interface foundation service

  9. AppBar 自定义顶部导航按钮 图标、颜色 以及 TabBar 定义顶部 Tab 切换

    一.Flutter AppBar 自定义顶部按钮图标.颜色 leading   在标题前面显示的一个控件,在首页通常显示应用的 logo:在其他界面通常显示为返回按钮 title  标题,通常显示为当 ...

随机推荐

  1. arm 2440 linux 应用程序 nes 红白机模拟器 第4篇 linux 手柄驱动支持

    小霸王学习机的真实手柄,实测CPU 占用 80% 接线图: 手柄读时序: joypad.c 驱动: 普通的字符设备驱动. #include <linux/module.h> #includ ...

  2. Bootstrap栅格系统详解,响应式布局

    Bootstrap栅格系统详解 栅格系统介绍 Bootstrap 提供了一套响应式.移动设备优先的流式栅格系统,随着屏幕或视口(viewport)尺寸的增加,系统会自动分为最多12列. 栅格系统用于通 ...

  3. 动态创建script在IE中缓存js文件时导致编码不正确bug

    $.each(scripts, function(){ if(!jsExist(this.src)){ var s = document.createElement("SCRIPT" ...

  4. 基于Session的国际化实现

    如何将我们网站的其它内容(如菜单.标题等)做国际化处理呢?这就是本篇要将的内容—>国际化. 在项目的spring.xml文件添加的内容如下 <mvc:interceptors> &l ...

  5. HTML5:web socket 和 web worker

    a:hover { cursor: pointer } 做练习遇到了一个选择题,是关于web worker的,问web worker会不会影响页面性能?补习功课之后,答案是不会影响. 查阅了相关资料学 ...

  6. SpringMVC框架下数据的增删改查,数据类型转换,数据格式化,数据校验,错误输入的消息回显

    在eclipse中javaEE环境下: 这儿并没有连接数据库,而是将数据存放在map集合中: 将各种架包导入lib下... web.xml文件配置为 <?xml version="1. ...

  7. [DataBase] MongoDB (8) 副本集

    MongoDB  创建副本集 MongoDB复制是将数据同步在多个服务器的过程. 复制提供了数据的冗余备份,并在多个服务器上存储数据副本,提高了数据的可用性, 并可以保证数据的安全性. 复制还允许您从 ...

  8. mysql connection refused

    mysql数据库认证的时候和别的服务器不一样,即使mysqld数据库服务器没有启动,使用mysql这种客户端程序去连接,也要先输入密码,从而使人有一种错觉,以会服务器已经正常启动了.是不是密码或是主机 ...

  9. 使用Python结合Face++ API识别人脸

    Face++是北京旷视科技旗下的视觉服务平台,可以进行人脸识别.检测等功能.其人脸识别技术据悉在目前准确率较高,其API非常友好,免费使用,功能众多,而且调用几乎没有限制.这里我使用了Python调用 ...

  10. sudo: no tty present and no askpass program specified(转)

    sudo: no tty present and no askpass program specified 2012-11-30 09:30 5040人阅读 评论(1) 收藏 举报 修改sudo配置文 ...