Winfrom+Devexpress 之GridControl ConvertTo TileView 制作精美的卡片式看板

gridcontrol如果以卡片的形式展示,刚开始都会选择转成Cardview,或者layoutview,原本我刚开始也是这么干的,cardview和layoutview,调整起来也很麻烦,界面不好看,有次在参考dev的demo的时候偶然发现gridcontrol(我用的dev18版)支持转tileview,

支持更高级的页面,加载展示动画很酷,支持自绘页面。写这篇文章的原因,发现网上对于这个的titleview的资料还是很少的,所有记录一下。,废话不多说,先上官方demo界面。

看板的形式展示

如上图,都是用titleview做的,

首先将gridcontrol转成tileview,然后在设计里面的tile templat里面就可以直接拖界面的,他是表格形式的,直接把你的数据源拖进你想放的位置,就行了。

至此大部分的操作就已经完成了。可以在layout的里面查看一下,同是也可设置间距注意一下,如果是是动态加载多列图片,如这个需要将图片转成二进制在循环element载加进去,附上代码截图

在tileview_itemCustomize事件中做处理,注意加载图片的时候要指定加载的位置(xxx格子里面)

附上代码

 

List<TileViewItemElement> GetMembersElements()
        {
            var result = new List<TileViewItemElement>();
            foreach (var pat in patlist)
            {
                Bitmap pathimage = (Bitmap)Properties.Resources.ResourceManager.GetObject(strs[i]);
                var image = ImageToByte(pathimage);
                var element = new TileViewItemElement();
                element.Image = ByteImageConverter.FromByteArray(image as byte[]);
                result.Add(element);
                //var photo = pat["PatImage"];
                //string[] strs = photo.ToString().Split(',');
                //for (int i = 0; i < strs.Length; i++)
                //{
                //    if (!string.IsNullOrEmpty(strs[i]))
                //    {

                //    }
                //}
            }
            return result;
        }

 

动态加载图片

 foreach (var element in elements)
                {
                    if (i < 5)
                    {
                        TileViewItemElement item = null;
                        e.Item.Elements.Add(element);
                        element.RowIndex = 3;
                        element.ColumnIndex = i;
                        element.AnchorIndent = 6;
                        element.ImageAlignment = TileItemContentAlignment.MiddleCenter;
                        element.ImageScaleMode = TileItemImageScaleMode.ZoomInside;
                        element.AnchorElement = item;
                        item = element;
                        i++;
                    }
                    else
                    {
                        TileViewItemElement item = null;
                        e.Item.Elements.Add(element);
                        element.RowIndex = 4;
                        element.ColumnIndex = j;
                        element.AnchorIndent = 6;
                        element.ImageAlignment = TileItemContentAlignment.MiddleCenter;
                        element.ImageScaleMode = TileItemImageScaleMode.ZoomInside;
                        element.AnchorElement = item;
                        item = element;
                        j++;
                    }

                }

 

 

 

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
客服系统的开发涉及多个方面,包括前端界面的设计和实现、后端的逻辑处理、数据存储和管理等。在此我将简要介绍一下基于WinForm和MySQL数据库实现客服系统的流程和代码示例。 1. 数据库设计 根据客服系统的需求,设计相应的数据库结构。常见的客服系统需要存储用户信息、客服人员信息、聊天记录等,因此需要设计相应的表结构。例如,用户表可以包含用户ID、用户名、邮箱、密码等字段;客服人员表可以包含客服人员ID、姓名、工号、密码等字段;聊天记录表可以包含记录ID、发送方ID、接收方ID、消息内容、发送时间等字段。具体字段和表结构根据实际情况来设计。 2. WinForm界面设计 设计客服系统的WinForm界面,如登录界面、主界面、聊天窗口等。可以使用Visual Studio等开发工具进行设计,将需要的控件拖放到界面上,并设置相应的属性和事件。例如,在登录界面中可以添加文本框、密码框、登录按钮等控件,然后在登录按钮的Click事件中编写相应的代码进行用户身份验证和登录操作。 3. 数据库连接与操作 在WinForm应用程序中,可以使用ADO.NET技术连接MySQL数据库,并进行数据操作。首先需要在应用程序中添加对MySQL数据库的引用,然后使用相应的连接字符串进行连接。例如: ```csharp using System.Data.SqlClient; // 连接字符串 string connString = "Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;"; // 创建连接对象 SqlConnection conn = new SqlConnection(connString); // 打开连接 conn.Open(); // 执行SQL语句 string sql = "SELECT * FROM Users"; SqlCommand cmd = new SqlCommand(sql, conn); SqlDataReader reader = cmd.ExecuteReader(); // 读取数据 while (reader.Read()) { // 处理数据 } // 关闭连接 conn.Close(); ``` 4. 数据库操作代码示例 以下是一个简单的代码示例,用于向数据库中插入一条聊天记录: ```csharp using System.Data.SqlClient; // 连接字符串 string connString = "Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;"; // 创建连接对象 SqlConnection conn = new SqlConnection(connString); // 打开连接 conn.Open(); // 构造插入语句 string sql = "INSERT INTO ChatRecords(SenderID, ReceiverID, Content, SendTime) VALUES (@senderID, @receiverID, @content, @sendTime)"; SqlCommand cmd = new SqlCommand(sql, conn); cmd.Parameters.AddWithValue("@senderID", senderID); cmd.Parameters.AddWithValue("@receiverID", receiverID); cmd.Parameters.AddWithValue("@content", content); cmd.Parameters.AddWithValue("@sendTime", DateTime.Now); // 执行插入操作 int rows = cmd.ExecuteNonQuery(); // 关闭连接 conn.Close(); ``` 以上是基于WinForm和MySQL数据库实现客服系统的简要流程和代码示例,具体实现过程中还需要根据需求进行相应的调整和完善。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值