Files
wg_cpso/CPSO/Forms/53_FieldOutput/ViewElementFieldOutput.cs

133 lines
4.9 KiB
C#
Raw Permalink Normal View History

2026-03-25 18:20:24 +08:00
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.ComponentModel;
using CaeModel;
using CaeGlobals;
using DynamicTypeDescriptor;
namespace CPSO
{
[Serializable]
[EnumResource("PrePoMax.Properties.Resources")]
[Editor(typeof(StandardValueEditor), typeof(System.Drawing.Design.UITypeEditor))]
[Flags]
public enum ViewElementFieldVariable
{
// Must start at 1 for the UI to work
[StandardValue("S", Description = "Stresses.")]
S = 1,
[StandardValue("PHS", Description = "Stresses magnitude and phase.")]
PHS = 2,
//
[StandardValue("E", Description = "Total strains.")]
E = 4,
//
[StandardValue("ME", Description = "Mechanical strains.")]
ME = 8,
//
[StandardValue("PEEQ", Description = "Equivalent plastic strain.")]
PEEQ = 16,
//
[StandardValue("ENER", Description = "Energy density.")]
ENER = 32,
// Thermal
[StandardValue("HFL", Description = "Heat flux.")]
HFL = 64,
// Error
[StandardValue("ERR", Description = "Extrapolation error estimator for stress calculations. " +
"ERR and ZZS are mutually exclusive.")]
ERR = 128,
//
[StandardValue("HER", Description = "Extrapolation error estimator for heat calculations. " +
"HER and ZZS are mutually exclusive.")]
HER = 256,
//
[StandardValue("ZZS", Description = "Zienkiewicz-Zhu improved stress. ERR and ZZS are mutually exclusive.")]
ZZS = 512,
//
[StandardValue("SDV", Description = "Internal state variables.")]
SDV = 1073741824,
}
[Serializable]
public class ViewElementFieldOutput : ViewFieldOutput
{
// Variables
private ElementFieldOutput _fieldOutput;
// Properties
public override string Name { get { return _fieldOutput.Name; } set { _fieldOutput.Name = value; } }
public override bool LastIterations
{
get { return _fieldOutput.LastIterations; }
set { _fieldOutput.LastIterations = value; }
}
public override bool ContactElements
{
get { return _fieldOutput.ContactElements; }
set { _fieldOutput.ContactElements = value; }
}
//
[OrderedDisplayName(3, 10, "Output (2D/3D)")]
[Category("Data")]
[Description("If Output=3D, the 1D and 2D elements are stored in their expanded 3D form.")]
public ElementFieldOutputOutputEnum Output
{
get { return _fieldOutput.Output; }
set { _fieldOutput.Output = value; }
}
//
[OrderedDisplayName(4, 10, "Variables to output")]
[Category("Data")]
[Description("Element field variables")]
public ViewElementFieldVariable Variables
{
get
{
return (ViewElementFieldVariable)_fieldOutput.Variables;
}
set
{
if (((value & ViewElementFieldVariable.ERR) == ViewElementFieldVariable.ERR) &&
((value & ViewElementFieldVariable.ZZS) == ViewElementFieldVariable.ZZS))
{
throw new Exception("ERR and ZZS are mutually exclusive.");
}
//
if (((value & ViewElementFieldVariable.HER) == ViewElementFieldVariable.HER) &&
((value & ViewElementFieldVariable.ZZS) == ViewElementFieldVariable.ZZS))
{
throw new Exception("HER and ZZS are mutually exclusive.");
}
//
_fieldOutput.Variables = (CaeModel.ElementFieldVariable)value;
}
}
//
public override bool Global { get { return _fieldOutput.Global; } set { _fieldOutput.Global = value; } }
//
public override FieldOutput Base { get { return _fieldOutput; } set { _fieldOutput = (ElementFieldOutput)value; } }
// Constructors
public ViewElementFieldOutput(ElementFieldOutput fieldOutput)
{
_fieldOutput = fieldOutput;
_dctd = ProviderInstaller.Install(this);
//
_dctd.RenameBooleanPropertyToYesNo(nameof(Global));
_dctd.RenameBooleanPropertyToOnOff(nameof(LastIterations));
_dctd.RenameBooleanPropertyToOnOff(nameof(ContactElements));
//
StringIntegerDefaultConverter.SetInitialValue = 1;
}
}
}