win32的输出int类型

在用win32创建了一个窗体,但是需要输出一个整型,然后win32的输出字符用的是TEXTOUT,里面的参数只接受TCHAR* 。所以基本思路是将int转换为char数组,然后char数组再转换为TCHAR数组。下面看具体步骤。
1.
int text;
char * putout;
TCHAR * putout2;
_itoa(text, putout, 10);

首先先声明需要用到的三个参数。当然text是有具体值的,此处我就不具体赋值给大家看了。
利用_itoa函数把int转为char数组,后面的10代表几进制,此处我用的是10进制。
2.
int iLength;
iLength = MultiByteToWideChar(CP_ACP, 0, putout, strlen(putout) + 1, NULL, 0);
MultiByteToWideChar(CP_ACP, 0, putout, strlen(putout) + 1, putout2, iLength);

利用函数转换把char数组转为TCHAR数组。
3.然后我调试的时候出现了错误,提示如下:

error C4996: '_itoa': This function or variable may be unsafe. Consider using _itoa_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.

提示说——itoa函数不安全,所以需要进行一下设置。
项目 =》属性 =》c/c++ =》预处理器=》点击预处理器定义,编辑,加入_CRT_SECURE_NO_WARNINGS,即可。这是我查找的资料。
这是添加这个
然后完美解决。

**
_itoa(num, (char*)szBuf, 10);
其中szBuf为TCHAR*类型

补充:将TCHAR*强制转换为char*
时只能取到第一位。所以不可取。
可按一下方法实现。
TCHAR szIWidth[50] = TEXT(“”);
char* chRtn = “”;
iLen = 2 * wcslen(szIWidth);//CString,TCHAR汉字算一个字符,因此不用普通计算长度
chRtn = new char[iLen + 1];
wcstombs(chRtn, szIWidth, iLen + 1);//转换成功返回为非负值
iWidth = atoi(chRtn);

char* 转TCHAR*:
char a[] = “Hello world”;
USES_CONVERSION;
TCHAR* b = A2T(a);
需要使用头文件#include “atlstr.h”

`GetImageEncoders` 是一个 Windows API 函数,用于获取系统中注册的可用图像编码器的信息。它的原型如下: ```c++ Status GetImageEncoders( UINT numEncoders, UINT sizeEncoder, ImageCodecInfo *pEncoders ); ``` 参数意义如下: - `numEncoders`:指定要获取的编码器的数量。 - `sizeEncoder`:指定返回 `ImageCodecInfo` 结构体的大小,以便函数知道如何分配内存。 - `pEncoders`:指向 `ImageCodecInfo` 数组的指针,用于存储编码器信息。 下面是一个示例代码,演示如何使用 `GetImageEncoders` 函数来获取系统中可用编码器的信息: ```c++ #include <iostream> #include <windows.h> #include <gdiplus.h> using namespace Gdiplus; int main() { ULONG_PTR token; GdiplusStartupInput input; GdiplusStartup(&token, &input, NULL); UINT numEncoders, sizeEncoder; GetImageEncodersSize(&numEncoders, &sizeEncoder); ImageCodecInfo* pEncoders = (ImageCodecInfo*)malloc(sizeEncoder); GetImageEncoders(numEncoders, sizeEncoder, pEncoders); for (UINT i = 0; i < numEncoders; i++) { std::wcout << "Codec Name: " << pEncoders[i].CodecName << std::endl; std::wcout << "MimeType: " << pEncoders[i].MimeType << std::endl; } free(pEncoders); GdiplusShutdown(token); return 0; } ``` 此示例代码首先调用 `GdiplusStartup` 函数,以启动 GDI+ 库。然后,它调用 `GetImageEncodersSize` 函数获取编码器数量和结构体大小,为存储编码器信息分配内存,并调用 `GetImageEncoders` 函数获取编码器信息。最后,它遍历编码器信息并输出编码器名称和 MIME 类型。 需要注意的是,此示例代码需要链接 GDI+ 库。如果使用 Visual Studio 编译,需要在项目属性中的“链接器 - 输入 - 附加依赖项”中添加 `gdiplus.lib`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值