当前位置: 首页>>代码示例>>C++>>正文


C++ ModelObject::name方法代码示例

本文整理汇总了C++中ModelObject::name方法的典型用法代码示例。如果您正苦于以下问题:C++ ModelObject::name方法的具体用法?C++ ModelObject::name怎么用?C++ ModelObject::name使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在ModelObject的用法示例。


在下文中一共展示了ModelObject::name方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: defaultSurfaceConstructions

TEST_F(ModelFixture, DefaultConstructionSet_CloneBadName)
{
  Model model;

  DefaultSurfaceConstructions defaultSurfaceConstructions(model);
  defaultSurfaceConstructions.setName("Easy name");
  ModelObject clone = defaultSurfaceConstructions.clone(model);
  EXPECT_EQ("Easy name 1", clone.name().get());
  clone = defaultSurfaceConstructions.clone(model);
  EXPECT_EQ("Easy name 2", clone.name().get());

  defaultSurfaceConstructions = DefaultSurfaceConstructions(model);
  defaultSurfaceConstructions.setName("Harder 1-8_(name)");
  clone = defaultSurfaceConstructions.clone(model);
  EXPECT_EQ("Harder 1-8_(name) 1", clone.name().get());
  clone = defaultSurfaceConstructions.clone(model);
  EXPECT_EQ("Harder 1-8_(name) 2", clone.name().get());

  defaultSurfaceConstructions = DefaultSurfaceConstructions(model);
  defaultSurfaceConstructions.setName("*H.a.r.d.e.s.t*^\\1|-|8/_#($name$)?#");
  clone = defaultSurfaceConstructions.clone(model);
  EXPECT_EQ("*H.a.r.d.e.s.t*^\\1|-|8/_#($name$)?# 1", clone.name().get());
  clone = defaultSurfaceConstructions.clone(model);
  EXPECT_EQ("*H.a.r.d.e.s.t*^\\1|-|8/_#($name$)?# 2", clone.name().get());
}
开发者ID:ChengXinDL,项目名称:OpenStudio,代码行数:25,代码来源:DefaultConstructionSet_GTest.cpp

示例2: idfObject

boost::optional<IdfObject> ForwardTranslator::translateLifeCycleCost( LifeCycleCost& modelObject )
{
  boost::optional<LifeCycleCostParameters> lifeCycleCostParameters = modelObject.model().lifeCycleCostParameters();
  if (!lifeCycleCostParameters){
    lifeCycleCostParameters = modelObject.model().getUniqueModelObject<LifeCycleCostParameters>();
  }

  int lengthOfStudyPeriodInMonths = 12*lifeCycleCostParameters->lengthOfStudyPeriodInYears();

  boost::optional<IdfObject> result;

  ModelObject item = modelObject.item();
  std::string comment = item.iddObject().name() + ", " + item.name().get();

  std::string name = modelObject.name().get();
  std::string category = modelObject.category();
  double totalCost = modelObject.totalCost();
  int yearsFromStart = modelObject.yearsFromStart();
  int monthsFromStart = modelObject.monthsFromStart();
  int repeatPeriodYears = modelObject.repeatPeriodYears();
  int repeatPeriodMonths = modelObject.repeatPeriodMonths();

  if (totalCost == 0){
    return boost::none;
  }

  bool hasRepeatingCosts = (repeatPeriodYears > 0 || repeatPeriodMonths > 0);

  // check for field types of LifeCycleCost:NonrecurringCost {Construction, Salvage, OtherCapital}
  if (istringEqual("Construction", category) ||
      istringEqual("Salvage", category) || 
      istringEqual("OtherCapital", category)){

    if (lengthOfStudyPeriodInMonths >= 12*yearsFromStart + monthsFromStart){

      // convert to LifeCycleCost::NonrecurringCosts
      IdfObject idfObject(openstudio::IddObjectType::LifeCycleCost_NonrecurringCost);
      idfObject.setComment(comment);
      m_idfObjects.push_back(idfObject);

      idfObject.setString(LifeCycleCost_NonrecurringCostFields::Name, name);
      idfObject.setString(LifeCycleCost_NonrecurringCostFields::Category, category);
      idfObject.setDouble(LifeCycleCost_NonrecurringCostFields::Cost, totalCost);
      idfObject.setString(LifeCycleCost_NonrecurringCostFields::StartofCosts, "ServicePeriod");

      if (yearsFromStart > 0){
        idfObject.setInt(LifeCycleCost_NonrecurringCostFields::YearsfromStart, yearsFromStart);
      }

      if (monthsFromStart > 0){
        idfObject.setInt(LifeCycleCost_NonrecurringCostFields::MonthsfromStart, monthsFromStart);
      }

      result = idfObject;

      // may create a recurring cost object to handle replacement costs, shift first replacement costs back one period
      if (istringEqual("Construction", category)){
        name += " Replacement";
      }else {
        name += " Recurring";
      }
      category = "Replacement";
      yearsFromStart += repeatPeriodYears;
      monthsFromStart += repeatPeriodMonths;
    
    }else{
      //LOG(Warn, "LifeCycleCost '" << name << "' occurs outside the study period, will not be translated");
    }
  }

  if (hasRepeatingCosts) {

    if (lengthOfStudyPeriodInMonths >= 12*yearsFromStart + monthsFromStart){

      // also create a LifeCycleCost::RecurringCosts to capture replacement costs
      IdfObject idfObject(openstudio::IddObjectType::LifeCycleCost_RecurringCosts);
      idfObject.setComment(comment);
      m_idfObjects.push_back(idfObject);

      idfObject.setString(LifeCycleCost_RecurringCostsFields::Name, name);
      idfObject.setString(LifeCycleCost_RecurringCostsFields::Category, category);
      idfObject.setDouble(LifeCycleCost_RecurringCostsFields::Cost, totalCost);
      idfObject.setString(LifeCycleCost_RecurringCostsFields::StartofCosts, "ServicePeriod");

      if (yearsFromStart > 0){
        idfObject.setInt(LifeCycleCost_RecurringCostsFields::YearsfromStart, yearsFromStart);
      }

      if (monthsFromStart > 0){
        idfObject.setInt(LifeCycleCost_RecurringCostsFields::MonthsfromStart, monthsFromStart);
      }

      if (repeatPeriodYears > 0){
        idfObject.setInt(LifeCycleCost_RecurringCostsFields::RepeatPeriodYears, repeatPeriodYears);
      }

      if (repeatPeriodMonths > 0){
        idfObject.setInt(LifeCycleCost_RecurringCostsFields::RepeatPeriodMonths, repeatPeriodMonths);
      }

//.........这里部分代码省略.........
开发者ID:ORNL-BTRIC,项目名称:OpenStudio,代码行数:101,代码来源:ForwardTranslateLifeCycleCost.cpp


注:本文中的ModelObject::name方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。