1、前期准备
VS2019、DevExpress19.2、MySql5.7、FreeSql3.2.808、.Net Farmework 4.8
2、创建本次示例中所需数据库及表
我这里建立的数据库为loldb,其下会使用到hero和country两个表
data:image/s3,"s3://crabby-images/5e4d5/5e4d5edd03e28db3e815623622fb6ec673f92dbc" alt=""
data:image/s3,"s3://crabby-images/1cde6/1cde647d634e446104c390583fc0f14ecc45917b" alt=""
3、在VS2019进行代码实现
1、首先在vs2019中建立一个WinForm窗体,并取名TileViewDemo
data:image/s3,"s3://crabby-images/d094f/d094fe70139a617e4781235fd4d30bac85836396" alt=""
data:image/s3,"s3://crabby-images/e56d9/e56d910298e70b8121c6f41d14c538d8a3689ec5" alt=""
2、窗体创建完成后引入我们本次会使用到的dll文件
Dev类目dll文件引用时需要我们在系统中确保已经安装了DevExpress19.2
FreeSql类目dll文件可以通过NuGet手动下载对应版本
data:image/s3,"s3://crabby-images/a4786/a478661da322624e79a95f5c792720c216d32a21" alt=""
3、为了美观,可设置为DevExpress窗体
data:image/s3,"s3://crabby-images/b2508/b2508a42c9660612e61c3938fd4195f7d6745c7b" alt=""
4、回到设计界面,在工具箱中找到对应控件
找到GridControl控件拖拽至主界面中,并将该控件Dock设置为Fill。
data:image/s3,"s3://crabby-images/2cae1/2cae15c3c0c1d46e965bab073b1fabf2eaea95f4" alt=""
转换view为TileView
data:image/s3,"s3://crabby-images/e2304/e23042284a32c0ee47e11afbccc11aa0099c397f" alt=""
data:image/s3,"s3://crabby-images/facfc/facfcfd8f8f44aa64a5b3604e999c69f02dbc44b" alt=""
5、点击Run Designer进行内容设计
添加column列表,并对一些特殊column进行设置
data:image/s3,"s3://crabby-images/b5ec8/b5ec89f23a2311c210ae33558fc6a88561ca7a17" alt=""
data:image/s3,"s3://crabby-images/655f8/655f86cc56e977ca838c99bcd2f5447fa3a2130b" alt=""
Views设置
data:image/s3,"s3://crabby-images/cd64e/cd64e27abb1fa6e01f771d84d3e973489b7b5537" alt=""
Layout设置
data:image/s3,"s3://crabby-images/ff273/ff273c123017f7f576af60feac0c35a5e63ab3f8" alt=""
Tile Template设置
data:image/s3,"s3://crabby-images/a73ff/a73ffba82c94cd144d5adf06d2b2d93407db92cf" alt=""
6、创建数据库连接类
data:image/s3,"s3://crabby-images/26431/2643171fca7c19b0bcaeb8cb397926d27e393629" alt=""
7、创建Domain
data:image/s3,"s3://crabby-images/b9fa0/b9fa0ae8ffd261b0d6ae6bf5f86bb04c03da0162" alt=""
hero表- using System;
- using System.Collections.Generic;
- using Newtonsoft.Json;
- using FreeSql.DataAnnotations;
- namespace Domain {
- [JsonObject(MemberSerialization.OptIn)]
- public partial class hero {
- [JsonProperty, Column(IsPrimary = true, IsIdentity = true)]
- public int N_Id { get; set; }
- [JsonProperty]
- public int CountryId { get => _CountryId; set {
- if (_CountryId == value) return;
- _CountryId = value;
- country = null;
- } }
- private int _CountryId;
- [JsonProperty]
- public string ImgSrc { get; set; }
- [JsonProperty]
- public string Name { get; set; }
- [JsonProperty]
- public string NickName { get; set; }
- [JsonProperty]
- public Sex Sex { get; set; }
- #region 外键 => 导航属性,ManyToOne/OneToOne
- [Navigate("CountryId")]
- public virtual country country { get; set; }
- #endregion
- #region 外键 => 导航属性,ManyToMany
- #endregion
- }
- public enum Sex {
- 女,
- 男
- }
- }
复制代码
8、关键代码
- using Domain;
- using System;
- using System.Collections.Generic;
- using System.ComponentModel;
- using System.Data;
- using System.Drawing;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using System.Windows.Forms;
- namespace TileViewDemo
- {
- public partial class MainForm : DevExpress.XtraEditors.XtraForm
- {
- public MainForm()
- {
- InitializeComponent();
- }
- private void MainForm_Load(object sender, EventArgs e)
- {
- Global.Instance.ConnnectionServer(out string exMsg);
- if (!string.IsNullOrEmpty(exMsg))
- {
- MessageBox.Show("数据库连接失败:" + exMsg);
- return;
- }
- List<hero> heroes = Global.Instance.freeSql.Select<hero>().Include(a => a.country).ToList();
- List<herodDto> heroDtos = new List<herodDto>();
- foreach (var item in heroes)
- {
- herodDto herodDto = new herodDto()
- {
- Id = item.N_Id,
- Photo = Image.FromFile(item.ImgSrc),
- Name = item.Name,
- NickName = item.NickName,
- Sex = item.Sex,
- CountryName = item.country.CountryName
- };
- heroDtos.Add(herodDto);
- }
- gc_DataList.DataSource = heroDtos;
- }
- /// <summary>
- /// 定制每个卡片
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void tv_DataList_ItemCustomize(object sender, DevExpress.XtraGrid.Views.Tile.TileViewItemCustomizeEventArgs e)
- {
- if (e.Item == null || e.Item.Elements.Count == 0)
- return;
- int sex = (int)tv_DataList.GetRowCellValue(e.RowHandle, tv_DataList.Columns["Sex"]);
- Color female = Color.LightBlue;
- Color male = Color.DarkRed;
- e.Item.Elements[5].Text = String.Empty;
- if (sex == 1)
- e.Item.Elements[5].Appearance.Normal.BackColor = female;
- else
- e.Item.Elements[5].Appearance.Normal.BackColor = male;
- }
- /// <summary>
- /// 每个卡片的点击事件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void tv_DataList_ItemClick(object sender, DevExpress.XtraGrid.Views.Tile.TileViewItemClickEventArgs e)
- {
- herodDto herodDto = tv_DataList.GetRow(e.Item.RowHandle) as herodDto;
- herodDto.IsSelect = !herodDto.IsSelect;
- tv_DataList.RefreshRow(e.Item.RowHandle);
- }
- }
- public class herodDto
- {
- public int Id { get; set; }
- public Image Photo { get; set; }
- public string Name { get; set; }
- public string NickName { get; set; }
- public Sex Sex { get; set; }
- public string CountryName { get; set; }
- public bool IsSelect { get; set; } = true;
- }
- }
复制代码
9、实际显示
data:image/s3,"s3://crabby-images/fb68a/fb68af5c380ada85cca91588246bf53bc8a24a64" alt=""
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |