一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C# - 在GridControl控件上綁定圖片的幾種操作方式詳解

在GridControl控件上綁定圖片的幾種操作方式詳解

2022-02-25 14:38wuhuacong(伍華聰) C#

GridControl控件是經常用來綁定數據的,一般以常規的字符內容為主,有時候也會有圖片的顯示需要,這篇文章主要介紹了在GridControl控件上綁定圖片的幾種操作方式詳解,具有一定的參考價值,感興趣的小伙伴們可以參考一下

我們知道,基于devexpress的開發winform的項目界面的時候,gridcontrol控件是經常用來綁定數據的,一般以常規的字符內容為主,有時候也會有圖片的顯示需要,那么如果顯示圖片,我們應該如何實現呢?本篇隨筆介紹基于原生gridcontrol控件的圖片綁定顯示操作和基于我封裝的分頁控件(封裝gridcontrol的分頁控件)兩種圖片綁定顯示的操作。

1、基于原生的gridcontrol控件圖片綁定

在GridControl控件上綁定圖片的幾種操作方式詳解

綁定圖片,一般我們可以在單元格里面綁定byte[]類型或者image類型,那么控件就會自動顯示圖片出來,當然我們也可以自定義對圖片路徑轉換為圖片然后顯示的,不過就是額外需要增加一些處理而已。

本例子針對這三種方式分別進行介紹,圖片的綁定操作。

