Как можно скопировать форму в visual studio?
Мне нужно как-то скопировать форму чтоб заново не создавать. Как я могу это сделать бес конфликтов в проекте?
- Вопрос задан более трёх лет назад
- 4028 просмотров
3 комментария
Простой 3 комментария

Foggy Finder @FoggyFinder
Просто скопируйте, а затем переименуйте класс.
Sasha294 @Sasha294 Автор вопроса
Понятно. Скопировать, переименовать все что назвалось этим формой. И не копировать в студии выбивает ошибку.

Foggy Finder @FoggyFinder
И не копировать в студии выбивает ошибку.
Решения вопроса 0
Ответы на вопрос 1
Андрей Смирнов @GameDev_Easy
Сегодня я пишу на змеях.
Здравствуйте!
Зайдите в обозреватель решений, нажмите на треугольничек рядом с именем вашей формы и выберите файл: .Designer.cs , скопируйте его содержимое.
Создайте новую форму, откройте для нею этот файл и жмите Ctrl + A, Ctrl + V
Ответ написан более трёх лет назад
Комментировать
Нравится Комментировать
Ваш ответ на вопрос
Войдите, чтобы написать ответ

- C#
- +1 ещё
Как проверять столкновение префаба и UI панели в Unity?
- 1 подписчик
- 6 часов назад
- 23 просмотра
Копирование формы
Совет: Узнайте больше о Microsoft Forms или сразу приступите к работе и создайте опрос, квиз или тест. Хотите использовать более сложные элементы фирменной символики, типы вопросов и анализ данных? Попробуйте Dynamics 365 Customer Voice.
- Перейдите в Microsoft Forms и войдите с помощью Рабочей или учебной учетной записи Microsoft 365 или личной учетной записи Майкрософт (Hotmail, Live или Outlook.com).
Примечание: Вы также можете войти на сайт Office.com,найти значки Microsoft 365 слева, а затем выбрать Forms.

В форме, которые вы хотите скопировать, выберите
дополнительные параметры в правом верхнем углу плитки, а затем выберите Копировать.
Совет: Если вы не видите плитки форм, возможно, вы просматривали представление списка, а не плитки. Чтобы скопировать форму в представлении списка, наведите курсор на ее правую часть и выберите Дополнительные параметры >Копировать.
При копировании формы копируется только вопрос, формат и макет. Существующие ответы не будут перенаться в новую форму. Microsoft Forms новая форма будет иметь то же имя, что и существующая, и ее можно будет изменить на то, что вам нужно.
Нужно создать дубликат формы или теста, чтобы другие люди могли редактировать их?
Вы можете создать специальную ссылку, которая позволит другим пользователям дублировать тест или форму на Microsoft Forms портале. Узнайте, как это сделать.
Отзыв о Microsoft Forms

Мы ждем ваших отзывов! Чтобы отправить отзыв о Microsoft Forms, перейдите в правый верхний угол формы и выберите Другие параметры формы > Отзыв.
Настройка функции копирования
Область применения:
Visual Studio Visual Studio для Mac
Visual Studio Code ![]()
В определенном домене языке (DSL), созданном с помощью пакета SDK для визуализации и моделирования Visual Studio, можно изменить то, что происходит при копировании и вставке элементов пользователем.
Стандартное поведение копирования и вставки
Чтобы включить копирование, задайте свойство Enable Copy Paste узла Редактора в Обозреватель DSL.
По умолчанию, когда пользователь копирует элементы в буфер обмена, также копируются следующие элементы.

