Exemplo n.º 1
0
        public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)
        {
            var uiapp = commandData.Application;
            var uidoc = uiapp.ActiveUIDocument;
            var doc   = uidoc.Document;
            var sel   = uidoc.Selection;

            AboutForm form = new AboutForm();

            form.Show(RevitWindowHelper.GetRevitWindow());

            return(Result.Succeeded);
        }
Exemplo n.º 2
0
        public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)
        {
            var uiapp = commandData.Application;
            var uidoc = uiapp.ActiveUIDocument;
            var doc   = uidoc.Document;

            DragForm toolform = DragForm.Instance;

            toolform.Show(RevitWindowHelper.GetRevitWindow());


            return(Result.Succeeded);
        }
Exemplo n.º 3
0
        public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)
        {
            var uiapp  = commandData.Application;
            var uidoc  = uiapp.ActiveUIDocument;
            var doc    = uidoc.Document;
            var acview = doc.ActiveView;

            var sel = uidoc.Selection;

            _doc = doc;

            doc.Application.DocumentChanged += OnDocumentChanged;

            ResultShow resultshowwin = ResultShow.Instance;

            resultshowwin.helper().Owner = RevitWindowHelper.GetRevitHandle();
            ResultShow.Instance.Show();

            uiapp.PostCommand(RevitCommandId.LookupPostableCommandId(PostableCommand.ModelLine));


            return(Result.Succeeded);
        }
Exemplo n.º 4
0
        public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)
        {
            var uiapp  = commandData.Application;
            var uidoc  = uiapp.ActiveUIDocument;
            var doc    = uidoc.Document;
            var sel    = uidoc.Selection;
            var acview = doc.ActiveView;

            //filter target columntypes
            ElementFilter architectureColumnFilter = new ElementCategoryFilter(BuiltInCategory.OST_Columns);
            ElementFilter structuralColumnFilter   = new ElementCategoryFilter(BuiltInCategory.OST_StructuralColumns);
            ElementFilter orfilter     = new LogicalOrFilter(architectureColumnFilter, structuralColumnFilter);
            var           collector    = new FilteredElementCollector(doc);
            var           columnstypes = collector.WhereElementIsElementType().WherePasses(orfilter).ToElements();

            ColumnTypesForm typesform = ColumnTypesForm.Getinstance(columnstypes.ToList());//new ColumnTypesForm(columnstypes.ToList());

            typesform.ShowDialog(RevitWindowHelper.GetRevitWindow());

            //get selected familysymbol of combobox in columntypesForm
            var familysymbol = typesform.symbolCombo.SelectedItem as FamilySymbol;

            //varient for setting bottom and top /*for learners self modifing*/
            var bottomlevel  = default(Level);
            var bottomoffset = default(double);

            var toplevel  = default(Level);
            var topoffset = default(double);

            var grids  = doc.TCollector <Grid>();
            var points = new List <XYZ>();

            foreach (var grid in grids)
            {
                foreach (var grid1 in grids)
                {
                    if (grid.Id == grid1.Id)
                    {
                        continue;
                    }
                    var curve1      = grid.Curve;
                    var curve2      = grid1.Curve;
                    var res         = new IntersectionResultArray();
                    var intersecRes = curve1.Intersect(curve2, out res);
                    if (intersecRes != SetComparisonResult.Disjoint)
                    {
                        if (res != null)
                        {
                            points.Add(res.get_Item(0).XYZPoint);
                        }
                    }
                }
            }
            //distinct points on same location
            points = points.Where((m, i) => points.FindIndex(n => n.IsAlmostEqualTo(m)) == i).ToList();

            //MessageBox.Show(points.Count.ToString());
            //CreateColumns as intersection point

            TransactionGroup tsg = new TransactionGroup(doc);

            tsg.Start("统一创建柱子");
            foreach (var point in points)
            {
                doc.Invoke(m =>
                {
                    if (!familysymbol.IsActive)
                    {
                        familysymbol.Activate();
                    }
                    var instance = doc.Create.NewFamilyInstance(point, familysymbol, acview.GenLevel,
                                                                StructuralType.NonStructural);
                }, "创建柱子");
            }
            tsg.Assimilate();
            return(Result.Succeeded);
        }
Exemplo n.º 5
0
        public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)
        {
            UIApplication uiapp  = commandData.Application;
            UIDocument    uidoc  = commandData.Application.ActiveUIDocument;
            Document      doc    = uidoc.Document;
            Selection     sel    = uidoc.Selection;
            View          acview = uidoc.ActiveView;

            var toolwin = MepcurveRank.Instance;

            toolwin.helper().Owner = RevitWindowHelper.GetRevitHandle();
            toolwin.Show(); //显示窗体 当点击窗体的 一键分布的时候 向revit窗体发送esc按键 结束 while循环
            var elelist = new List <ElementId>();

            while (true)
            {
                try
                {
                    var eleref = sel.PickObject(ObjectType.Element, doc.GetSelectionFilter(m => m is MEPCurve));
                    elelist.Add(eleref.ElementId);
                }
                catch (Exception e)
                {
                    break;
                }
            }
            var dis         = default(double);
            var parseresult = double.TryParse(toolwin.horizontalDis.Text, out dis);

            if (!parseresult)
            {
                MessageBox.Show("间距设置错误");
                return(Result.Cancelled);
            }
            //以第一根管不动 其他管 紧跟第一根管排列
            var         meplist   = elelist.Select(m => m.GetElement(doc) as MEPCurve).ToList();
            var         stablemep = meplist.First();
            Transaction ts        = new Transaction(doc, "***********");

            try
            {
                ts.Start();
                for (int i = 0; i < meplist.Count; i++)
                {
                    if (i == 0)
                    {
                        continue;
                    }
                    var temdis      = dis.MetricToFeet() * i;
                    var originaldir = -getprojectdir(meplist[i], stablemep);
                    var originaldis = getHorizontalDis(meplist[i], stablemep);
                    var moveVec     = (temdis - originaldis) * originaldir;
                    ElementTransformUtils.MoveElement(doc, meplist[i].Id, moveVec);
                }
                ts.Commit();
            }
            catch (Exception e)
            {
                MessageBox.Show(e.ToString());
                if (ts.GetStatus() == TransactionStatus.Started)
                {
                    ts.RollBack();
                }
                //throw;
            }
            return(Result.Succeeded);
        }