為了方便演示,我們創建一個菜單對象類,然后構建一些數據用于列表的綁定操作,如下代碼所示。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
/// <summary>
  /// 模擬一個菜單的對象,包括各種類型的圖片信息
  /// </summary>
  public class menuinfo
  {
    /// <summary>
    /// 編號
    /// </summary>
    public string id { get; set; }
 
    /// <summary>
    /// 圖標名稱
    /// </summary>
    public string name { get; set; }
 
    /// <summary>
    /// 圖片路徑
    /// </summary>
    public string imagefilepath {get;set;}
 
    /// <summary>
    /// 圖標字節
    /// </summary>
    public virtual byte[] embedicon { get; set; }
 
    /// <summary>
    /// 圖標圖片對象
    /// </summary>
    public image imageicon { get; set; }
 
 
    /// <summary>
    /// 構造函數
    /// 為了展示的方便,在構造函數里面構造相應的數據
    /// </summary>
    public menuinfo()
    {
      this.id = guid.newguid().tostring();
      this.name = "測試圖片菜單";
      this.imagefilepath = path.combine(system.environment.currentdirectory, "app.ico");
      if (file.exists(this.imagefilepath))
      {
        this.embedicon = fileutil.filetobytes(this.imagefilepath);
        this.imageicon = imagehelper.imagefromurl(this.imagefilepath);
      }
    }

創建gridcolumn的時候,我們可以利用gridview的擴展函數createcolumn進行創建幾個不同的列,如下代碼所示。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
public partial class frmrepositoryitemimageedit : baseform
  {
    public frmrepositoryitemimageedit()
    {
      initializecomponent();
 
      creategridview();
    }
 
    /// <summary>
    /// 創建gridview1列表所需顯示的列
    /// </summary>
    private void creategridview()
    {
      //創建一個隱藏的id列
      this.gridview1.createcolumn("id", "id").visible = false;
      //串一個名稱的列,并指定寬度
      this.gridview1.createcolumn("name", "名稱", 150);
 
      //創建一個圖片路徑的列,并指定它的編輯控件類型為repositoryitemimageedit
      //并為這個列實現parseeditvalue的方法,用于解析路徑為具體的圖片顯示
      this.gridview1.createcolumn("imagefilepath", "圖片路徑綁定", 100).createimageedit().parseeditvalue += (s, e) =>
      {
        if (e.value != null && e.value is string && e.value.tostring() != string.empty)
        {
          e.value = image.fromfile(string.concat(e.value));
          e.handled = true;
        }
      };
 
      //創建圖片字節的列,用于顯示圖片
      this.gridview1.createcolumn("embedicon", "圖片字節綁定", 100);
      //創建圖片對象的列,用于顯示圖片
      this.gridview1.createcolumn("imageicon", "圖片對象綁定", 100);
    }

上面代碼是創建gridview所需要顯示的列信息,那么我們準備好數據源綁定到列表控件上就可以了,如下代碼所示。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
/// <summary>
/// 綁定列表數據
/// </summary>
private void binddata()
 
{
  //構造只有一個記錄的集合
  list<menuinfo> menulist = new list<menuinfo>()
  {
    new menuinfo()
  };
  //綁定數據源到列表控件上
  this.gridcontrol1.datasource = menulist;
}

2、基于分頁控件的圖片綁定

在GridControl控件上綁定圖片的幾種操作方式詳解

很多時候,我們需要對數據庫的數據進行分頁顯示,以提高顯示的速度和效率,那么利用分頁控件就可以獲得很多這樣統一的界面和高效率顯示數據的好處,基于分頁控件的處理本質上和上面的過程差不多,不過處理的代碼需要變化一下,從而可以正常的實現圖片綁定顯示操作。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/// <summary>
  /// 基于分頁控件的圖片顯示案例
  /// </summary>
  public partial class frmrepositoryitemimageedit2 : baseform
  {
    public frmrepositoryitemimageedit2()
    {
      initializecomponent();
 
      creategridview();
    }
 
    /// <summary>
    /// 創建gridview1列表所需顯示的列
    /// </summary>
    private void creategridview()
    {
      this.wingridviewpager1.onpagechanged += new eventhandler(wingridviewpager1_onpagechanged);
      this.wingridviewpager1.onrefresh += new eventhandler(wingridviewpager1_onrefresh);
      this.wingridviewpager1.appendedmenu = this.contextmenustrip1;
      this.wingridviewpager1.showlinenumber = true;
      this.wingridviewpager1.bestfitcolumnwith = false;//是否設置為自動調整寬度,false為不設置
      this.wingridviewpager1.gridview1.datasourcechanged += new eventhandler(gridview1_datasourcechanged);
    }
 
    /// <summary>
    /// 綁定數據后,分配各列的寬度
    /// </summary>
    private void gridview1_datasourcechanged(object sender, eventargs e)
    {
      //對圖片路徑的列,重新使用repositoryitempictureedit類型
      //然后對該列的控件的parseeditvalue和formateditvalue函數進行實現,從而實現路徑到圖片的顯示
      var edit = this.wingridviewpager1.gridview1.columns.columnbyfieldname("imagefilepath").createpictureedit();     
      edit.parseeditvalue += (s, se) =>
      {
        if (se.value != null && se.value.gettype() == typeof(string) && se.value.tostring() != string.empty)
        {
          if (file.exists(string.concat(se.value)))
          {
            var picture = imagehelper.imagefromurl(string.concat(se.value));
            se.value = picture;
            se.handled = true;
 
          }
        }
      };
      edit.formateditvalue += (s, se) =>
      {
        if (file.exists(string.concat(se.value)))
        {
          var picture = imagehelper.imagefromurl(string.concat(se.value));
          se.value = picture;
          se.handled = true;
        }
      };
 
 
      if (this.wingridviewpager1.gridview1.columns.count > 0 && this.wingridviewpager1.gridview1.rowcount > 0)
      {
        //統一設置100寬度
        foreach (devexpress.xtragrid.columns.gridcolumn column in this.wingridviewpager1.gridview1.columns)
        {
          column.width = 120;
        }
 
        //可特殊設置特別的寬度
        gridview gridview = this.wingridviewpager1.gridview1;
        if (gridview != null)
        {
          //gridview.setgridcolumwidth("note", 200);
        }
      }
    }

而在分頁控件的數據綁定的時候,我們指定列名的中文名即可,如下代碼所示

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
/// <summary>
    /// 綁定列表數據
    /// </summary>
    private void binddata()
    {
      #region 添加別名解析
 
      this.wingridviewpager1.displaycolumns = "name,imagefilepath,embedicon,imageicon";
      this.wingridviewpager1.addcolumnalias("id", "編號");
      this.wingridviewpager1.addcolumnalias("name", "名稱");
      this.wingridviewpager1.addcolumnalias("imagefilepath", "圖片路徑綁定");
      this.wingridviewpager1.addcolumnalias("embedicon", "圖片字節綁定");
      this.wingridviewpager1.addcolumnalias("imageicon", "圖片對象綁定");
 
      this.wingridviewpager1.gridview1.optionsbehavior.editable = true;
      this.wingridviewpager1.gridview1.optionsbehavior.readonly = false;
 
      #endregion
 
      //構造只有一個記錄的集合
      list<menuinfo> menulist = new list<menuinfo>()
      {
        new menuinfo()
      };
 
      this.wingridviewpager1.datasource = menulist;
    }

以上就是基于gridcontrol控件上綁定圖片的幾種操作方式,方便我們在項目中參考使用。希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:http://www.cnblogs.com/wuhuacong/p/9145765.html

延伸 · 閱讀

精彩推薦
  • C#C#通過KD樹進行距離最近點的查找

    C#通過KD樹進行距離最近點的查找

    這篇文章主要為大家詳細介紹了C#通過KD樹進行距離最近點的查找,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    帆帆帆6112022-01-22
  • C#C#裁剪,縮放,清晰度,水印處理操作示例

    C#裁剪,縮放,清晰度,水印處理操作示例

    這篇文章主要為大家詳細介紹了C#裁剪,縮放,清晰度,水印處理操作示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    吳 劍8332021-12-08
  • C#WPF 自定義雷達圖開發實例教程

    WPF 自定義雷達圖開發實例教程

    這篇文章主要介紹了WPF 自定義雷達圖開發實例教程,本文介紹的非常詳細,具有參考借鑒價值,需要的朋友可以參考下...

    WinterFish13112021-12-06
  • C#C#實現XML文件讀取

    C#實現XML文件讀取

    這篇文章主要為大家詳細介紹了C#實現XML文件讀取的相關代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    Just_for_Myself6702022-02-22
  • C#C#設計模式之Visitor訪問者模式解決長隆歡樂世界問題實例

    C#設計模式之Visitor訪問者模式解決長隆歡樂世界問題實例

    這篇文章主要介紹了C#設計模式之Visitor訪問者模式解決長隆歡樂世界問題,簡單描述了訪問者模式的定義并結合具體實例形式分析了C#使用訪問者模式解決長...

    GhostRider9502022-01-21
  • C#深入解析C#中的交錯數組與隱式類型的數組

    深入解析C#中的交錯數組與隱式類型的數組

    這篇文章主要介紹了深入解析C#中的交錯數組與隱式類型的數組,隱式類型的數組通常與匿名類型以及對象初始值設定項和集合初始值設定項一起使用,需要的...

    C#教程網6172021-11-09
  • C#Unity3D實現虛擬按鈕控制人物移動效果

    Unity3D實現虛擬按鈕控制人物移動效果

    這篇文章主要為大家詳細介紹了Unity3D實現虛擬按鈕控制人物移動效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一...

    shenqingyu060520232410972022-03-11
  • C#C# 實現對PPT文檔加密、解密及重置密碼的操作方法

    C# 實現對PPT文檔加密、解密及重置密碼的操作方法

    這篇文章主要介紹了C# 實現對PPT文檔加密、解密及重置密碼的操作方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下...

    E-iceblue5012022-02-12
主站蜘蛛池模板: 色亚| a级情欲片在线观看hd | 日韩制服丝袜在线观看 | 成年人免费观看的视频 | 日本理论片中文在线观看2828 | 国产男女性特黄录像 | 免费的强动漫人物 | 久久婷婷五月综合色丁香 | 国产精品久久99 | 成年看片免费高清观看 | 果冻传媒在线视频观看免费 | 国模一区二区三区视频一 | 草草在线免费视频 | 精品国产美女AV久久久久 | 色呦呦tv | 2020中文字幕 | 国产一区二区视频在线观看 | 国产精品久久久久久五月尺 | 国产在线观看福利片 | 动漫在线观看h | 四虎影视网址 | 欧式午夜理伦三级在线观看 | 97午夜视频| 亚洲精品电影天堂网 | 1986葫芦兄弟全集免费观看第十集 | 和肥岳在厨房激情 | 波多野结衣中文字幕 | 国人精品视频在线观看 | 7788理论片在线观看 | 欧美丰满大乳大屁在线观看股 | 午夜国产在线 | 紧身短裙女教师波多野 | 好大好硬好湿好紧h | yy6080久久国产伦理 | 成年美女黄网站色视频大全免费 | 91麻豆国产精品91久久久 | 男女视频在线观看网站 | 国产午夜亚洲精品不卡 | 2022超帅男同gayxxx | 日本护士撒尿xxxx18 | 日韩精品欧美国产精品亚 |