Последние сообщения

Последние сообщения

Страницы: [1] 2 3 ... 10
1
AutoCAD .NET API / Re: Оффтопик. Изучаем C#
« Последний ответ от Алексей Кулик 03-02-2026, 15:13:37 »
Может, проще NuGet-пакет поставить?
2
AutoCAD .NET API / Re: Оффтопик. Изучаем C#
« Последний ответ от Electric 03-02-2026, 14:57:53 »
У вас забыт using System; Поэтому недоступен Environment.
Попробуйте полностью написать Autodesk.AutoCAD.ApplicationServices.Application и Autodesk.AutoCAD.Runtime.CommandMethod

Да, и похоже я забыл добавить accoremgd.dll в ссылки. После этого проблема исчезла.
3
AutoCAD .NET API / Re: Оффтопик. Изучаем C#
« Последний ответ от avc 03-02-2026, 13:28:51 »
У вас забыт using System; Поэтому недоступен Environment.
Попробуйте полностью написать Autodesk.AutoCAD.ApplicationServices.Application и Autodesk.AutoCAD.Runtime.CommandMethod
4
AutoCAD .NET API / Re: Оффтопик. Изучаем C#
« Последний ответ от Electric 03-02-2026, 12:17:21 »
У меня тупой вопрос. Я попробовал скомпилировать простейший код из примера для начинающих. Но выдает ошибки.

В AutoCAD 2022 создал библиотеку классов .NetFramework
В проект - свойства - целевая рабочая среда поставил .NETFramework 4.8
В раздел ссылки в свойствах Решения добавил  acmgd.dll и acdbmgd.dll из папки автокада, в свойствах у них "Копировать локально" в False.

Код:

Код - C# [Выбрать]
  1. using Autodesk.AutoCAD.Runtime;
  2. using Autodesk.AutoCAD.ApplicationServices;
  3.  
  4. namespace AutocadPlugin
  5. {
  6.         public class test : IExtensionApplication
  7.         {
  8.                 [CommandMethod("hello")]
  9.                 public void Helloworld()
  10.                 {
  11.                         var editor = Application.DocumentManager.MdiActiveDocument.Editor;
  12.                         editor.WriteMessage("Привет из Autocad плагина");
  13.                 }
  14.  
  15.                 public void Initialize()
  16.                 {
  17.                         var editor = Application.DocumentManager.MdiActiveDocument.Editor;
  18.                         editor.WriteMessage("Инициализация плагина.." + Environment.NewLine);
  19.                 }
  20.  
  21.                 public void Terminate()
  22.                 {
  23.  
  24.                 }
  25.  
  26.         }
  27. }
  28.  

Подсвечиваются красным:
 CommandMethod   - CS0246 не удалось найти тип или имя пространства имен
DocumentManager -   CS0012 Тип Application  определен в сборке, на которую нет ссылки.  И CS0117  Application  не содержит определения DocumentManager
 Environment - CS0103   имя  Environment не существует в текущем контексте.

Что я делаю не так? Нужно добавить какие-то библиотеки в using ? Или  ошибка  в чем-то ином
5
AutoCAD .NET API / ToneOperatorParameters у вьюпорта
« Последний ответ от avc 01-02-2026, 00:15:39 »
Есть у вьюпортов настройки цвета и яркости для рендеринга текстур. Пользователь их настраивает в палитре _RenderExposure. Я нашел в API , что у вьюпорта есть свойство ToneOperatorParameters. Это объект у которого уже есть нужные мне свойства, включая Exposure. Но вот беда, AutoCAD игнорирует изменение этих свойств. Хотя есть все сеттеры, можно присвоить свойства объекта ToneOperatorParameters, можно поменять сам ToneOperatorParameters у вьюпорта. Ошибок не происходит. Но и новые значения не сохраняются! Если кто-то работал с этими настройками - пожалуйста отзовитесь. У меня ощущение, что это баг в API. Тестирую на AutoCAD 2025 и 2026.
6
AutoCAD .NET API / Re: Атрибут блока, входящего в мультивыноску
« Последний ответ от nolte 27-01-2026, 13:04:55 »
Спасибо. GetBlockAttribute - это то что искалось но не находилось в автокаде 2026 буду попробывать сообщу.
7
AutoCAD .NET API / Re: Атрибут блока, входящего в мультивыноску
« Последний ответ от avc 27-01-2026, 12:37:22 »
Для изменяемых атрибутов у выноски есть метод GetBlockAttribute. Для константных - просто редактируем btr блока.

