C#中马赛克算法
public static Bitmap KiMosaic(Bitmap b, int val)
{
if (b.Equals(null)) { return null; }
int w = b.Width;
int h = b.Height;
int stdR, stdG, stdB;
stdR = 0; stdG = 0; stdB = 0;
BitmapData srcData = b.LockBits(new Rectangle(0, 0, w, h), ImageLockMode.ReadWrite, PixelFormat.Format24bppRgb);
unsafe
{
byte* p = (byte*)srcData.Scan0.ToPointer();
for (int y = 0; y < h; y++)
{
for (int x = 0; x < w; x++)
{
if (y % val == 0)
{
if (x % val == 0) { stdR = p[2]; stdG = p[1]; stdB = p[0]; }
else { p[0] = (byte)stdB; p[1] = (byte)stdG; p[2] = (byte)stdR; }
}
else
{
byte* pTemp = p - srcData.Stride;
p[0] = (byte)pTemp[0];
p[1] = (byte)pTemp[1];
p[2] = (byte)pTemp[2];
} p += 3;
}
p += srcData.Stride - w * 3;
}
b.UnlockBits(srcData);
}
return b;
}
{
if (b.Equals(null)) { return null; }
int w = b.Width;
int h = b.Height;
int stdR, stdG, stdB;
stdR = 0; stdG = 0; stdB = 0;
BitmapData srcData = b.LockBits(new Rectangle(0, 0, w, h), ImageLockMode.ReadWrite, PixelFormat.Format24bppRgb);
unsafe
{
byte* p = (byte*)srcData.Scan0.ToPointer();
for (int y = 0; y < h; y++)
{
for (int x = 0; x < w; x++)
{
if (y % val == 0)
{
if (x % val == 0) { stdR = p[2]; stdG = p[1]; stdB = p[0]; }
else { p[0] = (byte)stdB; p[1] = (byte)stdG; p[2] = (byte)stdR; }
}
else
{
byte* pTemp = p - srcData.Stride;
p[0] = (byte)pTemp[0];
p[1] = (byte)pTemp[1];
p[2] = (byte)pTemp[2];
} p += 3;
}
p += srcData.Stride - w * 3;
}
b.UnlockBits(srcData);
}
return b;
}
欢迎转载,但请保留链接 http://www.cnblogs.com/limlee
--- GeekLion
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架