CListBox控件在进行调整大小时,默认是按照控件内item的高度进行高度变化递增的,也就是说,高度会是单个项高度的倍数,以便完整显示可见项。这样在父窗口OnSize时调整控件大小会出现高度和计算出的填充全客户区大小高度不一致的问题,显示上会有部分区域重绘错误。改变这种默认高度行为的方法就是在创建控件时,加上LBS_NOINTEGRALHEIGHT这个style bit。
K-Res
终于忍不了了,入手DSTWO替下了DSTT
玩了2年多的IDSL,最近实在是忍不了了,DSTT内核停止更新已经很久了,一些非官方的内核啊,补丁库什么的更新速度也是不尽人意,这点当初刚买机子的时候有同事用老DS加SLOT2端烧录卡的时候就预见到这个问题了,没想到还挺快。考虑再三还是决定入手当红烧录卡DSTWO(花了240,没敢淘宝买,看好多人说收到的卡金手指都锈了…)了,留个影纪念一下吧。PS:淘宝上看到很多人说DSTWO的做工差,这点我倒是没太看出来。不过发现一个比较恶心的问题就是这卡用在DSL上SLOT1槽内会非常紧,插进去就不能弹出来了,问商家,商家说这卡就这样,一般他们用的时候都是只拔小卡(TF卡),还好烧录卡没事也不会总拔。不过这个卡在同事的DSI就没有问题,进出都很顺畅。
用BCG Control Bar库的MFC程序中文字体过小问题的解决方法
这个问题和上一个转帖的VS2010 MFC文字过小问题如出一辙,但是那篇帖子里的解决方法只是一个临时的解决方法,对于应用BCG库后的MFC程序,尤其是应用了部分主题以后,即使修改了字体,也会由于UI部分很多地方会调用BCGPGLOBAL_DATA的UpdateFonts导致修改后的font被默认字体覆盖。
其实用源码跟踪了一下后发现,导致中文字体难看的原因其实是Segoe UI这个字体,于是修改了Bcgglobals.cpp中
static const CString strOffice2007FontName = _T(“Segoe UI”);
这行为
static const CString strOffice2007FontName = _T(“Tahoma”);
使用Tahoma字体就可以了。
开启Visual Studio下C++的注释TODO自动列表到TaskList窗口功能
用Eclipse写JAVA时已经习惯了在注释里写TODO,然后Tasks小窗口中就能够看到当前source页里的所有TODO,用起来很方便。这几天用VS 2010写MFC时留了很多TODO,才发现开了VS的Task List窗口竟然看不到代码页里的TODO位置,看了一下M$的官方Blog发现原来只有VC++用这个功能时是需要手动开启的,VB、C#都是直接开启的。VC++开启这个功能的位置如下:
Tools->Options->Text Editor->C/C++->Formatting-> Miscellaneous->Enumerate Comment Tasks。
官方说法这个选项在C++里被默认关闭的原因是due to performance reasons。
为SDL窗口模式程序添加menu
一定要窗口模式的程序,还要有menu,找了很多资料都找不到相关内容。
老外说要hack sdl的库,进入底层,HOHO,好深奥,不解,但我就是要实现这个窗口加menu,所以主席说的好,自己动手,丰衣足食!
取得windows中一些特殊文件夹路径的方法
比如当前用户的documents文件夹、windows安装文件夹等,虽然一些软件的默认文档保存位置通过这种方式取得感觉有点恶心,不过在用户未指定默认目录的情况下通过这种方式取得的路径还是比较合理的。
以下内容转抄自Visual C++ Tips,原始链接:http://weseetips.com/2008/05/01/how-to-get-the-path-of-special-folders-in-windows/
Windows have a number of special folder such as my documents, desktop folder etc. They are special because, their path can be different in system to system. So how can you get the path of special folder in windows?
[转]Visual studio 2008/2010 MFC程序Menu、Toolbar字体偏小解决办法
原文:http://www.blogjava.net/luchunwei/archive/2010/06/09/323118.html
首先,这是一个MFC的Bug
http://connect.microsoft.com/VisualStudio/feedback/details/505466/mfc-visual-style-font-size-too-small-to-display-chinese-character-clearly-on-windows-xp
解决时间暂时还不确定,临时的方案如下:
App在InitInstance中加入:
记录VS2010下用BCGControlBar编译程序时的一个小问题
链接期错误信息如下:
Flash CS5的AS3 TLF发布swf的共享库问题
给blog的banner换了个flash版,顺便学学AS3和体验一下CS5系列,结果在开发系统上debug,publish看着都没问题,到了另一个xp系统下访问页面的时候出现flash一直…的问题,下载下来swf用flash player直接打开,蹦出错误提示VerifyError: #1014 flashx.textLayout.container::ContainerController,尝试升级flash activex插件到最新版本以及对fla中的字体进行embed操作都没有解决,最后发现在publish的时候,目录下会连带生成textLayout_1.0.0.595.swz这个东西,查了一下是flash的运行时共享库,原来stage上用到了CS5的新玩意TLF Text Field,而TLF依赖于这个swz库,所以连带这个swz和swf一起发布到网站上就可以了(据说这个库没有的话客户端也会自动去adobe官方下载,但我这一直…没有成功)。
为Eclipse ADT创建的android项目通过ant添加proguard混淆支持
假设已有ADT创建的android项目HelloAndroid并且已经有可用的proguard混淆器(我用的proguard4.4)。
第一步要做的是为项目添加ant build支持。由于ADT插件并不直接支持proguard等混淆器,所以不能像j2me那样在有功能比较完善的插件(如EclipseME等)的基础上直接一键混淆一键打包,不过好在android sdk本身提供了比较完善的ant编译支持,可以通过类似命令行编译的方式,对android项目的整个编译、生成过程进行自定义,从而能够实现对编译中途生成的java bytecode进行插入proguard混淆操作然后再转android dex码生成apk。
进入命令行模式,并切换到项目目录,执行如下命令为ADT创建的项目添加ant build支持:
Continue reading…