国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

.NET傳圖識(shí)色

2019-11-14 14:26:19
字體:
供稿:網(wǎng)友
前些日子看千圖網(wǎng)的傳圖識(shí)色有點(diǎn)好奇就查找了一些資料,在此分析下:

首先,創(chuàng)建一個(gè)值類型:
 1 public struct MajorColor : IComparable<MajorColor> 2 { 3     internal int Color;//顏色值 4     internal int Amount;//顏色總數(shù) 5     public MajorColor(int Color, int Amount) 6     { 7         this.Color = Color; 8         this.Amount = Amount; 9     }10     public int CompareTo(MajorColor obj)11     {12         return this.Amount.CompareTo(obj.Amount);13     }14 }
創(chuàng)建一個(gè)值類型

接下來是主要算法:

 1 /// <summary> 2 /// 識(shí)別主色調(diào) 3 /// </summary> 4 /// <param name="Bmp">Bmp位圖</param> 5 /// <param name="PCAAmount">主色調(diào)數(shù)目</param> 6 /// <param name="Delta">閾值</param> 7 /// <returns></returns> 8 public unsafe static List<MajorColor> PRincipalColorAnalysis(Bitmap Bmp, int PCAAmount, int Delta = 24) 9 {10     List<MajorColor> MC = new List<MajorColor>();11 12     int X, Y, Width, Height, Stride, Index, TotalColorAmount = 0;13     int HalfDelta;14     byte* Pointer, Scan0;//定義指針?biāo)孕枰猽nsafe關(guān)鍵字15     BitmapData BmpData = Bmp.LockBits(new Rectangle(0, 0, Bmp.Width, Bmp.Height), ImageLockMode.ReadWrite, PixelFormat.Format24bppRgb);//將位圖鎖定到系統(tǒng)內(nèi)存中16     Height = Bmp.Height;17     Width = Bmp.Width;18     Stride = BmpData.Stride;//Bitmap對(duì)象的跨距寬度(也稱掃描寬度)19     Scan0 = (byte*)BmpData.Scan0;//位圖中第一個(gè)像素?cái)?shù)據(jù)的地址20 21     int[] Table = new int[256 * 256 * 256];22     int[] NonZero = new int[Width * Height];23     int[] Map = new int[256];24 25     if (Delta > 2)26     {27         HalfDelta = Delta / 2 - 1;28     }29     else30     {31         HalfDelta = 0;32     }33     for (Y = 0; Y < 256; Y++)34     {35         Map[Y] = ((Y + HalfDelta) / Delta) * Delta;36         if (Map[Y] > 255) Map[Y] = 255;37     }38     for (Y = 0; Y < Height; Y++)39     {40         Pointer = Scan0 + Stride * Y;41         for (X = 0; X < Width; X++)42         {43             Index = (Map[*Pointer] << 16) + (Map[*(Pointer + 1)] << 8) + Map[*(Pointer + 2)];44             if (Table[Index] == 0)//顏色未出現(xiàn)45             {46                 NonZero[TotalColorAmount] = Index;//記錄顏色47                 TotalColorAmount++;//總數(shù)加148             }49             Table[Index]++;//對(duì)應(yīng)的顏色數(shù)目加150             Pointer += 3;//遍歷下個(gè)像素51         }52     }53     MajorColor[] Result = new MajorColor[TotalColorAmount];54     for (Y = 0; Y < TotalColorAmount; Y++)55     {56         Result[Y].Amount = Table[NonZero[Y]];57         Result[Y].Color = NonZero[Y];58     }59     Array.Sort(Result);//排序60     Array.Reverse(Result);//反轉(zhuǎn)61 62     for (Y = 0; Y < (Result.Length > PCAAmount ? PCAAmount : Result.Length); Y++)63     {64         MC.Add(new MajorColor(Result[Y].Color, Result[Y].Amount));65     }66     Bmp.UnlockBits(BmpData);//從系統(tǒng)內(nèi)存中解鎖此位圖67     GC.Collect();//釋放內(nèi)存68     return MC;69 }
算法

unsafe關(guān)鍵字編譯報(bào)錯(cuò)解決方案:項(xiàng)目屬性-生成-勾選允許不安全代碼即可。

最后獲取到的List< MajorColor > 就是我們要獲取的主色調(diào)了。

接下來遍歷循環(huán)獲取所有色調(diào)

 1 if (MC != null) 2 { 3     for (int i = 0; i < MC.Count; i++) 4     { 5         IntToColor(MC[i].Color))); 6     } 7 } 8 //顏色值轉(zhuǎn)換成RGB 9 public static string IntToColor(int color)10 {11     int R = color & 255;12     int G = (color & 65280) / 256;13     int B = (color & 16711680) / 65536;14     return ColorTranslator.ToHtml(System.Drawing.Color.FromArgb(R, G, B));15 }
循環(huán)獲取色調(diào)

這塊小功能也算初步完成了,至于圖片怎么傳到后臺(tái)這個(gè)應(yīng)該不用說明了。

友情提示:B/S可將圖片轉(zhuǎn)成Base64數(shù)字編碼。

源碼來源于 ->作者 : laviewpbt

 


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 和田市| 阳东县| 陆良县| 新巴尔虎右旗| 庐江县| 云梦县| 建平县| 东乌珠穆沁旗| 石渠县| 九龙县| 武隆县| 鄱阳县| 阿鲁科尔沁旗| 盐山县| 西峡县| 巨鹿县| 曲水县| 邯郸市| 青海省| 申扎县| 三穗县| 竹北市| 闻喜县| 大田县| 淮北市| 安溪县| 嘉黎县| 驻马店市| 阜宁县| 苗栗县| 京山县| 锡林浩特市| 建昌县| 临武县| 突泉县| 武冈市| 廉江市| 绩溪县| 宜兰县| 凌云县| 金门县|