Ejemplo n.º 1
0
        public static Dictionary <string, object> NodeCoordinates(object GsaFile, string sList)
        {
            ComAuto GsaObj = GsaFile as ComAuto;

            int[] NodeRefs = null;

            short s = GsaObj.EntitiesInList(sList, GsaEntity.NODE, out NodeRefs);

            Array.Sort(NodeRefs);

            List <Point> PtList = new List <Point>();


            GsaNode[] Nodes;


            //Get node coordinates
            short t = GsaObj.Nodes(NodeRefs, out Nodes);

            foreach (GsaNode item in Nodes)
            {
                PtList.Add(Point.ByCoordinates(item.Coor[0], item.Coor[1], item.Coor[2]));
            }

            return(new Dictionary <string, object>
            {
//
                { "Nodes.Coordinates", PtList as List <Point> },
                { "Node.Refs", NodeRefs as int[] }
            });
        }
Ejemplo n.º 2
0
        public static Dictionary <string, double> CreateGSANodes(object GsaFile, Point StartPts, Point EndPts, double tolerance)
        {
            double StXcoord = StartPts.X;
            double StYcoord = StartPts.Y;
            double StZcoord = StartPts.Z;

            double EndXcoord = EndPts.X;
            double EndYcoord = EndPts.Y;
            double EndZcoord = EndPts.Z;

            double tol = (double)tolerance;

            ComAuto GsaObj = GsaFile as ComAuto;

            int StartNode = GsaObj.Gen_NodeAt(StXcoord, StYcoord, StZcoord, tol);
            int EndNode   = GsaObj.Gen_NodeAt(EndXcoord, EndYcoord, EndZcoord, tol);


            SetElem1d(GsaObj, 1, 1, "1", StartNode, EndNode);

            return(new Dictionary <string, double>
            {
                { "GsaNodes", StartNode }
            });
        }
Ejemplo n.º 3
0
        public static Dictionary <string, ComAuto> OpenModel(string filePath)
        {
            ComAuto GsaObj = new ComAuto();

            GsaObj.SetLocale(Locale.LOC_EN_GB);
            GsaObj.Open(filePath);

            return(new Dictionary <string, ComAuto>
            {
                { "GSA File", GsaObj as ComAuto }
            });
        }
Ejemplo n.º 4
0
        public static Dictionary <string, ComAutoClass> OpenGsaModel(string filePath)
        {
            ComAuto GsaObj = new ComAuto();

            GsaObj.SetLocale(Locale.LOC_EN_GB);
            GsaObj.Open(filePath);
//            ComAutoClass gsaFile = GsaObj as ComAutoClass;

            return(new Dictionary <string, ComAutoClass>
            {
//                    {"GSA File", gsaFile},
                { "GSA Object", GsaObj as ComAutoClass }
            });
        }
Ejemplo n.º 5
0
        public static Dictionary <string, object> GetGsaNodeNumbers(ComAutoClass GsaObj, string List)
        {
            ComAuto GsaFile = GsaObj as ComAuto;

            int[] NodeRefs = null;

            short s = GsaFile.EntitiesInList(List, GsaEntity.NODE, out NodeRefs);

            //short s = GsaObj.EntitiesInList(List, GsaEntity.NODE, out NodeRefs);

            Array.Sort(NodeRefs);

            return(new Dictionary <string, object>
            {
                { "Node Refs", NodeRefs }
            });
        }
Ejemplo n.º 6
0
        public static int SetElem1d(object GsaFile, int iElem, int iProp, string sID, int StartNode, int EndNode)
        {
            ComAuto GsaObj = GsaFile as ComAuto;

            string sGwaCommand = "";

            //write beam element
            //EL_BEAM | num | prop | group | topo(2) | node | angle | dummy
            sGwaCommand  = "EL_BEAM:";
            sGwaCommand += "{RVT:" + sID + "}";
            sGwaCommand += "," + iElem.ToString();        //'number
            sGwaCommand += "," + iProp.ToString();        //'property
            sGwaCommand += ",1";                          //'group
            sGwaCommand += "," + StartNode.ToString();    //'topo 0
            sGwaCommand += "," + EndNode.ToString();      //'topo 1

            GsaObj.GwaCommand("EL_BEAM");

            return(iElem);
        }
Ejemplo n.º 7
0
        public static Dictionary <string, object> Elements(object GsaFile, string sList)
        {
            ComAuto GsaObj = GsaFile as ComAuto;

            int[] EleRefs = null;

            short s = GsaObj.EntitiesInList(sList, GsaEntity.ELEMENT, out EleRefs);

            Array.Sort(EleRefs);
            List <int[]> Pts        = new List <int[]>();
            List <int>   Properties = new List <int>();
            List <int>   Names      = new List <int>();

            //       List<Point> StPoint = new List<Point>();
            //       List<Point> EndPoint = new List<Point>();



            GsaElement[] GsaElements;

            //Get node coordinates
            short t = GsaObj.Elements(EleRefs, out GsaElements);

            foreach (GsaElement item in GsaElements)
            {
                Pts.Add(item.Topo);
                Properties.Add(item.Property);
                Names.Add(item.eType);
            }



            return(new Dictionary <string, object>
            {
                { "Elements.Refs", EleRefs as int[] },
                { "Elements.EndPoints", Pts as List <int[]> },
                { "Elements.Properties", Properties as List <int> },
                { "Elements.Names", Names as List <int> }
            });
        }
Ejemplo n.º 8
0
        public static Dictionary <string, object> NodesFromRefs(object GsaFile, int[] NodeRefs)
        {
            ComAuto GsaObj = GsaFile as ComAuto;

            List <Point> PtList = new List <Point>();


            GsaNode[] Nodes;


            //Get node coordinates
            short t = GsaObj.Nodes(NodeRefs, out Nodes);

            foreach (GsaNode item in Nodes)
            {
                PtList.Add(Point.ByCoordinates(item.Coor[0], item.Coor[1], item.Coor[2]));
            }

            return(new Dictionary <string, object>
            {
                { "Node.Refs", NodeRefs as int[] },
                { "Nodes.Coordinates", PtList as List <Point> }
            });
        }
Ejemplo n.º 9
0
        /***************************************************/
        /**** Constructors                              ****/
        /***************************************************/

        public GSALink()
        {
            m_Gsa    = new ComAuto();
            ErrorLog = new List <string>();
        }
Ejemplo n.º 10
0
 public static short Method1(this ComAuto com, object param)
 {
     return(com.GetShortValue(param));
 }