- Внедренные элементы-потомки выбранных элементов (т. е. элементы, которые являются целевыми объектами отношений внедрения для копируемых элементов).
- Связи отношений между скопированными элементами. Это правило применяется к скопированным элементам и связям рекурсивно. Скопированные элементы и связи сериализуются и сохраняются в ElementGroupPrototype (EGP), который размещается в буфере обмена. Изображение скопированных элементов также помещается в буфер обмена. Это позволяет пользователю вставлять их в другие приложения, например в Word. Пользователь может вставить скопированные элементы в целевой объект, который может принять их в соответствии с определением DSL. Например, в DSL, созданном из шаблона решения компонентов, пользователь может вставить порты в компоненты, но не в схему, а также вставить компоненты в схему, но не в другие компоненты.
Настройка поведения копирования и вставки
Дополнительные сведения о настройке модели с помощью кода программы см. в статье «Навигация и обновление модели в коде программы».
Включите или отключите копирование, вырезать и вставить. В Обозреватель DSL задайте свойство Enable Copy Paste узла Editor.
Скопируйте ссылки на тот же целевой объект. например, чтобы скопировать поле для комментариев, связанное с тем же элементом темы. Задайте свойству «Распространение копирования» роли только для распространения копирования. Дополнительные сведения см. в разделе «Настройка поведения копирования ссылок».
Скопируйте связанные элементы. Например, при копировании нового элемента также делаются копии всех связанных полей комментариев. Задайте свойству «Распространение копирования » роли для распространения копирования, чтобы связать и противоположного проигрывателя ролей. Дополнительные сведения см. в разделе «Настройка поведения копирования ссылок».
Быстрое дублирование элементов путем копирования и вставки. Обычно элемент, который только что был скопирован, остается выбран, и в него нельзя вставить такой же тип элемента. Добавьте директиву слияния элементов в класс домена и настройте его на передачу слияний в родительский класс. Это будет также влиять на операции перетаскивания. Дополнительные сведения см. в разделе «Настройка создания и перемещения элементов».
Выберите схему перед вставкой элементов, переопределив ClipboardCommandSet.ProcessOnPasteCommand() . Добавьте этот код в пользовательский файл в проекте DslPackage:
namespace Company.MyDsl < using System.Linq; using Microsoft.VisualStudio.Modeling.Diagrams; using Microsoft.VisualStudio.Modeling.Shell; partial class MyDslClipboardCommandSet < protected override void ProcessOnMenuPasteCommand() < // Deselect the current selection after copying: Diagram diagram = (this.CurrentModelingDocView as SingleDiagramDocView).Diagram; this.CurrentModelingDocView .SelectObjects(1, new object[] < diagram >, 0); > > >
Создайте дополнительные ссылки, когда пользователь вставляется в выбранный целевой объект. Например, когда поле для комментариев вставляется в элемент, между ними создается связь. Добавьте директиву слияния элементов в целевой класс домена и настройте его на обработку слияния добавлением связей. Это будет также влиять на операции перетаскивания. Дополнительные сведения см. в разделе «Настройка создания и перемещения элементов».
Переопределите ClipboardCommandSet.ProcessOnPasteCommand() для создания дополнительных связей после вызова базового метода.
Настройте форматы, в которых элементы можно копировать во внешние приложения, например, чтобы добавить границу в форму растрового изображения. Переопределите MyDsl ClipboardCommandSet.ProcessOnMenuCopyCommand() в проекте DslPackage.
Настройте способ копирования элементов в буфер обмена с помощью команды копирования, но не в операции перетаскивания. Переопределите MyDsl ClipboardCommandSet.CopyModelElementsIntoElementGroupPrototype() в проекте DslPackage.
Сохраните макет фигуры с помощью копирования и вставки. Если пользователь копирует несколько фигур, можно сделать так, чтобы при вставке их положение относительно друг друга сохранялось. Этот метод демонстрируется примером в VMSDK: пример схемы схемы.
Чтобы достигнуть такого эффекта, добавьте фигуры и соединители в скопированный ElementGroupPrototype. Самый удобный метод переопределения — это ElementOperations.CreateElementGroupPrototype(). Для этого добавьте в проект Dsl следующий код:
public class MyElementOperations : DesignSurfaceElementOperations < // Create an EGP to add to the clipboard. // Called when the elements to be copied have been // collected into an ElementGroup. protected override ElementGroupPrototype CreateElementGroupPrototype(ElementGroup elementGroup, ICollectionelements, ClosureType closureType) < // Add the shapes and connectors: // Get the elements already in the group: ModelElement[] mels = elementGroup.ModelElements .Concat(elementGroup.ElementLinks) // Omit if the paste target is not the diagram. .ToArray(); // Get their shapes: IEnumerableshapes = mels.SelectMany(mel => PresentationViewsSubject.GetPresentation(mel)); elementGroup.AddRange(shapes); return base.CreateElementGroupPrototype (elementGroup, elements, closureType); > public MyElementOperations(IServiceProvider serviceProvider, ElementOps1Diagram diagram) : base(serviceProvider, diagram) < >> // Replace the standard ElementOperations // singleton with your own: partial class MyDslDiagram // EDIT NAME < /// /// Singleton ElementOperations attached to this diagram. /// public override DesignSurfaceElementOperations ElementOperations < get < if (singleton == null) < singleton = new MyElementOperations(this.Store as IServiceProvider, this); >return singleton; > > private MyElementOperations singleton = null; >
Вставьте фигуры в выбранное место, например в текущее положение указателя. Если пользователь копирует несколько фигур, можно сделать так, чтобы при вставке их положение относительно друг друга сохранялось. Этот метод демонстрируется примером в VMSDK: пример схемы схемы.
Для достижения такого эффекта переопределите ClipboardCommandSet.ProcessOnMenuPasteCommand() , чтобы использовать версию ElementOperations.Merge() , зависящую от местоположения. Для этого добавьте в проект DslPackage следующий код:
partial class MyDslClipboardCommandSet // EDIT NAME < /// /// This method assumes we only want to paste things onto the diagram /// - not onto anything contained in the diagram. /// The base method pastes in a free space on the diagram. /// But if the menu was used to invoke paste, we want to paste in the cursor position. /// protected override void ProcessOnMenuPasteCommand() < NestedShapesSampleDocView docView = this.CurrentModelingDocView as NestedShapesSampleDocView; // Retrieve data from clipboard: System.Windows.Forms.IDataObject data = System.Windows.Forms.Clipboard.GetDataObject(); Diagram diagram = docView.CurrentDiagram; if (diagram == null) return; if (!docView.IsContextMenuShowing) < // User hit CTRL+V - just use base method. // Deselect anything that's selected, otherwise // pasted item will be incompatible: if (!this.IsDiagramSelected()) < docView.SelectObjects(1, new object[] < diagram >, 0); > // Paste into a convenient spare space on diagram: base.ProcessOnMenuPasteCommand(); > else < // User right-clicked - paste at mouse position. // Utility class: DesignSurfaceElementOperations op = diagram.ElementOperations; ShapeElement pasteTarget = diagram; // Check whether what's in the paste buffer is acceptable on the target. if (pasteTarget != null && op.CanMerge(pasteTarget, data)) < // Although op.Merge would be a no-op if CanMerge failed, we check CanMerge first // so that we don't create an empty transaction (after which Undo would be no-op). using (Transaction t = diagram.Store.TransactionManager.BeginTransaction("paste")) < PointD place = docView.ContextMenuMousePosition; op.Merge(pasteTarget, data, PointD.ToPointF(place)); t.Commit(); >> > > >
Пусть пользователь перетаскивает элементы. См . практическое руководство. Добавление обработчика перетаскивания.
Настройка поведения копирования ссылок
Когда пользователь копирует элемент, стандартное поведение заключается в том, что также копируются все внедренные элементы. Стандартное поведение копирования можно изменить. В определении DSL выберите роль в одной стороне связи и в окно свойств задайте значение «Распространение копирования«.