Код - C# [Выбрать]
  1.     /// <summary>
  2.     /// Записать в выноску с блоком заданное значение заданного атрибута.
  3.     /// если имя атрибута пустое - атрибут должен быть единственный в блоке
  4.     /// </summary>
  5.     public static bool
  6.     SetBlockAttribute(this MLeader ml, string attTag, string value, Transaction tr, bool add = false, string separator = "")
  7.     {
  8.       if (ml is null || ml.IsErased || ml.ContentType != ContentType.BlockContent || ml.BlockContentId.IsNull)
  9.         return false;
  10.       BlockTableRecord btr = tr.GetObject(ml.BlockContentId, OpenMode.ForRead) as BlockTableRecord;
  11.       if (btr is null) return false;
  12.       ObjectId singleAtt = ObjectId.Null;
  13.       foreach (ObjectId attDefId in btr)
  14.       {
  15.         if (attDefId.IsNull || attDefId.IsErased || attDefId.ObjectClass != dbAttDef) continue;
  16.  
  17.         if (IsNullOrEmpty(attTag)) // должен быть единственный атрибут
  18.           if (singleAtt.IsNull) { singleAtt = attDefId; continue; } // запомним первый и продолжим поиски
  19.           else { singleAtt = ObjectId.Null; break; } // нашелся второй атрибут
  20.  
  21.         using AttributeReference attRef = ml.GetBlockAttribute(attDefId);
  22.         if (attRef is null) continue;
  23.         if (attTag == attRef.Tag)
  24.         {
  25.           SetText(attRef, value, add, separator);
  26.           ml.SetBlockAttribute(attDefId, attRef);
  27.           return true;
  28.         }
  29.       } // foreach
  30.  
  31.       if (IsNullOrEmpty(attTag))
  32.         if (singleAtt.IsNull) return false;
  33.         else
  34.         {
  35.           using AttributeReference attRef = ml.GetBlockAttribute(singleAtt);
  36.           SetText(attRef, value, add, separator);
  37.           ml.SetBlockAttribute(singleAtt, attRef);
  38.           return true;
  39.         }
  40.       return false;
  41.     }
  42.  
  43.  
  44.     public static void
  45.     SetText(this AttributeReference attr, string contents, bool add = false, string separator = "")
  46.     {
  47.       if (attr is null || attr.IsErased) return;
  48.       contents = Concat(add, attr.GetTextWithFieldCodes(), separator, contents);
  49.       if (contents.Contains("%<\\")) // это поле
  50.       {
  51.         Field f = new(contents, true);
  52.         f.Evaluate();
  53.         attr.SetField(f);
  54.       }
  55.       else
  56.         attr.TextString = contents;
  57.     }
  58.  
  59.  
8
AutoCAD .NET API / Атрибут блока, входящего в мультивыноску
« Последний ответ от nolte 27-01-2026, 09:52:52 »
День добрый всем. Автокад 2026 кто знает как добраться до атрибута блока.
9
В этом видео показал каким можно еще путем пойти для чтения основной таблицы и многое другое:
10
Работа для программистов / Ищем разработчика C# .Net
« Последний ответ от Павел55 16-01-2026, 12:56:04 »
Вакансия - C#/.NET-разработчик

Ищем специалиста на позицию - C#/.NET-разработчик в нашу команду.

Направления:
• Разработка плагинов для платформы nanoCAD и вертикальных решений Нанософт
• Разработка плагинов для Model Studio CS
• Разработка программ для внутренних нужд компании (чат боты, парсеры и т.д)

О компании:
Компания «Центр Программных Решений» - российская аккредитованная IT-компания, занимающаяся внедрением и сервисным обслуживанием систем автоматизации предприятий (CRM, телекоммуникации, САПР).

Мы рады пригласить в команду профессионалов, готовых развиваться вместе с нами.

Что мы ждем от кандидата:
•  Опыт работы с API nanoCAD/AutoCAD.
•  Опыт разработки прикладных программ под САПР.
•  Опыт разработки приложений на C#/C++
•  Опыт работы с WPF
•  Понимание простых геометрических функций и алгоритмов, системное мышление.

Будет плюсом:
•  Опыт работы с САПР nanoCAD, AutoCAD на уровне квалифицированного пользователя.
•  Опыт работы с другими САПР.
•  Опыт работы в команде.
•  Опыт разработки ТЗ.

Основные задачи:

✔️Разработка ТЗ и уточнение требований клиента.
✔️ Разработка интерфейсов на WPF.
✔️ Создание логики с использованием алгоритмов различной степени сложности.
✔️ Изучение API САПР.
✔️ Разработка собственных решений, упрощающих написание кода.

Мы предлагаем:

•  Работа в аккредитованной ИТ-компании.

•  Трудоустройство по ТК РФ с первого рабочего дня, белая зарплата + 4 дополнительные дня к отпуску ежегодно.

•  Компенсация: уровень заработной платы обсуждается с каждым кандидатом на собеседовании. В компании есть премии, повышения и профессиональный рост.

•  График работы: 5/2, гибкое начало дня (можно распределять время в течение дня на своё усмотрение, если это не мешает работе команды).
Формат работы: офис/гибрид

•  Офис: Омск, БЦ "На Гагарина" (ул. Гагарина, 14)

•  Заботимся о сотрудниках: проводим выездные корпоративы и вечеринки в офисе, дарим подарки на праздники, запускаем спортивные программы, отмечаем дни рождения, дарим мерч и многое другое.

•  Возможность принимать решения, настраивать процессы и предлагать идеи, которые будут услышаны и реализованы.

Ссылка на вакансию:https://omsk.hh.ru/vacancy/129414429?query=%D0%A1%23+%D1%80%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D1%87%D0%B8%D0%BA&hhtmFrom=vacancy_search_list
Страницы: [1] 2 3 ... 10