亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

c#掃描圖片去黑邊(掃描儀去黑邊)

2020-01-24 02:44:54
字體:
來源:轉載
供稿:網友

自動去除圖像掃描黑邊

復制代碼 代碼如下:

/// <summary>
        /// 自動去除圖像掃描黑邊
        /// </summary>
        /// <param name="fileName"></param>
        public static void AutoCutBlackEdge(string fileName)
        {
            //打開圖像
            Bitmap bmp = OpenImage(fileName);

            RemoveBlackEdge(bmp);
            //保存圖像
            SaveImage(bmp, fileName);
        }

        private static byte[] rgbValues; // 目標數組內存

        /// <summary>
        /// 圖像去黑邊
        /// </summary>
        /// <param name="bmp"></param>
        /// <returns></returns>
        private static Bitmap RemoveBlackEdge(Bitmap bmp)
        {
            Rectangle rect = new Rectangle(0, 0, bmp.Width, bmp.Height);
            BitmapData bmpData = bmp.LockBits(rect, ImageLockMode.ReadWrite, bmp.PixelFormat);

            // 獲取圖像參數 
            int w = bmpData.Width;
            int h = bmpData.Height;
            int stride = bmpData.Stride;  // 掃描線的寬度
            double picByteSize = GetPicByteSize(bmp.PixelFormat);
            int bWidth = (int)Math.Ceiling(picByteSize * w); //顯示寬度
            int offset = stride - bWidth;  // 顯示寬度與掃描線寬度的間隙 
            IntPtr ptr = bmpData.Scan0;   // 獲取bmpData的內存起始位置 
            int scanBytes = stride * h;  // 用stride寬度,表示這是內存區域的大小

            // 分別設置兩個位置指針,指向源數組和目標數組 
            int posScan = 0;
            rgbValues = new byte[scanBytes];  // 為目標數組分配內存 
            Marshal.Copy(ptr, rgbValues, 0, scanBytes);  // 將圖像數據拷貝到rgbValues中 

            bool isPass = true;
            int i = 0, j = 0;
            int cutW = (int)(bWidth * 0.02); //2%寬度(可修改)
            int cutH = (int)(h * 0.02);      //2%高度(可修改)
            int posLen = (int)(picByteSize * 8); //繼續查找深度為8的倍數(可修改)
            //左邊
            for (i = 0; i < h; i++)
            {
                for (j = 0; j < bWidth; j++)
                {
                    isPass = true;
                    if (rgbValues[posScan] < 255) rgbValues[posScan] = 255;

                    if (rgbValues[posScan + 1] == 255)
                    {
                        for (int m = 1; m <= posLen; m++)
                        {
                            if (rgbValues[posScan + m] < 255) isPass = false;
                        }
                    }
                    if (rgbValues[posScan + 1] < 255 || bWidth / 2 < j) isPass = false;
                    recCheck(ref rgbValues, posScan, h, stride, true);

                    posScan++;
                    if (j >= cutW && isPass) break;
                }
                // 跳過圖像數據每行未用空間的字節,length = stride - width * bytePerPixel 
                if (j == bWidth) posScan += offset;
                else posScan += (offset + bWidth - j - 1);
            }
            //右邊
            posScan = scanBytes - 1;
            for (i = h - 1; i >= 0; i--)
            {
                posScan -= offset;
                for (j = bWidth - 1; j >= 0; j--)
                {
                    isPass = true;
                    if (rgbValues[posScan] < 255) rgbValues[posScan] = 255;

                    if (rgbValues[posScan - 1] == 255)
                    {
                        for (int m = 1; m <= posLen; m++)
                        {
                            if (rgbValues[posScan - m] < 255) isPass = false;
                        }
                    }
                    if (rgbValues[posScan - 1] < 255 || bWidth / 2 > j) isPass = false;
                    recCheck(ref rgbValues, posScan, h, stride, false);

                    posScan--;
                    if (cutH < (h - i))
                        if (j < (bWidth - cutW) && isPass) break;
                }
                // 跳過圖像數據每行未用空間的字節,length = stride - width * bytePerPixel
                if (j != -1) posScan -= j;
            }

            // 內存解鎖 
            Marshal.Copy(rgbValues, 0, ptr, scanBytes);
            bmp.UnlockBits(bmpData);  // 解鎖內存區域 

            return bmp;
        }

        /// <summary>
        /// 上下去除黑邊時,臨近黑點去除
        /// </summary>
        /// <param name="rgbValues"></param>
        /// <param name="posScan"></param>
        /// <param name="h"></param>
        /// <param name="stride"></param>
        /// <param name="islLeft"></param>
        private static void recCheck(ref byte[] rgbValues, int posScan, int h, int stride, bool islLeft)
        {
            int scanBytes = h * stride;
            int cutH = (int)(h * 0.01); //臨近最大1%高度(可修改)
            for (int i = 1; i <= cutH; i++)
            {
                int befRow = 0;
                if (islLeft && (posScan - stride * i) > 0)
                {
                    befRow = posScan - stride * i;
                }
                else if (!islLeft && (posScan + stride * i) < scanBytes)
                {
                    befRow = posScan + stride * i;
                }
                if (rgbValues[befRow] < 255) rgbValues[befRow] = 255;
                else break;
            }
        }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美极品在线视频| 久久精品视频免费播放| 韩国三级日本三级少妇99| 国产成人免费av| 91精品国产成人| 久久躁日日躁aaaaxxxx| 九九热最新视频//这里只有精品| 亚洲欧美色婷婷| 91精品国产高清久久久久久91| 日韩一二三在线视频播| 亚洲va欧美va国产综合剧情| 亚洲美女视频网| 国产亚洲精品一区二555| 欧美成人免费在线视频| 国精产品一区一区三区有限在线| 国产精品极品美女在线观看免费| 日韩av综合中文字幕| 丝袜亚洲另类欧美重口| 国产成人亚洲综合91| 九九久久综合网站| 在线看日韩av| 亚洲免费中文字幕| 欧美大奶子在线| 91国语精品自产拍在线观看性色| 国产精品一区二区三| 最近2019中文字幕一页二页| 欧美激情videoshd| 亚洲国产精久久久久久| 久久久精品在线观看| 欧美性猛交xxxx乱大交| 国产精品video| 欧美成aaa人片在线观看蜜臀| 亚洲欧美成人一区二区在线电影| 韩国日本不卡在线| 亚洲精品免费网站| 国产亚洲一区二区精品| 亚洲精品女av网站| 欧美大片免费观看在线观看网站推荐| 欧美大片va欧美在线播放| 国产精品高潮呻吟视频| 91免费看片网站| 国产亚洲精品久久久久久牛牛| 国产成人在线视频| 国产裸体写真av一区二区| 51午夜精品视频| 亚洲国产精品电影在线观看| 国产精品444| 欧美日韩国产激情| 欧美午夜视频一区二区| 久久人人爽人人爽人人片亚洲| 欧美日韩亚洲一区二区三区| 欧美怡红院视频一区二区三区| 国产精品极品尤物在线观看| …久久精品99久久香蕉国产| 色偷偷888欧美精品久久久| 国产精品入口免费视| 高清视频欧美一级| 国产在线a不卡| 亚洲午夜性刺激影院| 欧美日韩性视频在线| 国产精品一区二区三区毛片淫片| 国产欧美日韩中文字幕| 久久久久久久久国产精品| 国产精品久久综合av爱欲tv| 粉嫩av一区二区三区免费野| 自拍偷拍亚洲精品| 久久99久国产精品黄毛片入口| 亚洲色图av在线| 欧美亚洲在线播放| 亚洲男人第一av网站| 亚洲成色777777在线观看影院| 综合av色偷偷网| 精品国内自产拍在线观看| 亚洲成人黄色网址| 羞羞色国产精品| 伊人久久久久久久久久久久久| 日本高清视频一区| 国产成+人+综合+亚洲欧美丁香花| 91中文精品字幕在线视频| 亚洲区中文字幕| 国产精品啪视频| 国产精品91久久久| 欧美另类精品xxxx孕妇| 欧美日韩国产精品| 久久久亚洲国产| 伊人久久久久久久久久久| 中文国产成人精品| 91av在线免费观看视频| 在线电影av不卡网址| 精品免费在线视频| 国产精品露脸av在线| 国产网站欧美日韩免费精品在线观看| 激情懂色av一区av二区av| 91在线播放国产| 91久久精品国产91久久| 色综合天天狠天天透天天伊人| 国产精品91免费在线| 成人网在线免费看| 久久天天躁狠狠躁老女人| 国产精品99久久久久久久久| 成人精品视频久久久久| 中文字幕亚洲综合| 亚洲欧洲在线视频| 欧美乱大交xxxxx另类电影| 91福利视频网| 成人福利视频网| 亚洲欧美激情另类校园| 78m国产成人精品视频| 久久久成人精品视频| 国产精品精品久久久久久| 蜜臀久久99精品久久久无需会员| 亚洲欧美色图片| 亚洲第一精品久久忘忧草社区| 成人黄色在线观看| 亚洲区免费影片| 欧美在线亚洲一区| 欧美理论电影在线观看| 亚洲色图35p| 2019中文字幕全在线观看| 亚洲精品国精品久久99热| 超碰日本道色综合久久综合| 自拍偷拍亚洲精品| 91精品国产91久久久久久最新| 国产精品扒开腿爽爽爽视频| 亚洲精品国产综合久久| 福利视频第一区| 精品在线观看国产| 国产精品成人国产乱一区| 日韩激情av在线播放| 国产成人精品久久二区二区| 日韩性xxxx爱| 午夜精品三级视频福利| 久久精品国产精品亚洲| 亚洲国产欧美一区二区丝袜黑人| 精品呦交小u女在线| 国内精品一区二区三区| 欧美床上激情在线观看| 91亚洲精品久久久久久久久久久久| 久热99视频在线观看| 日韩av一卡二卡| 国产亚洲在线播放| 欧美成人自拍视频| 一区二区日韩精品| 国产婷婷色综合av蜜臀av| 国产精品午夜一区二区欲梦| 国产成人久久精品| 国产欧美精品日韩| 国产一区二区成人| 成人久久精品视频| 国产欧美一区二区三区久久| 91av在线网站| 性欧美视频videos6一9| 国产精品99久久久久久人| 国产成人精品一区二区在线| 成人国产在线激情| 欧美巨猛xxxx猛交黑人97人| 在线播放日韩精品| 国a精品视频大全| 精品国产成人在线| 热久久99这里有精品| 成人亚洲激情网| 成人激情视频在线| 欧美老少做受xxxx高潮| 亚洲精品一区中文|