Поддерживается три значения:

- Не распространять копирование.
- Распространить копирование только на связь: когда вставляется группа, новая копия этой связи ссылается на существующий элемент на другом конце связи.
- Распространить копирование на исполнителя противоположной роли: скопированная группа включает копию элемента на другом конце связи. Сделанные изменения повлияют на элементы и скопированное изображение.
Программирование поведения копирования и вставки
Многие аспекты поведения DSL относительно копирования, вставки, создания и удаления объектов управляются экземпляром ElementOperations , который связан с схемой. Вы можете изменить поведение DSL, наследив собственный класс и ElementOperations переопределив ElementOperations свойство класса схемы.
Дополнительные сведения о настройке модели с помощью кода программы см. в статье «Навигация и обновление модели в коде программы».


Определение собственного ElementOperations
- В новом файле проекта доменного языка создайте класс, производный от класса DesignSurfaceElementOperations.
- Добавьте определение разделяемого класса для класса схемы. Имя этого класса можно найти в dsl\GeneratedCode\Diagrams.cs. В классе схемы переопределите ElementOperations , чтобы вернуть экземпляр подкласса ElementOperations. Необходимо вернуть тот же самый экземпляр в каждом классе. Добавьте этот код в пользовательский файл кода в проекте DslPackage:
using Microsoft.VisualStudio.Modeling; using Microsoft.VisualStudio.Modeling.Diagrams; using Microsoft.VisualStudio.Modeling.Diagrams.ExtensionEnablement; public partial class MyDslDiagram < public override DesignSurfaceElementOperations ElementOperations < get < if (this.elementOperations == null) < this.elementOperations = new MyElementOperations(this.Store as IServiceProvider, this); >return this.elementOperations; > > private MyElementOperations elementOperations = null; > public class MyElementOperations : DesignSurfaceElementOperations < public MyElementOperations(IServiceProvider serviceProvider, MyDslDiagram diagram) : base(serviceProvider, diagram) < >// Overridden methods follow >
Получение элементов, перетаскиваемых из других моделей
ElementOperations можно также использовать для определения поведения копирования, перемещения, удаления и перетаскивания. Для демонстрации использования ElementOperations в приведенном ниже примере определяется пользовательское поведение перетаскивания. Однако для этого можно рассмотреть альтернативный подход, описанный в разделе «Практическое руководство. Добавление обработчика перетаскивания», который является более расширяемым.
Определите два метода в классе ElementOperations:
- CanMerge(ModelElement targetElement, System.Windows.Forms.IDataObject data) определяет, можно ли перетащить исходный элемент на целевую фигуру, соединитель или схему.
- MergeElementGroupPrototype(ModelElement targetElement, ElementGroupPrototype sourcePrototype) который объединяет исходный элемент в целевой объект.
CanMerge()
CanMerge() вызывается для определения отзывов, которые должны быть предоставлены пользователю при перемещении мыши по схеме. Для метода используются следующие параметры: элемент, на который наводится указатель мыши, и данные об источнике, из которого была выполнена операция перетаскивания. Пользователь может перетащить элемент из любого места экрана, поэтому исходный объект может быть разных типов и сериализован в разных форматах. Если источник является доменным языком или моделью UML, параметр данных является сериализацией ElementGroupPrototype. Операции перетаскивания, копирования и панели инструментов используют ElementGroupPrototypes для представления фрагментов моделей.
Прототип группы элементов может содержать любое количество элементов и связей. Типы элементов можно идентифицировать по их GUID. GUID принадлежит перетащенной фигуре, а не базовому элементу модели. В следующем примере CanMerge() возвращает значение true, если фигура класса из диаграммы UML перетаскивается в эту схему.
public override bool CanMerge(ModelElement targetShape, System.Windows.Forms.IDataObject data) < // Extract the element prototype from the data. ElementGroupPrototype prototype = ElementOperations.GetElementGroupPrototype(this.ServiceProvider, data); if (targetShape is MyTargetShape && prototype != null && prototype.RootProtoElements.Any(rootElement =>rootElement.DomainClassId.ToString() == "3866d10c-cc4e-438b-b46f-bb24380e1678")) // Guid of UML Class shapes // or SourceClass.DomainClassId return true; return base.CanMerge(targetShape, data); >
MergeElementGroupPrototype()
Этот метод вызывается, если пользователь вставляет элемент в схему, фигуру или соединитель. Он должен произвести слияние перетаскиваемого содержимого с целевым объектом. В этом примере код определяет, распознается ли комбинация типов цели и прототипа. Если да, то метод преобразует перетаскиваемые элементы в прототип элементов, которые должны быть добавлены к модели. Базовый метод вызывается для выполнения слияния преобразованных или не преобразованных элементов.
public override void MergeElementGroupPrototype(ModelElement targetShape, ElementGroupPrototype sourcePrototype) < ElementGroupPrototype prototypeToMerge = sourcePrototype; MyTargetShape pel = targetShape as MyTargetShape; if (pel != null) < prototypeToMerge = ConvertDraggedTypeToLocal(pel, sourcePrototype); >if (prototypeToMerge != null) base.MergeElementGroupPrototype(targetShape, prototypeToMerge); >
В этом примере обрабатываются элементы класса UML, перетаскиваемого из схемы класса UML. DSL не предусматривает прямое сохранение классов UML. Вместо этого создается элемент DSL для каждого перетаскиваемого класса UML. Это пригодится, если, например, доменный язык является схемой экземпляра. Пользователь может перетаскивать классы на схему, чтобы создать экземпляры этих классов.
private ElementGroupPrototype ConvertDraggedTypeToLocal (MyTargetShape snapshot, ElementGroupPrototype prototype) < // Find the UML project: EnvDTE.DTE dte = snapshot.Store.GetService(typeof(EnvDTE.DTE)) as EnvDTE.DTE; foreach (EnvDTE.Project project in dte.Solution.Projects) < IModelingProject modelingProject = project as IModelingProject; if (modelingProject == null) continue; // not a modeling project IModelStore store = modelingProject.Store; if (store == null) continue; // Look for the shape that was dragged: foreach (IDiagram umlDiagram in store.Diagrams()) < // Get modeling diagram that implements UML diagram: Diagram diagram = umlDiagram.GetObject(); Guid elementId = prototype.SourceRootElementIds.FirstOrDefault(); ShapeElement shape = diagram.Partition.ElementDirectory.FindElement(elementId) as ShapeElement; if (shape == null) continue; IClass classElement = shape.ModelElement as IClass; if (classElement == null) continue; // Create a prototype of elements in my DSL, based on the UML element: Instance instance = new Instance(snapshot.Store); instance.Type = classElement.Name; // Pack them into a prototype: ElementGroup group = new ElementGroup(instance); return group.CreatePrototype(); > > return null; >
Стандартное поведение копирования
Код в этом разделе включает методы, которые можно переопределить для изменения поведения копирования. Чтобы показать вам, как можно настроить код в соответствии с индивидуальными требованиями, в этом разделе представлен код, которые переопределяет методы, задействованные в копировании, но не изменяет стандартное поведение.
Когда пользователь нажимает сочетание клавиш CTRL + C или применяет команду меню «Копировать», вызывается метод ProcessOnMenuCopyCommand. Вы можете узнать, как это настроить в DslPackage\Generated Code\CommandSet.cs. Дополнительные сведения о настройке команд см. в разделе «Практическое руководство. Добавление команды в контекстное меню».
Можно переопределить ProcessOnMenuCopyCommand, добавив частичное определение класса MyDsl ClipboardCommandSet в проект DslPackage.
using System.Collections.Generic; using System.Drawing; using System.Windows.Forms; using Microsoft.VisualStudio.Modeling; using Microsoft.VisualStudio.Modeling.Diagrams; partial class MyDslClipboardCommandSet < /// /// Override ProcessOnMenuCopyCommand() to copy elements to the /// clipboard in different formats, or to perform additional tasks /// before or after copying - for example deselect the copied elements. /// protected override void ProcessOnMenuCopyCommand() < IListselectedModelElements = this.SelectedElements; if (selectedModelElements.Count == 0) return; // System container for clipboard data. // The IDataObject can contain data in several formats. IDataObject dataObject = new DataObject(); Bitmap bitmap = null; // For export to other programs. try < #region Create EGP for copying to a DSL. this.CopyModelElementsIntoElementGroupPrototype (dataObject, selectedModelElements); #endregion #region Create bitmap for copying to another application. // Find all the shapes associated with this selection: Listshapes = new List( this.ResolveExportedShapesForClipboardImages (dataObject, selectedModelElements)); bitmap = this.CreateBitmapForClipboard(shapes); if (bitmap != null) < dataObject.SetData(DataFormats.Bitmap, bitmap); >#endregion // Add the data to the clipboard: Clipboard.SetDataObject(dataObject, true, 5, 100); > finally < // Dispose bitmap after SetDataObject: if (bitmap != null) bitmap.Dispose(); >> /// /// Override this to customize the element group that is copied to the clipboard. /// protected override void CopyModelElementsIntoElementGroupPrototype(IDataObject dataObject, IList selectedModelElements) < return this.ElementOperations.Copy(dataObject, selectedModelElements); >>
Каждая схема имеет единственный экземпляр ElementOperations. Можно указать свою собственную производную. Этот файл, который можно поместить в проект доменного языка, будет вести себя так же, как и код, который он переопределяет:
using System; using System.Collections.Generic; using System.Linq; using Microsoft.VisualStudio.Modeling; using Microsoft.VisualStudio.Modeling.Diagrams; namespace Company.MyDsl < partial class MyDslDiagram < /// /// Singleton ElementOperations attached to this diagram. /// public override DesignSurfaceElementOperations ElementOperations < get < if (this.elementOperations == null) < this.elementOperations = new MyElementOperations(this.Store as IServiceProvider, this); >return this.elementOperations; > > private MyElementOperations elementOperations = null; > // Our own version of ElementOperations so that we can override: public class MyElementOperations : DesignSurfaceElementOperations < public MyElementOperations(IServiceProvider serviceProvider, ElementOps1Diagram diagram) : base(serviceProvider, diagram) < >/// /// Copy elements to the clipboard data. /// Provides a hook for adding custom data. /// public override void Copy(System.Windows.Forms.IDataObject data, ICollection elements, ClosureType closureType, System.Drawing.PointF sourcePosition) < if (CanAddElementGroupFormat(elements, closureType)) < AddElementGroupFormat(data, elements, closureType); >// Override these to store additional data: if (CanAddCustomFormat(elements, closureType)) < AddCustomFormat(data, elements, closureType, sourcePosition); >> protected override void AddElementGroupFormat(System.Windows.Forms.IDataObject data, ICollection elements, ClosureType closureType) < // Add the selected elements and those implied by the propagate copy rules: ElementGroup elementGroup = this.CreateElementGroup(elements, closureType); // Mark all the elements that are not embedded under other elements: this.MarkRootElements(elementGroup, elements, closureType); // Store in the clipboard data: ElementGroupPrototype elementGroupPrototype = this.CreateElementGroupPrototype(elementGroup, elements, closureType); data.SetData(ElementGroupPrototype.DefaultDataFormatName, elementGroupPrototype); >/// /// Override this to store additional elements in the element group: /// protected override ElementGroupPrototype CreateElementGroupPrototype(ElementGroup elementGroup, ICollection elements, ClosureType closureType) < ElementGroupPrototype prototype = new ElementGroupPrototype(this.Partition, elementGroup.RootElements, elementGroup); return prototype; >/// /// Create an element group from the given starting elements, using the /// copy propagation rules specified in the DSL Definition. /// By default, this includes all the embedded descendants of the starting elements, /// and also includes reference links where both ends are already included. /// /// model elements to copy /// /// protected override ElementGroup CreateElementGroup(ICollection startElements, ClosureType closureType) < // ElementClosureWalker finds all the connected elements, // according to the propagate copy rules specified in the DSL Definition: ElementClosureWalker walker = new ElementClosureWalker(this.Partition, closureType, // Normally ClosureType.CopyClosure startElements, true, // Do not load other models. null, // Optional list of domain roles not to traverse. true); // Include relationship links where both ends are already included. walker.Traverse(startElements); IListclosureList = walker.ClosureList; Dictionary closureContext = walker.Context; // create a group for this closure ElementGroup group = new ElementGroup(this.Partition); group.AddRange(closureList, false); // create the element group prototype for the group foreach (object key in closureContext.Keys) < group.SourceContext.ContextInfo[key] = closureContext[key]; >return group; > > >
Связанный контент
- Настройка создания и перемещения элементов
- Практическое руководство. Добавление обработчика перетаскивания
- Пример: пример схемы каналов VMSDK
Компонент Text Template Transformation (Преобразование текстовых шаблонов) автоматически устанавливается как часть рабочей нагрузки разработки расширений Visual Studio. Его также можно установить на вкладке Отдельные компоненты Visual Studio Installer в категории Пакеты SDK, библиотеки и платформы. Установите компонент Пакет SDK для моделирования со вкладки Отдельные компоненты.
Как создать копию формы в программе Visual Studio?
Сегодня хочу показать, как можно быстро создать копию формы с помощью графического интерфейса программы Visual Studio.
1. Создадим новый проект типа Windows Forms Application.
2. Выполним команду: Build -> Build Solution.

3. Переходим в окно Solution Explorer и нажимаем правую кнопку мышки на имени текущего проекта. После чего в появившемся контекстном меню выбираем пункт Add и следом в дополнительном меню выбираем пункт New Item.

4. В появившемся окне Add New Item выбираем пункт Inherited Form, после чего нажимаем на кнопку Add.

5. В открывшемся диалоговом окне Inheritance Picker выбираем компонент (форму), на основе которого мы хотим создать копию.

В данном примере в списке содержится только один компонент Form1, поэтому можно сразу же нажать на кнопку OK. (Если данная кнопка не доступна (не активна), то это значит, что вы не выполнили пункт №2).
После нажатия на кнопку выполняется обычно наследование:
class Form2 : Form1 <>
В результате создаётся копия первой формы (Form2).

- Как выполнить команду в cmd
- Как получить исходный код страницы с помощью класса WebBrowser?
- Убираем выделение в первой ячейке DataGridView
Один комментарий
Я добавляю новую форму выбираю производная форма после выбираю форму Form1 и создается копия Form2 на скрине у меня она уже создана