如何准确判断单元格是否处于锁定状态Locked

发布时间:2012/11/13 00:11 发布者:葡萄城产品团队

返回博客中心

Spread中的属性设置存在继承关系,单元格的Locked属性值也可以从是在的行、列进行继承。

因为Cell、Row和Column的Locked属性值默认是false,如果我们直接取Cells[r,c].Locked就无法判断该单元格是否处于锁定状态。

不过,Spread给我们提供了GetCompositeInfo和GetDirectInfo方法来判断单元格属性的详细设置情况,比如通过下面代码我们可以准确的判断单元格是否处于锁定状态:
  1.   
    StyleInfo csi = new StyleInfo();
    
        StyleInfo dsi = new StyleInfo();
    
    
    
        fpSpread1.ActiveSheet.Models.Style.GetCompositeInfo(fpSpread1.ActiveSheet.ActiveRowIndex, fpSpread1.ActiveSheet.ActiveColumnIndex, -1, csi);
    
        fpSpread1.ActiveSheet.Models.Style.GetDirectInfo(fpSpread1.ActiveSheet.ActiveRowIndex, fpSpread1.ActiveSheet.ActiveColumnIndex, dsi);
    
    复制代码
    GetCompositeInfo方法取到的是该单元格最终的属性设置,包括从Row和Column继承的结果
    GetDirectInfo方法是用于判断是否直接设置了单元格的某个属性,而不是从Row和Column继承的结果

    源码下载:VS2010 + Spread .NET 6.0.3505
0000_Locked.zip (10.67 K, 下载次数:6)


运行截图:

最后编辑

关于葡萄城

赋能开发者!葡萄城是专业的集开发工具、商业智能解决方案、低代码开发平台于一身的软件和服务提供商,为超过 75% 的全球财富 500 强企业提供服务。葡萄城专注控件软件领域30年,希望通过模块化的开发控件、灵活的低代码应用开发平台等一系列开发工具、解决方案和服务,帮助开发者快速响应复杂多变的业务需求,最大程度地发挥开发者的才智和潜能,让开发者的 IT 人生更从容更美好。

了解详情,请访问葡萄城官网