我们经常用到显示各种颜色,但又不知道颜色的效果与名称或值。没有一个颜色板进行查询。
我的做法是把颜色以网页的形式显示出来,存放到word文档里以备查询。可能法子笨了点,但还挺管用。
由于color为struct类型,所以无法直接获取出来。方法如下:
private void GetColors() { System.Reflection.PropertyInfo[] fs = typeof(System.Drawing.Color).GetProperties(); int i = 0; DataTable dt = new DataTable("colors"); dt.Columns.Add(new DataColumn("颜色名称")); dt.Columns.Add(new DataColumn("十六进制值")); dt.Columns.Add(new DataColumn("十进制值")); dt.Columns.Add(new DataColumn("效果")); foreach (System.Reflection.PropertyInfo f in fs) { if (f.ToString().IndexOf("System.Drawing.Color") != -1) { string s = f.ToString().Replace("System.Drawing.Color ", ""); System.Drawing.Color c = System.Drawing.Color.FromName(s); DataRow dr = dt.NewRow(); dr[0] = s; dr[1] = "#" + c.R.ToString("X").PadLeft(2, '0') + c.G.ToString("X").PadLeft(2, '0') + c.B.ToString("X").PadLeft(2, '0'); dr[2] = c.R.ToString() + " " + c.G.ToString() + " " + c.B.ToString(); dr[3] = " "; dt.Rows.Add(dr); } i++; } this.GridView1.DataSource = dt; this.GridView1.DataBind(); }
还需要添加显示的效果。
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e) { if (e.Row.RowType != DataControlRowType.DataRow) return; System.Drawing.Color c = System.Drawing.Color.FromName(e.Row.Cells[0].Text.Trim()); e.Row.Cells[3].BackColor = c; }