//
// (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;
}
}
}
}