WINFORM - DevExpress -> gridcontrol 设置行和列只读

1.一列不可以编辑

 gridView1.Columns[“列名”].OptionsColumn.AllowEdit = false;//设置列不可以编辑

2.一行不可以编辑

 private void gv_ShowingEditor(object sender, CancelEventArgs e)
{
    QuDaily quDaily = gv.GetFocusedRow() as QuDaily;
    if (quDaily.StatusEnum != QuDailyStatus.提交)
    {
        e.Cancel = true;
    }
}

案例:行只读(ShowingEditor)+CellValueChanged+存储过程作为数据库 实现特定行编辑

private void bandedGridView1_ShowingEditor(object sender, CancelEventArgs e)
{
     int rowIndex = bandedGridView1.FocusedRowHandle;
     string kinddivision = bandedGridView1.GetRowCellValue(rowIndex, "kinddivision").ToString();
     if (kinddivision =="工位标准")
     {
        e.Cancel = true;
     }
     else if (kinddivision == "检验人" && rbll.Select_Ruturn1("检验人", empname).Rows[0]["returnvalue"].ToString() != "2")
     {
        e.Cancel = true;
     }
     else if (kinddivision == "IPQC确认" && rbll.Select_Ruturn1("IPQC确认", empname).Rows[0]["returnvalue"].ToString() != "3")
     {
        e.Cancel = true;
     }
     else if (kinddivision == "实测" && rbll.Select_Ruturn1("实测", empname).Rows[0]["returnvalue"].ToString() != "1")
     {
        e.Cancel = true;
     }
}
private void bandedGridView1_CellValueChanged(object sender, DevExpress.XtraGrid.Views.Base.CellValueChangedEventArgs e)
{
    GridView view = sender as GridView;
    //rowHandle的含义是获取定位编辑的单元格在第几行,可理解为Y坐标            
    int rowIndex = e.RowHandle;
    //获取被编辑的单元格在第几列,可理解为X坐标
    int columnindex = e.Column.AbsoluteIndex;
    //获取绑定到这个单元格的字段名
    string changeFiled = e.Column.FieldName;
    //获取被编辑的单元格的表头
    string caption = e.Column.Caption;
    //获取新输入的值
    string newValue = newValue = e.Value.ToString().Trim();
    string newsId = bandedGridView1.GetRowCellValue(rowIndex, "newsId").ToString();
            
    string kinddivision = bandedGridView1.GetRowCellValue(rowIndex, "kinddivision").ToString();
    string station = bandedGridView1.GetRowCellValue(rowIndex, "station").ToString();
    if (kinddivision == "实测")
    {
       try{
          if (!string.IsNullOrEmpty(newValue))
          {
             if (Convert.ToInt32(newValue) >= 360 && Convert.ToInt32(newValue) <= 400)
             {
                rbll.Update_1(changeFiled, newValue, newsId);
             }
             else
             {
                string changeFiled2 = rbll.Select_5(newsId).Rows[0][changeFiled].ToString();
                this.bandedGridView1.SetRowCellValue(rowIndex, changeFiled, changeFiled2);
             }
          }
       }catch(Exception ex){
          XtraMessageBox.Show("注:实测(360-400).");
       }
     }
   else
   {
       rbll.Update_1(changeFiled, newValue, newsId);
   }
}
create procedure [dbo].[selectdianlaoempname]
(
     @date  nvarchar(250) , --插入的日期
     @flag  nvarchar(250) --判定插入的数据
)
AS
begin
declare @SignStatus nvarchar(250) ;--状态
end
if @date='实测'
   begin
   if @flag='1' or @flag='人员'
   set @SignStatus='1'
   end
else if @date='检验人'
   begin
   if @flag='1' or @flag='人员'
   set @SignStatus='2'
   end  
else if @date='IPQC确认' 
   begin
   if @flag='1' or @flag='人员'
   set @SignStatus='3'
   end 
   select @SignStatus as returnvalue

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
WinForm中,可以通过自定义单元格样式来实现GridControl中单元格文字的不同颜色或背景色。具体步骤如下: 1. 在GridControl的Properties窗口中找到Appearance属性,将其设为DevExpress.XtraGrid.Views.Grid.DrawFocusRectStyle.None,这样可以去掉单元格的焦点框。 2. 在GridControl上双击打开GridView的Designer界面。 3. 选中要修改样式的,找到AppearanceCell属性,单击右侧的“...”按钮打开AppearanceObject对象的编辑器。 4. 在AppearanceObject编辑器中,可以设置字体、背景色、前景色等属性,还可以通过条件格式化来实现更复杂的样式。例如,可以在FormatConditions表中添加条件格式化规则,然后在Appearance属性中设置对应的样式。 5. 保存样式后,关闭Designer界面即可看到效果。 下面是一段示例代码,演示如何在GridView中实现单元格文字颜色的动态变化: ```csharp private void gridView1_CustomDrawCell(object sender, DevExpress.XtraGrid.Views.Base.RowCellCustomDrawEventArgs e) { if (e.Column.FieldName == "Status") { string status = e.CellValue.ToString(); if (status == "OK") { e.Appearance.ForeColor = Color.Green; } else if (status == "Warning") { e.Appearance.ForeColor = Color.Yellow; } else if (status == "Error") { e.Appearance.ForeColor = Color.Red; } } } ``` 这段代码在GridView的CustomDrawCell事件中,判断当前单元格的名是否为“Status”,如果是,则根据单元格的值来设置不同的字体颜色。可以根据自己的需求修改相应的代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fyhs

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值