// // (C) Copyright 2003-2014 by Autodesk, Inc. // // Permission to use, copy, modify, and distribute this software in // object code form for any purpose and without fee is hereby granted, // provided that the above copyright notice appears in all copies and // that both that copyright notice and the limited warranty and // restricted rights notice below appear in all supporting // documentation. // // AUTODESK PROVIDES THIS PROGRAM "AS IS" AND WITH ALL FAULTS. // AUTODESK SPECIFICALLY DISCLAIMS ANY IMPLIED WARRANTY OF // MERCHANTABILITY OR FITNESS FOR A PARTICULAR USE. AUTODESK, INC. // DOES NOT WARRANT THAT THE OPERATION OF THE PROGRAM WILL BE // UNINTERRUPTED OR ERROR FREE. // // Use, duplication, or disclosure by the U.S. Government is subject to // restrictions set forth in FAR 52.227-19 (Commercial Computer // Software - Restricted Rights) and DFAR 252.227-7013(c)(1)(ii) // (Rights in Technical Data and Computer Software), as applicable. // using System; using System.Collections.Generic; using System.Linq; using System.Text; using Autodesk.Revit; using Autodesk.Revit.DB; using System.Diagnostics; using System.IO; using System.Collections; using Autodesk.Revit.UI; using Autodesk.Revit.UI.Selection; using System.Windows.Forms; using Revit.SDK.Samples.ScheduleCreation.CS; using KMBIM.Revit.Tools; namespace KMBIM { [Autodesk.Revit.Attributes.Transaction(Autodesk.Revit.Attributes.TransactionMode.Manual)] [Autodesk.Revit.Attributes.Regeneration(Autodesk.Revit.Attributes.RegenerationOption.Manual)] [Autodesk.Revit.Attributes.Journaling(Autodesk.Revit.Attributes.JournalingMode.NoCommandData)] public class SleeveTableCommand : IExternalCommand { /// /// Implement this method as an external command for Revit. /// /// An object that is passed to the external application /// which contains data related to the command, /// such as the application object and active view. /// A message that can be set by the external application /// which will be displayed if a failure or cancellation is returned by /// the external command. /// A set of elements to which the external application /// can add elements that are to be highlighted in case of failure or cancellation. /// Return the status of the external command. /// A result of Succeeded means that the API external method functioned as expected. /// Cancelled can be used to signify that the user cancelled the external operation /// at some point. Failure should be returned if the application is unable to proceed with /// the operation. public Autodesk.Revit.UI.Result Execute(Autodesk.Revit.UI.ExternalCommandData commandData, ref string message, ElementSet elements) { try { if (!WorkMain.GetInstance().IsValid) return Autodesk.Revit.UI.Result.Succeeded; //Transaction documentTransaction = new Transaction(commandData.Application.ActiveUIDocument.Document, "Document"); //documentTransaction.Start(); // Get the application of revit //Autodesk.Revit.UI.UIApplication revit = commandData.Application; UIApplication uiapp = commandData.Application; UIDocument uidoc = uiapp.ActiveUIDocument; Document m_doc = uidoc.Document; // New a real operation class. //ExcelExport dlg = new ExcelExport(commandData.Application.ActiveUIDocument.Document); //dlg.revit = commandData; //dlg.ShowDialog(); //if (dlg.DialogResult == DialogResult.Cancel) return Result.Succeeded; /* try { UIDocument uiDocument = commandData.Application.ActiveUIDocument; ScheduleCreationUtility utility = new ScheduleCreationUtility(); utility.CreateAndAddSchedules(uiDocument); return Result.Succeeded; } catch (Exception ex) { message = ex.Message; return Result.Failed; }*/ //ÆÐ¹Ð¸® Àüü °Ë»ö //¼Ó¼º ¼±Åà //À϶÷Ç¥ ÀÛ¼º // ¼±Åà //List lstSelType = new List(); //lstSelType.Add(typeof(FamilyInstance)); //string msg = "½½¸®ºê ¼±ÅÃ:"; //IList ielement = uidoc.Selection.PickElementsByRectangle("½½¸®ºê ¼±ÅÃ:"); //List sleeveel = new List(); //foreach (var r in ielement) //{ // if(r.Category.Id.IntegerValue == (int)BuiltInCategory.OST_GenericModel &&( // r.Name == "ÆÄÀÌÇÁ ½½¸®ºê" || // r.Name == "Á÷»ç°¢Çü ´öÆ® ½½¸®ºê" || // r.Name == "¿øÇü ´öÆ® ½½¸®ºê" || // r.Name == "Ÿ¿øÇü ´öÆ® ½½¸®ºê" // )) // { // sleeveel.Add(r); // } // //} //MessageBox.Show("°Ë»öµÈ ½½¸®ºê ÃѰè : "+sleeveel.Count.ToString()); // IList lstRef = uidoc.Selection.PickObjects(ObjectType.LinkedElement, new FamilyInstanceSelectionFilter(lstSelType), msg); //if (lstRef == null) return Result.Succeeded; //foreach (var r in lstRef.ToList()) //{ // Element e1 = m_doc.GetElement(r.ElementId); // RevitLinkInstance rli = e1 as RevitLinkInstance; // if (rli != null) // { // var link_doc = rli.GetLinkDocument(); // e1 = link_doc.GetElement(r.LinkedElementId); // FamilyInstance familyInstance = e1 as FamilyInstance; // } //} SleeveScheduleCreationUtility df = new SleeveScheduleCreationUtility(); df.CreateAndAddSchedules(uidoc); // if everything goes well, return succeeded. return Autodesk.Revit.UI.Result.Succeeded; } catch (Exception ex) { // If any error, give error information and return failed message = ex.Message; return Autodesk.Revit.UI.Result.Failed; } } } }