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

本文通过代码讲述Spread提供的GetCompositeInfo和GetDirectInfo方法来判断单元格属性的详细设置情况

发布于 2012/11/13 00:00

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


运行截图:

最后编辑

关于葡萄城

葡萄城是专业的软件开发技术和低代码平台提供商,以“赋能开发者”为使命,致力于通过表格控件、低代码和BI等各类软件开发工具和服务,一站式满足开发者需求,帮助企业提升开发效率并创新开发模式。葡萄城开发技术始于1980年,40余年来始终聚焦软件开发技术,有深厚的技术积累和丰富的产品线。是业界能够同时赋能软件开发和低代码开发的企业。凭借过硬的产品能力、活跃的用户社区和丰富的伙伴生态,与超过3000家合作伙伴紧密合作,产品广泛应用于信息和软件服务、制造、交通运输、建筑、金融、能源、教育、公共管理等支柱产业。

推荐相关案例
推荐相关资源
关注微信
葡萄城社区二维码

关注“葡萄城社区”

活字格低代码二维码

关注“活字格低代码”

想了解更多信息,请联系我们, 随时掌握技术资源和产品动态