Во вкладке Database в панели области просмотра найдите кнопку Labels и откройте ее раскрывающийся список. В нем находится предварительно загруженный список автоматических меток для иерархии уровня различных уровней и полей запасов. Вы можете расширить этот список, добавив в него пользовательские метки. Примеры создания некоторых пользовательских меток приведены ниже.
Table of Contents |
---|
Добавление пользовательской метки
Нажмите значок шестеренки, находящийся справа от раскрывающегося списка Label.
Нажмите синюю кнопку со знаком плюса, чтобы добавить новую метку.
Измените имя метки на «Record» (Запись)понятное.
Вставьте фрагмент формулы в редактор кода.
Подсказки по кодам можно посмотреть дважды щелкнув по Available Formulas (Доступные формулы).
Нажмите ОК для завершения.
...
Примеры пользовательских меток
Пример 1. Создание
...
метки с пользовательским ИД
Code Block |
---|
using System;
using System.Linq;
using Alastri.Patri.V2;
using Alastri.TotalScheduler.ScriptExtensions;
using System.Collections.Generic;
using Alastri.Scripting;
using Alastri.SchedulingCore;
public class Label : ILabelTextProvider
{
public string GetLabel(RecordAndShadingContext rsc)
{
if(rsc.Record.Table.HoldsDumps)
return "";
var Name = rsc.Record.GetNames();
var pit = Name[2];
var bench = Name[4];
var blast = Name[5];
return pit + "_" + bench + "_" + blast;
}
} |
Пример 2. Идентификационная метка только для выемочного блока
...
контроля содержаний
Code Block |
---|
using System; using System.Linq; using Alastri.Patri.V2; using Alastri.TotalScheduler.ScriptExtensions; using System.Collections.Generic; using Alastri.Scripting; using Alastri.SchedulingCore; public class Label : ILabelTextProvider { public string GetLabel(RecordAndShadingContext rsc) { //If dump record or a blast solid, return nothing. if(!rsc.Record.GetNames()[0].EqEquals("Reserves") || !rsc.Record.IsDigLeaf) return ""; var agent = rsc.CurrentAgent; var database = rsc.Record.Database; var digBlock = rsc.Record.GetStringValue(database.FindField("DigSolid", "reservesDataSource"), (IParcelSubset)null); var isGradeControl = digBlock.EqEquals("BlockModel"); var blast = string.Empty; var flitch = string.Empty; var parcel = string.Empty; var block = string.Empty; if (isGradeControl) { var Name = rsc.Record.GetNames(); var pit = Name[2]; var bench = Name[4]; var shot = Name[5]; return agent + " " + flitch + "RL" + Environment.NewLine + shot ; } var names = rsc.Record.GetNames(); flitch = names[6]; blast = names[5]; return agent + " " + flitch + "RL" + Environment.NewLine + blast + "_" + parcel + "_" + block; } } |
Пример 3. Объем и тонны для блока
Code Block |
---|
using System;
using System.Linq;
using Alastri.Patri.V2;
using Alastri.TotalScheduler.ScriptExtensions;
using System.Collections.Generic;
using Alastri.Scripting;
using Alastri.SchedulingCore;
public class Label : ILabelTextProvider
{
PatriField miningVol;
PatriField miningDt;
public string GetLabel(RecordAndShadingContext rsc)
{
miningDt ??= rsc.ShadingContext.Database.FindField("mining_drytonnes");
miningVol ??= rsc.ShadingContext.Database.FindField ("mining_volume");
return "dig: " + rsc.Record.GetDoubleValue(miningVol, ParcelAll.Default).ToString("#,##0") + " bcm"
+ Environment.NewLine + rsc.Record.GetDoubleValue(miningDt, ParcelAll.Default).ToString("#,##0") + " t";
}
} |
Пример 4. Когда блок был запланирован в первый раз
Code Block |
---|
using System;
using System.Linq;
using Alastri.Patri.V2;
using Alastri.TotalScheduler.ScriptExtensions;
using System.Collections.Generic;
using Alastri.Scripting;
using Alastri.SchedulingCore;
public class Label : ILabelTextProvider
{
public string GetLabel(RecordAndShadingContext rsc)
{
var date = rsc.FirstScheduledTime.ToString();
var ignoreDate = "31/12/9999 11:59:59 PM";
//Skip Conditions
if(date == ignoreDate) return "" ;
else return date;
}
} |
...