6,图像平移

如果dstX = srcX + deltaX,dstY = srcY + deltaY,那么,将(dstX,dstY)的位置赋值(srcX,srcY)的像素。其余的可以暂时为白色。
即添加函数

void CDib::PingYi(int xMove, int yMove)
{
//指向原图像的指针
LPBYTE lpSrc;
LPBYTE p_data = GetData();;
//图像的宽和高
LONG width = GetWidth();
LONG height = GetHeight();;
//图像每行的字节数
LONG lLineBytes = (width*8+31)/32 * 4;
//暂时分配内存,以保存新图像
LPBYTE temp = new BYTE[lLineBytes * height];
//初始化新分配的内存,设定初始值为255
LPBYTE lpDst = (LPBYTE)temp;
memset(lpDst, (BYTE)255, lLineBytes * height);
for (int i = 0; i < width; i++)
{
for (int j = 0; j < height; j++)
{
//计算该像素在原DIB中的坐标
lpSrc = (LPBYTE)p_data + lLineBytes * (height - 1 - j) + i;
//计算新坐标
int i0 = i + xMove;
int j0 = j + yMove;
//判断是否在新图像范围内,如果不在,则直接赋值255
if ((i0 >= 0 ) && ( i0 < width) && (j0 >=0 ) && (j0 < height))
{
lpDst = (LPBYTE)temp + lLineBytes * (height - 1 - j0) + i0;
*lpDst = lpSrc;
}
else
{
((unsigned char)lpDst) = 255;
}
}
}
//复制平移后的图像
memcpy(p_data, temp, lLineBytes
height);
//释放内存
delete temp;
}

在初始化时,加载后,调用即可。

CMy1_showbitmapView::CMy1_showbitmapView()
{
// TODO: add construction code here
_cdib.LoadFile (“D:/Test/DataProcess/result.bmp”);

 _cdib.PingYi(100, 100);

}
onDraw()不变

void CMy1_showbitmapView::OnDraw(CDC* pDC)
{
CMy1_showbitmapDoc* pDoc = GetDocument();
ASSERT_VALID(pDoc);
if (!pDoc)
return;

// TODO: add draw code for native data here
//this->StretchBitMap(pDC);
//控制缩放比例
int m_scale = 1;
//CDib类指针对象
BYTE* pBitmapData = _cdib.GetData();
LPBITMAPINFO pBitmapInfo = _cdib.GetInfo();
int bitmapHeight = _cdib.GetHeight();
int bitmapWidth = _cdib.GetWidth();
int scaledWidth = (int)(bitmapWidth * m_scale);
int scaledHeight = (int)(bitmapHeight * m_scale);
bool bGetRGB = _cdib.GetRGB();
if (!bGetRGB)
{
	return;
}

CPalette* hPalette = CreateBitmapPalette(&_cdib);
//将已创建的调色板调用到设备上下文中
CPalette* hOldPalette = pDC->SelectPalette(hPalette, true);
//实现调色板
pDC->RealizePalette();

::StretchDIBits(pDC->GetSafeHdc(), 0, 0, scaledWidth, scaledHeight,
	0, 0,
	bitmapWidth, bitmapHeight,
	pBitmapData, pBitmapInfo,
	DIB_RGB_COLORS,
	SRCCOPY);


pDC->SelectPalette(hOldPalette, true);
::DeleteObject(hPalette);

}

运算结果显示如下:
在这里插入图片描述

【无线传感器】使用 MATLAB和 XBee连续监控温度传感器无线网络研究(Matlab代码实现)内容概要:本文围绕使用MATLAB和XBee技术实现温度传感器无线网络的连续监控展开研究,介绍了如何构建无线传感网络系统,并利用MATLAB进行数据采集、处理与可视化分析。系统通过XBee模块实现传感器节点间的无线通信,实时传输温度数据至主机,MATLAB负责接收并处理数据,实现对环境温度的动态监测。文中详细阐述了硬件连接、通信协议配置、数据解析及软件编程实现过程,并提供了完整的MATLAB代码示例,便于读者复现和应用。该方案具有良好的扩展性和实用性,适用于远程环境监测场景。; 适合人群:具备一定MATLAB编程基础和无线通信基础知识的高校学生、科研人员及工程技术人员,尤其适合从事物联网、传感器网络相关项目开发的初学者与中级开发者。; 使用场景及目标:①实现基于XBee的无线温度传感网络搭建;②掌握MATLAB与无线模块的数据通信方法;③完成实时数据采集、处理与可视化;④为环境监测、工业测控等实际应用场景提供技术参考。; 阅读建议:建议读者结合文中提供的MATLAB代码与硬件连接图进行实践操作,先从简单的点对点通信入手,逐步扩展到多节点网络,同时可进一步探索数据滤波、异常检测、远程报警等功能的集成。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值