按标签的坐标值对标签的二维码/条码排序
本博客主要还是为了学习Lambda 表达式运算符 =>,微软帮助参考地址为:
[1]: https://docs.microsoft.com/zh-cn/previous-versions/visualstudio/visual-studio-2010/bb397687(v%3Dvs.100)
=> 运算符(C# 参考)
[2]: https://docs.microsoft.com/zh-cn/previous-versions/visualstudio/visual-studio-2010/bb311046(v%3Dvs.100)
当我们用工业相机读取标签的条码/二维码时(下面统称为:ID码),视野内会有N多个ID码,读码工具读码是随机读取的(也有可能它是按图像的明暗度来读取的),这时为了顺序的得到ID码,就要根据标签的坐标对它进行排序了,可以先按Y坐标排序,再按X坐标排序。此处为了简化代码,视野内只放一排标签,或搜索范围只设为一批,只对X坐标排序。
方法一:加入到数组,使用冒泡排序。实际使用的排序是改进过的选择排序,比冒泡排序快一些。
int len = IDTool.Results.Count;
string[] code = new string[len];
double[] x = new double[len];
for (int i = 0; i < len; i++)
{
cogDisplay1.InteractiveGraphics.Add(IDTool.Results[i].CreateResultGraphics(CogIDResultGraphicConstants.All), "IDResult", true);
code[i] = IDTool.Results[i].DecodedData.DecodedString.ToString();
x[i] = IDTool.Results[i].CenterX;
}
//按位置冒泡排序,选择排序(循环后置,升序降序和循环里面的判断有关)
for (int i = 0; i < len - 1; i++)
{
for (int j = 0; j < len - i - 1; j++)
{
if (x[j] > x[j + 1])
{
double xTmp = x[j + 1];
x[j