一个开源的Asp.net2.0博客系统
中英文数字字母标点混合的情况,会自动过滤中文汉字和英文字母外的内容,如果取不到某个字符的拼音首字母就自动跳过。测试了下,基本上可以用。不过不是很完美,对某些汉字没办法取到首字母,比如现在很火的 “囧”,多音字也没办法处理。
- //根据汉字字符串返回首字母字符串
- #include <Windows.h>
- class GB2Alpha
- {
- public:
- GB2Alpha()
- {
- pAlpha = NULL;
- }
- ~GB2Alpha()
- {
- if (pAlpha)
- {
- delete[] pAlpha;
- pAlpha = NULL;
- }
- }
- //得到实际的拼音首字母buffer
- const char* GetAlpha(const char* pStr)
- {
- if (pAlpha)
- {
- delete pAlpha;
- pAlpha = NULL;
- }
- if (!pStr)
- {
- return NULL;
- }
- char chr[3];
- wchar_t wchr = 0;
- unsigned int nlen = strlen(pStr);
- pAlpha = new char[nlen+1];
- memset(pAlpha,0x00,nlen+1);
- int nIndex = 0; //首字母数组的长度索引
- for (int i = 0;i< nlen ;)
- {
- char tmpchar = '\0';
- if (pStr[i] > 0) //非汉字
- {
- if (pStr[i] >= 'a' && pStr[i] <= 'z')
- {
- tmpchar = (char)(pStr[i] - 'a' + 'A');
- pAlpha[nIndex++] = tmpchar;
- }
- if (pStr[i] >= 'A' && pStr[i] <= 'Z')
- {
- tmpchar = pStr[i];
- pAlpha[nIndex++] = tmpchar;
- }
- i++;
- }
- else //汉字
- {
- memset(chr, 0x00, sizeof(chr));
- chr[0] = pStr[i++];
- chr[1] = pStr[i++];
- chr[2] = '\0';
- wchr = 0;
- wchr = (chr[0] & 0xff) << 8;
- wchr |= (chr[1] & 0xff);
- tmpchar = convert(wchr);
- if(tmpchar != '\0')
- {
- pAlpha[nIndex++] = tmpchar;
- }
- }
- }
- return pAlpha;
- }
- private:
- //汉字首字母转换表
- char convert(wchar_t n)
- {
- if (In(0xB0A1,0xB0C4,n)) return 'A';
- if (In(0XB0C5,0XB2C0,n)) return 'B';
- if (In(0xB2C1,0xB4ED,n)) return 'C';
- if (In(0xB4EE,0xB6E9,n)) return 'D';
- if (In(0xB6EA,0xB7A1,n)) return 'E';
- if (In(0xB7A2,0xB8c0,n)) return 'F';
- if (In(0xB8C1,0xB9FD,n)) return 'G';
- if (In(0xB9FE,0xBBF6,n)) return 'H';
- if (In(0xBBF7,0xBFA5,n)) return 'J';
- if (In(0xBFA6,0xC0AB,n)) return 'K';
- if (In(0xC0AC,0xC2E7,n)) return 'L';
- if (In(0xC2E8,0xC4C2,n)) return 'M';
- if (In(0xC4C3,0xC5B5,n)) return 'N';
- if (In(0xC5B6,0xC5BD,n)) return 'O';
- if (In(0xC5BE,0xC6D9,n)) return 'P';
- if (In(0xC6DA,0xC8BA,n)) return 'Q';
- if (In(0xC8BB,0xC8F5,n)) return 'R';
- if (In(0xC8F6,0xCBF0,n)) return 'S';
- if (In(0xCBFA,0xCDD9,n)) return 'T';
- if (In(0xCDDA,0xCEF3,n)) return 'W';
- if (In(0xCEF4,0xD188,n)) return 'X';
- if (In(0xD1B9,0xD4D0,n)) return 'Y';
- if (In(0xD4D1,0xD7F9,n)) return 'Z';
- return '\0';
- }
- bool In(wchar_t start, wchar_t end, wchar_t code)
- {
- if (code >= start && code <= end)
- {
- return true;
- }
- return false;
- }
- protected:
- char* pAlpha;
- };
最近一段做一些关于文字编码方面的东西,常常涉及到各种编码字符之间的转换。主要是做中日文方面的,包括中文gb2312, 日文JIS, SHIFT-JIS,以及他们和Unnicode码之间的转换。
使用过QQ的人都知道,只要把文件拖拽到消息框中就可以传送文件了。那么这种功能是如何实现的呢?其实很简单,只需要响应一个WM_DROPFILES消息就可以了。
在基于对话框的程序中,默认是没有这个消息的,按下Ctrl+W,弹出类向导对话框,选择Class Info标签,在Message fileter下拉列表中选择Window,然后再点击Message Maps标签,就出现WM_DROPFILES消息了,添加该消息的响应函数:
- void CTestDlg::OnDropFiles(HDROP hDropInfo)
- {
- // TODO: Add your message handler code here and/or call default
- CDialog::OnDropFiles(hDropInfo);
- }
另外,要让对话框能够接受文件拖拽,还需要设置对话框属性。在对话框上点击右键,选择Properties->Extended Styles,点选Accept files选项即可。
要获得当前拖拽的文件的完整文件名(含路径),只需要一个函数:
- UINT DragQueryFile(
- HDROP hDrop,
- UINT iFile,
- LPTSTR lpszFile,
- UINT cch
- );
参数解释:
hDrop: HDROP标识符,即响应函数中的hDropInfo参数
iFile: 待查询的文件索引号,从0开始。可以同时拖拽多个文件,因此就需要一个索引号来进行区分。如果该参数为0xFFFFFFFF,则该函数返回拖拽的文件的个数
lpszFile: 用于存放文件名的缓冲区首地址
cch: 缓冲区长度
返回值:文件名长度
另外,查询完成后需要释放系统分配内存,使用下面这个函数:
- VOID DragFinish(
- HDROP hDrop
- );
下面是一个完整的代码示例,将文件拖拽到对话框上后会弹出消息框显示完整文件名:
- void CTestDlg::OnDropFiles(HDROP hDropInfo)
- {
- // TODO: Add your message handler code here and/or call default
- UINT count;
- char filePath[200];
- count = DragQueryFile(hDropInfo, 0xFFFFFFFF, NULL, 0);
- if(count)
- {
- for(UINT i=0; i<count; i++)
- {
- int pathLen = DragQueryFile(hDropInfo, i, filePath, sizeof(filePath));
- AfxMessageBox(filePath);
- }
- }
- DragFinish(hDropInfo);
- CDialog::OnDropFiles(hDropInfo);
- }
同理,如果只有把文件拖拽到特定的控件中时才有响应,只需要把该控件的Accept files样式勾选上即可。
首先在stdafx.h或者其他头文件里面加上以下代码,以包含GDI+的头文件和lib文件:
- #include <gdiplus.h>
- using namespace Gdiplus;
- #pragma comment(lib, "gdiplus.lib")
然后在CWinApp继承下来的应用程序类里面声明两个变量:
- private:
- GdiplusStartupInput gdiplusStartupInput;
- ULONG_PTR gdiplusToken;
在初始化函数InitInstance()里面加入:
- GdiplusStartup(&gdiplusToken, &gdiplusStartupInput, NULL);
到这里,GDI+的初始化工作已经完成,可以在应用程序当中使用GDI+了!
在退出应用程序之前,还需要关闭GDI+,你可以在CWinApp::ExitInstance()当中加入:
- GdiplusShutdown(gdiplusToken);
使用第一段代码可以获得应用程序运行时所在目录。但由于在使用Microsoft Visual Studio.NET编译并运行项目时,真正的宿主是IDE,所以当前目录是项目所在目录,并不是DEBUG或者RELEASE目录,这一点需要注意。而第二段代码可以动态解决此问题。并且增加了Unicode支持(TCHAR)。