开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 2478|回复: 42
收起左侧

[其它源码] 【2023开源大赛】C#隔行扫描代码

[复制链接]
结帖率:95% (84/88)
发表于 2023-11-16 13:43:56 | 显示全部楼层 |阅读模式   美国
分享源码
界面截图: -
是否带模块: 纯源码
备注说明: -
本帖最后由 陽陽陽 于 2023-11-22 09:26 编辑
效果图:
两张大图:
1.bmp
4.bmp

隔行扫描找不同后的图:
27954.bmp
75326.bmp

里面带着不同的开始坐标。

延迟大的图片在100ms左右,越小越快
目前还没找到改进的方法,欢迎大佬改进。。。

[C#] 纯文本查看 复制代码
namespace Diff
{
public class InterlacedScanningDiff
{
private int separation = 10;
public static bool HasDiff(ref Bitmap b1, ref Bitmap b2, Rectangle area, int separation_ = 10)
{
int w = area.Width;
int h = area.Height;

for (int i = 1; i < (int)(h / separation_); i++)
{
for (int n = 0; n < w; n++)
{
if (b1.GetPixel(n + area.X, i * separation_ + area.Y) != b2.GetPixel(n + area.X, i * separation_ + area.Y))
{
return true;
}
}
}
return false;
}
public void GetDiff(Bitmap b1, Bitmap b2, out List<InterlacedScanningImageInfo> infor, out List<Bitmap> imgs)
{
List<InterlacedScanningImageInfo> ls = new List<InterlacedScanningImageInfo>();
int w = (b1.Width < b2.Width) ? (b1.Width) : (b2.Width); //最小的
int h = (b1.Height < b2.Height) ? (b1.Height) : (b2.Height);

for (int i = 1; i < (int)(h / separation); i++)
{
for (int n = 0; n < w; n++)
{
if (b1.GetPixel(n, i * separation) != b2.GetPixel(n, i * separation))
{
//Rectangle rectangle = new Rectangle(0, (i - 1) * separation, w, separation * 2);
//, image = Drawing.PartImage.ExtractRegionFromImage(b2, rectangle)
ls.Add(new InterlacedScanningImageInfo() { StartPos = (i - 1) * separation, Height = separation * 2 }); // i -1, i , i + 1
i += 1; // i+1+1
Console.WriteLine(i);
break;
/*


-----------------------
----------------------=i-1
-----------------------找到的线 - i height = 2 * space
----------------------=i+1---------------------------------------不同i-1
-----------------------i+=2 - 再从这开始 -假如有不同 不同i height = 2 * space
----------------------- 不同i+1
-----------------------
-----------------------
*/
}
}
}

foreach (var a in ls)
{
Console.WriteLine("stat pos: " + a.StartPos + " end pos: " + (a.Height + a.StartPos));
}
for (int i = 0; i < ls.Count; i++)
{
for (int n = 0; n < ls.Count; n++)
{
if (ls[n].StartPos + ls[n].Height == ls.StartPos) //i在底下
{
//var temp = ls[n];
//temp.height = ls[n].height;
//ls[n] = temp;
//ls.RemoveAt(i);
//i--;
var temp = ls;
temp.StartPos = ls[n].StartPos;
temp.Height = ls.Height + ls[n].Height;
ls = temp;
ls.RemoveAt(n);

i--;
}
}
}
foreach (var a in ls)
{
Console.WriteLine(a.StartPos);
}

List<Bitmap> bitmaps = new List<Bitmap>();
foreach (var a in ls)
{
Rectangle rectangle = new Rectangle(0, a.StartPos, w, a.Height);
bitmaps.Add(Drawing.PartImage.ExtractRegionFromImage(b2, rectangle));
}
infor = ls;
imgs = bitmaps;
}
}
public struct InterlacedScanningImageInfo
{
public int StartPos;
public int Height;
//public Bitmap image;
}
}

编辑补充:
1:既然大家都参与了开源大赛,我这前几天帖子发急了,现在编辑一下
2:修复了几个小问题
3:添加了隔行扫描判断图片是否变化,非常快,比直接对比点阵信息有效率,而且还能一定程度地去除微小变化(如果需要精确判断是否变化,可能不适用)

附赠一个精确找不同源码(如果短时间内频繁调用可会失效):
[C#] 纯文本查看 复制代码
                        //var bmp1 = b1.Clone(a, PixelFormat.Format8bppIndexed);
                        //Monitor.Enter(imageMonitor);


                        //var data = b1.LockBits(a, ImageLockMode.ReadWrite, PixelFormat.Format8bppIndexed);
                        //IntPtr ptr = data.Scan0;
                        //int NumBytes = data.Stride * data.Height;
                        //byte[] rgbValues1 = new byte[NumBytes];
                        //Marshal.Copy(ptr, rgbValues1, 0, NumBytes);
                        //b1.UnlockBits(data);

                        //var data2 = b2.LockBits(a, ImageLockMode.ReadWrite, PixelFormat.Format8bppIndexed);
                        //IntPtr ptr2 = data2.Scan0;
                        //int NumBytes2 = data2.Stride * data2.Height;
                        //byte[] rgbValues2 = new byte[NumBytes2];
                        //Marshal.Copy(ptr2, rgbValues2, 0, NumBytes2);
                        //b2.UnlockBits(data2);

                        ////for(int i = 0; i < 20; i++) Console.WriteLine("1 ---- " + rgbValues1);
                        ////for(int i = 0; i < 20; i++) Console.WriteLine("2 ---- " + rgbValues2);

                        //Monitor.Exit(imageMonitor);

                        //if (!md5.ComputeHash(rgbValues1).SequenceEqualEX(md5.ComputeHash(rgbValues2)))
                        //{
                        //    //for (int i = 0; i < rgbValues1.Length; i++)
                        //    //{
                        //    //    if (rgbValues1 != rgbValues2) Console.WriteLine("diff at pos" + i + ": " + rgbValues1 + " and " + rgbValues2);
                        //    //}
                        //    Monitor.Enter(listMonitor);
                        //    // Console.WriteLine(diffList.FirstOrDefault(x => x.X == a.X && x.Y == a.Y && x.Width == a.Width && x.Height == a.Height) == default);
                        //    if (diffList.FirstOrDefault(x => x.X == a.X && x.Y == a.Y && x.Width == a.Width && x.Height == a.Height) == default)
                        //    {
                        //        diffList.Add(a);
                        //        changeAction?.Invoke();
                        //        Console.WriteLine("Add one");
                        //    }
                        //    Monitor.Exit(listMonitor);
                        //}


评分

参与人数 1精币 +1 收起 理由
wa690602724 + 1 感谢分享,很给力!~

查看全部评分


本帖被以下淘专辑推荐:

签到天数: 8 天

发表于 2023-11-27 21:24:55 | 显示全部楼层   山西省吕梁市
感谢大佬分享~~
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)
发表于 2023-11-25 15:29:54 | 显示全部楼层   河南省郑州市

回帖奖励 +2 枚 精币

回复 支持 反对

使用道具 举报

结帖率:100% (27/27)

签到天数: 3 天

发表于 2023-11-24 13:14:07 | 显示全部楼层   香港特别行政区*

回帖奖励 +2 枚 精币

        感谢分享,很给力!~
回复 支持 反对

使用道具 举报

结帖率:75% (3/4)

签到天数: 7 天

发表于 2023-11-24 09:48:04 | 显示全部楼层   河北省沧州市

回帖奖励 +2 枚 精币

【2023开源大赛】C#隔行扫描代码
回复 支持 反对

使用道具 举报

签到天数: 15 天

发表于 2023-11-23 19:34:50 | 显示全部楼层   广东省揭阳市

回帖奖励 +2 枚 精币

新技能已get√
回复 支持 反对

使用道具 举报

签到天数: 2 天

发表于 2023-11-23 18:09:08 | 显示全部楼层   广东省汕尾市

回帖奖励 +2 枚 精币

谢谢分享。。。
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)

签到天数: 3 天

发表于 2023-11-23 18:03:44 | 显示全部楼层   河南省周口市

回帖奖励 +2 枚 精币

感谢分享,很给力!~
回复 支持 反对

使用道具 举报

结帖率:100% (29/29)

签到天数: 15 天

发表于 2023-11-23 16:42:20 | 显示全部楼层   山东省潍坊市

回帖奖励 +2 枚 精币

感谢分享,
回复 支持 反对

使用道具 举报

结帖率:100% (1/1)

签到天数: 14 天

发表于 2023-11-23 16:37:16 | 显示全部楼层   山东省济南市

回帖奖励 +2 枚 精币

膜拜大佬作品
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 诚聘英才| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 800073686,邮箱:800073686@b.qq.com
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表