Compare commits
8 Commits
main
...
Lab2_Volko
Author | SHA1 | Date | |
---|---|---|---|
3ba5fd8046 | |||
4865ee8da9 | |||
160b7dc88a | |||
66702ee864 | |||
cca38e76c1 | |||
5f19fb8329 | |||
c44986349c | |||
52a0e50af6 |
31
VolkovLabs/VolkovLabs.sln
Normal file
31
VolkovLabs/VolkovLabs.sln
Normal file
@ -0,0 +1,31 @@
|
||||
|
||||
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||
# Visual Studio Version 17
|
||||
VisualStudioVersion = 17.9.34723.18
|
||||
MinimumVisualStudioVersion = 10.0.40219.1
|
||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "WinFormsLibraryVolkov", "WinFormsLibraryVolkov\WinFormsLibraryVolkov.csproj", "{80044A4D-FF3B-4CA9-AA16-4E4E2520B60C}"
|
||||
EndProject
|
||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "WinFormsTestApp", "WinFormsTestApp\WinFormsTestApp.csproj", "{10C4BDA8-E7E7-4B43-8F9E-6549C5C40646}"
|
||||
EndProject
|
||||
Global
|
||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||
Debug|Any CPU = Debug|Any CPU
|
||||
Release|Any CPU = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||
{80044A4D-FF3B-4CA9-AA16-4E4E2520B60C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||
{80044A4D-FF3B-4CA9-AA16-4E4E2520B60C}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{80044A4D-FF3B-4CA9-AA16-4E4E2520B60C}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{80044A4D-FF3B-4CA9-AA16-4E4E2520B60C}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
{10C4BDA8-E7E7-4B43-8F9E-6549C5C40646}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||
{10C4BDA8-E7E7-4B43-8F9E-6549C5C40646}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{10C4BDA8-E7E7-4B43-8F9E-6549C5C40646}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{10C4BDA8-E7E7-4B43-8F9E-6549C5C40646}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(SolutionProperties) = preSolution
|
||||
HideSolutionNode = FALSE
|
||||
EndGlobalSection
|
||||
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||
SolutionGuid = {07EF6063-AD68-403B-A72B-B19E4B920CD0}
|
||||
EndGlobalSection
|
||||
EndGlobal
|
@ -0,0 +1,18 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Runtime.Serialization;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace WinFormsLibraryVolkov.Exceptions
|
||||
{
|
||||
[Serializable]
|
||||
public class DateBoundsNotSetException: ApplicationException
|
||||
{
|
||||
public DateBoundsNotSetException() : base() { }
|
||||
public DateBoundsNotSetException(string message) : base(message) { }
|
||||
public DateBoundsNotSetException(string message, Exception exception) : base(message, exception){ }
|
||||
protected DateBoundsNotSetException(SerializationInfo info, StreamingContext contex) : base(info, contex) { }
|
||||
}
|
||||
}
|
@ -0,0 +1,17 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Runtime.Serialization;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace WinFormsLibraryVolkov.Exceptions
|
||||
{
|
||||
public class DateOutOfBoundsException : ApplicationException
|
||||
{
|
||||
public DateOutOfBoundsException() : base() { }
|
||||
public DateOutOfBoundsException(string message) : base(message) { }
|
||||
public DateOutOfBoundsException(string message, Exception exception) : base(message, exception) { }
|
||||
protected DateOutOfBoundsException(SerializationInfo info, StreamingContext contex) : base(info, contex) { }
|
||||
}
|
||||
}
|
@ -0,0 +1,16 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace WinFormsLibraryVolkov.NonVisualComponents
|
||||
{
|
||||
public enum DiagramLegendEnum
|
||||
{
|
||||
TopLeft = 0,
|
||||
TopRight = 1,
|
||||
BottomRight = 2,
|
||||
BottomLeft = 3,
|
||||
}
|
||||
}
|
36
VolkovLabs/WinFormsLibraryVolkov/NonVisualComponents/ExcelDiagramComponent.Designer.cs
generated
Normal file
36
VolkovLabs/WinFormsLibraryVolkov/NonVisualComponents/ExcelDiagramComponent.Designer.cs
generated
Normal file
@ -0,0 +1,36 @@
|
||||
namespace WinFormsLibraryVolkov.NonVisualComponents
|
||||
{
|
||||
partial class ExcelDiagramComponent
|
||||
{
|
||||
/// <summary>
|
||||
/// Обязательная переменная конструктора.
|
||||
/// </summary>
|
||||
private System.ComponentModel.IContainer components = null;
|
||||
|
||||
/// <summary>
|
||||
/// Освободить все используемые ресурсы.
|
||||
/// </summary>
|
||||
/// <param name="disposing">истинно, если управляемый ресурс должен быть удален; иначе ложно.</param>
|
||||
protected override void Dispose(bool disposing)
|
||||
{
|
||||
if (disposing && (components != null))
|
||||
{
|
||||
components.Dispose();
|
||||
}
|
||||
base.Dispose(disposing);
|
||||
}
|
||||
|
||||
#region Код, автоматически созданный конструктором компонентов
|
||||
|
||||
/// <summary>
|
||||
/// Требуемый метод для поддержки конструктора — не изменяйте
|
||||
/// содержимое этого метода с помощью редактора кода.
|
||||
/// </summary>
|
||||
private void InitializeComponent()
|
||||
{
|
||||
components = new System.ComponentModel.Container();
|
||||
}
|
||||
|
||||
#endregion
|
||||
}
|
||||
}
|
@ -0,0 +1,119 @@
|
||||
using Microsoft.Office.Interop.Excel;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel;
|
||||
using System.Diagnostics;
|
||||
using System.Linq;
|
||||
using System.Reflection;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace WinFormsLibraryVolkov.NonVisualComponents
|
||||
{
|
||||
[ToolboxItem(true)]
|
||||
public partial class ExcelDiagramComponent : Component
|
||||
{
|
||||
public ExcelDiagramComponent()
|
||||
{
|
||||
InitializeComponent();
|
||||
}
|
||||
|
||||
public ExcelDiagramComponent(IContainer container)
|
||||
{
|
||||
container.Add(this);
|
||||
|
||||
InitializeComponent();
|
||||
}
|
||||
|
||||
public bool createWithDiagram<T>(string path, string title, string diagramTitle, DiagramLegendEnum diagramLegendAnchor, List<T> data, string seriesNameField, string valueField)
|
||||
{
|
||||
var excelApp = new Microsoft.Office.Interop.Excel.Application { SheetsInNewWorkbook = 1 };
|
||||
Workbook workbook = excelApp.Workbooks.Add(Type.Missing);
|
||||
try
|
||||
{
|
||||
Worksheet worksheet = (Worksheet)workbook.Worksheets.get_Item(1);
|
||||
|
||||
FieldInfo? seriesName = typeof(T).GetField(seriesNameField);
|
||||
FieldInfo? value = typeof(T).GetField(valueField);
|
||||
if (seriesName == null || value == null) throw new ArgumentException("Переданного поля не существует");
|
||||
int columnCount = 2;
|
||||
foreach(var item in data)
|
||||
{
|
||||
var cell = worksheet.get_Range("A" + columnCount, "A" + columnCount);
|
||||
cell.Font.Size = 14;
|
||||
cell.Font.Name = "Times New Roman";
|
||||
cell.ColumnWidth = 8;
|
||||
cell.RowHeight = 25;
|
||||
cell.HorizontalAlignment = Constants.xlCenter;
|
||||
cell.VerticalAlignment = Constants.xlCenter;
|
||||
cell.Value2 = seriesName.GetValue(item);
|
||||
|
||||
cell = worksheet.get_Range("B" + columnCount, "B" + columnCount);
|
||||
cell.Font.Size = 14;
|
||||
cell.Font.Name = "Times New Roman";
|
||||
cell.ColumnWidth = 8;
|
||||
cell.RowHeight = 25;
|
||||
cell.HorizontalAlignment = Constants.xlCenter;
|
||||
cell.VerticalAlignment = Constants.xlCenter;
|
||||
cell.Value2 = value.GetValue(item);
|
||||
|
||||
columnCount++;
|
||||
}
|
||||
|
||||
//header
|
||||
var excelcells = worksheet.get_Range("A1", "A1");
|
||||
excelcells.Font.Bold = true;
|
||||
excelcells.Font.Size = 14;
|
||||
excelcells.Font.Name = "Times New Roman";
|
||||
excelcells.ColumnWidth = 8;
|
||||
excelcells.RowHeight = 25;
|
||||
excelcells.HorizontalAlignment = Constants.xlCenter;
|
||||
excelcells.VerticalAlignment = Constants.xlCenter;
|
||||
excelcells.Value2 = title;
|
||||
|
||||
var charts = worksheet.ChartObjects() as ChartObjects;
|
||||
int chartWidth = 300;
|
||||
int chartHeight = 300;
|
||||
var chartObject = charts.Add(250, 10, chartWidth, chartHeight);
|
||||
var chart = chartObject.Chart;
|
||||
var range = worksheet.get_Range($"A2", $"B{columnCount - 1}");
|
||||
chart.SetSourceData(range);
|
||||
chart.ChartType = XlChartType.xlPie;
|
||||
switch (diagramLegendAnchor)
|
||||
{
|
||||
case DiagramLegendEnum.TopLeft:
|
||||
chart.Legend.Top = 0;
|
||||
chart.Legend.Left = 0;
|
||||
break;
|
||||
case DiagramLegendEnum.TopRight:
|
||||
chart.Legend.Top = 0;
|
||||
chart.Legend.Left = chartWidth - chart.Legend.Width;
|
||||
break;
|
||||
case DiagramLegendEnum.BottomLeft:
|
||||
chart.Legend.Top = chartHeight - chart.Legend.Height;
|
||||
chart.Legend.Left = 0;
|
||||
break;
|
||||
case DiagramLegendEnum.BottomRight:
|
||||
chart.Legend.Top = chartHeight - chart.Legend.Height;
|
||||
chart.Legend.Left = chartWidth - chart.Legend.Width;
|
||||
break;
|
||||
}
|
||||
chart.ChartWizard(Source: range, Title: diagramTitle);
|
||||
|
||||
object missing = System.Reflection.Missing.Value;
|
||||
workbook.SaveAs(path, XlFileFormat.xlOpenXMLWorkbook, missing, missing, false, false, XlSaveAsAccessMode.xlNoChange,
|
||||
XlSaveConflictResolution.xlUserResolution, true, missing, missing, missing);
|
||||
workbook.Close();
|
||||
excelApp.Quit();
|
||||
|
||||
return true;
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
workbook.Close();
|
||||
excelApp.Quit();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
@ -0,0 +1,22 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace WinFormsLibraryVolkov.NonVisualComponents
|
||||
{
|
||||
public class ExcelImageInfo
|
||||
{
|
||||
public ExcelImageInfo(string path, string title, string[] imagePaths)
|
||||
{
|
||||
this.path = path;
|
||||
this.title = title;
|
||||
this.imagePaths = imagePaths;
|
||||
}
|
||||
|
||||
public string path;
|
||||
public string title;
|
||||
public string[] imagePaths;
|
||||
}
|
||||
}
|
36
VolkovLabs/WinFormsLibraryVolkov/NonVisualComponents/ExcelImagesComponent.Designer.cs
generated
Normal file
36
VolkovLabs/WinFormsLibraryVolkov/NonVisualComponents/ExcelImagesComponent.Designer.cs
generated
Normal file
@ -0,0 +1,36 @@
|
||||
namespace WinFormsLibraryVolkov.NonVisualComponents
|
||||
{
|
||||
partial class ExcelImagesComponent
|
||||
{
|
||||
/// <summary>
|
||||
/// Обязательная переменная конструктора.
|
||||
/// </summary>
|
||||
private System.ComponentModel.IContainer components = null;
|
||||
|
||||
/// <summary>
|
||||
/// Освободить все используемые ресурсы.
|
||||
/// </summary>
|
||||
/// <param name="disposing">истинно, если управляемый ресурс должен быть удален; иначе ложно.</param>
|
||||
protected override void Dispose(bool disposing)
|
||||
{
|
||||
if (disposing && (components != null))
|
||||
{
|
||||
components.Dispose();
|
||||
}
|
||||
base.Dispose(disposing);
|
||||
}
|
||||
|
||||
#region Код, автоматически созданный конструктором компонентов
|
||||
|
||||
/// <summary>
|
||||
/// Требуемый метод для поддержки конструктора — не изменяйте
|
||||
/// содержимое этого метода с помощью редактора кода.
|
||||
/// </summary>
|
||||
private void InitializeComponent()
|
||||
{
|
||||
components = new System.ComponentModel.Container();
|
||||
}
|
||||
|
||||
#endregion
|
||||
}
|
||||
}
|
@ -0,0 +1,75 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel;
|
||||
using System.Drawing;
|
||||
using System.Diagnostics;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using Microsoft.Office.Interop.Excel;
|
||||
using Microsoft.Office.Core;
|
||||
|
||||
namespace WinFormsLibraryVolkov.NonVisualComponents
|
||||
{
|
||||
public partial class ExcelImagesComponent : Component
|
||||
{
|
||||
public ExcelImagesComponent()
|
||||
{
|
||||
InitializeComponent();
|
||||
}
|
||||
|
||||
public ExcelImagesComponent(IContainer container)
|
||||
{
|
||||
container.Add(this);
|
||||
|
||||
InitializeComponent();
|
||||
}
|
||||
|
||||
public bool createWithImages(ExcelImageInfo info)
|
||||
{
|
||||
var excelApp = new Microsoft.Office.Interop.Excel.Application { SheetsInNewWorkbook = 1 };
|
||||
Workbook workbook = excelApp.Workbooks.Add(Type.Missing);
|
||||
try
|
||||
{
|
||||
//create
|
||||
Worksheet worksheet = (Worksheet)workbook.Worksheets.get_Item(1);
|
||||
|
||||
//header
|
||||
var excelcells = worksheet.get_Range("A1", "D1");
|
||||
excelcells.Merge(Type.Missing);
|
||||
excelcells.Font.Bold = true;
|
||||
excelcells.Font.Size = 14;
|
||||
excelcells.Font.Name = "Times New Roman";
|
||||
excelcells.ColumnWidth = 8;
|
||||
excelcells.RowHeight = 25;
|
||||
excelcells.HorizontalAlignment = Constants.xlCenter;
|
||||
excelcells.VerticalAlignment = Constants.xlCenter;
|
||||
excelcells.Value2 = info.title;
|
||||
|
||||
int topOffset = 25;
|
||||
foreach (string path in info.imagePaths)
|
||||
{
|
||||
Bitmap bm = new Bitmap(path);
|
||||
worksheet.Shapes.AddPicture2(path, MsoTriState.msoFalse, MsoTriState.msoCTrue, 0, topOffset, bm.Width, bm.Height, MsoPictureCompress.msoPictureCompressFalse);
|
||||
topOffset += bm.Height;
|
||||
bm.Dispose();
|
||||
}
|
||||
|
||||
//save
|
||||
object missing = System.Reflection.Missing.Value;
|
||||
workbook.SaveAs(info.path, XlFileFormat.xlOpenXMLWorkbook, missing, missing, false, false, XlSaveAsAccessMode.xlNoChange,
|
||||
XlSaveConflictResolution.xlUserResolution, true, missing, missing, missing);
|
||||
workbook.Close();
|
||||
excelApp.Quit();
|
||||
|
||||
return true;
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
workbook.Close();
|
||||
excelApp.Quit();
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
36
VolkovLabs/WinFormsLibraryVolkov/NonVisualComponents/ExcelTableComponent.Designer.cs
generated
Normal file
36
VolkovLabs/WinFormsLibraryVolkov/NonVisualComponents/ExcelTableComponent.Designer.cs
generated
Normal file
@ -0,0 +1,36 @@
|
||||
namespace WinFormsLibraryVolkov.NonVisualComponents
|
||||
{
|
||||
partial class ExcelTableComponent
|
||||
{
|
||||
/// <summary>
|
||||
/// Обязательная переменная конструктора.
|
||||
/// </summary>
|
||||
private System.ComponentModel.IContainer components = null;
|
||||
|
||||
/// <summary>
|
||||
/// Освободить все используемые ресурсы.
|
||||
/// </summary>
|
||||
/// <param name="disposing">истинно, если управляемый ресурс должен быть удален; иначе ложно.</param>
|
||||
protected override void Dispose(bool disposing)
|
||||
{
|
||||
if (disposing && (components != null))
|
||||
{
|
||||
components.Dispose();
|
||||
}
|
||||
base.Dispose(disposing);
|
||||
}
|
||||
|
||||
#region Код, автоматически созданный конструктором компонентов
|
||||
|
||||
/// <summary>
|
||||
/// Требуемый метод для поддержки конструктора — не изменяйте
|
||||
/// содержимое этого метода с помощью редактора кода.
|
||||
/// </summary>
|
||||
private void InitializeComponent()
|
||||
{
|
||||
components = new System.ComponentModel.Container();
|
||||
}
|
||||
|
||||
#endregion
|
||||
}
|
||||
}
|
@ -0,0 +1,193 @@
|
||||
using Microsoft.Office.Interop.Excel;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel;
|
||||
using System.Data.Common;
|
||||
using System.Diagnostics;
|
||||
using System.Linq;
|
||||
using System.Reflection;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace WinFormsLibraryVolkov.NonVisualComponents
|
||||
{
|
||||
public partial class ExcelTableComponent : Component
|
||||
{
|
||||
public ExcelTableComponent()
|
||||
{
|
||||
InitializeComponent();
|
||||
}
|
||||
|
||||
public ExcelTableComponent(IContainer container)
|
||||
{
|
||||
container.Add(this);
|
||||
|
||||
InitializeComponent();
|
||||
}
|
||||
|
||||
private string GetExcelColumnName(int columnNumber)
|
||||
{
|
||||
string columnName = "";
|
||||
|
||||
while (columnNumber > 0)
|
||||
{
|
||||
int modulo = (columnNumber - 1) % 26;
|
||||
columnName = Convert.ToChar('A' + modulo) + columnName;
|
||||
columnNumber = (columnNumber - modulo) / 26;
|
||||
}
|
||||
|
||||
return columnName;
|
||||
}
|
||||
|
||||
public bool createWithTable<T>(string path, string title, List<(int, int)> merges, List<int> heights, List<(string, string)> headers, List<T> items)
|
||||
{
|
||||
if (merges.Count == 0 || heights.Count == 0 || headers.Count == 0 || items.Count == 0) throw new ArgumentException("Недостаточно данных");
|
||||
int[] cellsArray = new int[heights.Count];
|
||||
foreach (var merge in merges)
|
||||
{
|
||||
if (merge.Item1 >= merge.Item2) throw new ArgumentException("Неправильно заполнены объединения строк");
|
||||
for (int i = merge.Item1; i < merge.Item2; i++)
|
||||
{
|
||||
cellsArray[i]++;
|
||||
}
|
||||
}
|
||||
foreach (int cell in cellsArray)
|
||||
{
|
||||
if (cell > 1) throw new ArgumentException("Объединения заходят друг на друга");
|
||||
}
|
||||
|
||||
var excelApp = new Microsoft.Office.Interop.Excel.Application { SheetsInNewWorkbook = 1 };
|
||||
Workbook workbook = excelApp.Workbooks.Add(Type.Missing);
|
||||
try
|
||||
{
|
||||
//create
|
||||
Worksheet worksheet = (Worksheet)workbook.Worksheets.get_Item(1);
|
||||
|
||||
//header
|
||||
var excelcells = worksheet.get_Range("A1", "A1");
|
||||
excelcells.Font.Bold = true;
|
||||
excelcells.Font.Size = 14;
|
||||
excelcells.Font.Name = "Times New Roman";
|
||||
excelcells.ColumnWidth = 8;
|
||||
excelcells.RowHeight = 25;
|
||||
excelcells.HorizontalAlignment = Constants.xlCenter;
|
||||
excelcells.VerticalAlignment = Constants.xlCenter;
|
||||
excelcells.Value2 = title;
|
||||
|
||||
//checks
|
||||
List<Microsoft.Office.Interop.Excel.Range> ranges = new List<Microsoft.Office.Interop.Excel.Range>();
|
||||
foreach (var merge in merges)
|
||||
{
|
||||
ranges.Add(worksheet.get_Range("A" + (merge.Item1 + 2), "A" + (merge.Item2 + 2)));
|
||||
}
|
||||
|
||||
int rangeIndex = 0;
|
||||
int headerIndex = 0;
|
||||
List<FieldInfo> cellFields = new List<FieldInfo>();
|
||||
var type = typeof(T);
|
||||
for (int i = 0; i < heights.Count; i++)
|
||||
{
|
||||
if (cellsArray[i] == 1)
|
||||
{
|
||||
//work with merge
|
||||
if (!string.IsNullOrEmpty(headers[headerIndex].Item1)) throw new ArgumentException("Заголовки и объединения строк не совпадают");
|
||||
|
||||
var groupRange = ranges[rangeIndex];
|
||||
groupRange.Merge(Type.Missing);
|
||||
groupRange.Font.Bold = true;
|
||||
groupRange.Font.Size = 14;
|
||||
groupRange.Font.Name = "Times New Roman";
|
||||
groupRange.ColumnWidth = 20;
|
||||
groupRange.HorizontalAlignment = Constants.xlCenter;
|
||||
groupRange.VerticalAlignment = Constants.xlCenter;
|
||||
groupRange.Value2 = headers[headerIndex].Item2;
|
||||
headerIndex++;
|
||||
|
||||
//work with cells in merge
|
||||
for (; i <= merges[rangeIndex].Item2; i++)
|
||||
{
|
||||
//work with cell
|
||||
if (string.IsNullOrEmpty(headers[headerIndex].Item1)) throw new ArgumentException("Заголовки и объединения строк не совпадают");
|
||||
var field = type.GetField(headers[headerIndex].Item1);
|
||||
if (field == null) throw new ArgumentException("В заголовках указано поле, которого нет в переданном классе");
|
||||
//format header
|
||||
var range = worksheet.get_Range("B" + (i + 2), "B" + (i + 2));
|
||||
range.Font.Bold = true;
|
||||
range.Font.Size = 14;
|
||||
range.Font.Name = "Times New Roman";
|
||||
range.ColumnWidth = 20;
|
||||
range.RowHeight = heights[i];
|
||||
range.HorizontalAlignment = Constants.xlCenter;
|
||||
range.VerticalAlignment = Constants.xlCenter;
|
||||
range.Value2 = headers[headerIndex].Item2;
|
||||
|
||||
cellFields.Add(field);
|
||||
headerIndex++;
|
||||
}
|
||||
i--;
|
||||
rangeIndex++;
|
||||
}
|
||||
else
|
||||
{
|
||||
//work with cell
|
||||
if (string.IsNullOrEmpty(headers[headerIndex].Item1)) throw new ArgumentException("Заголовки и объединения строк не совпадают");
|
||||
var field = type.GetField(headers[headerIndex].Item1);
|
||||
if (field == null) throw new ArgumentException("В заголовках указано поле, которого нет в переданном классе");
|
||||
//format header
|
||||
var range = worksheet.get_Range("A" + (i + 2), "B" + (i + 2));
|
||||
range.Merge(Type.Missing);
|
||||
range.Font.Bold = true;
|
||||
range.Font.Size = 14;
|
||||
range.Font.Name = "Times New Roman";
|
||||
range.ColumnWidth = 40;
|
||||
range.RowHeight = heights[i];
|
||||
range.HorizontalAlignment = Constants.xlCenter;
|
||||
range.VerticalAlignment = Constants.xlCenter;
|
||||
range.Value2 = headers[headerIndex].Item2;
|
||||
|
||||
cellFields.Add(field);
|
||||
headerIndex++;
|
||||
}
|
||||
}
|
||||
|
||||
int columnNum = 3;
|
||||
foreach (T item in items)
|
||||
{
|
||||
string column = GetExcelColumnName(columnNum);
|
||||
int rowNum = 2;
|
||||
foreach (var cellField in cellFields)
|
||||
{
|
||||
var range = worksheet.get_Range(column + rowNum, column + rowNum);
|
||||
range.Font.Size = 14;
|
||||
range.Font.Name = "Times New Roman";
|
||||
range.ColumnWidth = 20;
|
||||
range.HorizontalAlignment = Constants.xlCenter;
|
||||
range.VerticalAlignment = Constants.xlCenter;
|
||||
range.Value2 = cellField.FieldType == typeof(bool) ? ((bool) cellField.GetValue(item) ? "Да" : "Нет") : cellField.GetValue(item);
|
||||
|
||||
rowNum++;
|
||||
}
|
||||
columnNum++;
|
||||
}
|
||||
var borderRange = worksheet.get_Range("A2", GetExcelColumnName(columnNum-1) + (headerIndex - 1));
|
||||
borderRange.Borders.LineStyle = XlLineStyle.xlContinuous;
|
||||
borderRange.Borders.Weight = 2d;
|
||||
|
||||
//save
|
||||
object missing = System.Reflection.Missing.Value;
|
||||
workbook.SaveAs(path, XlFileFormat.xlOpenXMLWorkbook, missing, missing, false, false, XlSaveAsAccessMode.xlNoChange,
|
||||
XlSaveConflictResolution.xlUserResolution, true, missing, missing, missing);
|
||||
workbook.Close();
|
||||
excelApp.Quit();
|
||||
|
||||
return true;
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
workbook.Close();
|
||||
excelApp.Quit();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
59
VolkovLabs/WinFormsLibraryVolkov/VisualComponents/CustomInputRangeDate.Designer.cs
generated
Normal file
59
VolkovLabs/WinFormsLibraryVolkov/VisualComponents/CustomInputRangeDate.Designer.cs
generated
Normal file
@ -0,0 +1,59 @@
|
||||
namespace WinFormsLibraryVolkov
|
||||
{
|
||||
partial class CustomInputRangeDate
|
||||
{
|
||||
/// <summary>
|
||||
/// Обязательная переменная конструктора.
|
||||
/// </summary>
|
||||
private System.ComponentModel.IContainer components = null;
|
||||
|
||||
/// <summary>
|
||||
/// Освободить все используемые ресурсы.
|
||||
/// </summary>
|
||||
/// <param name="disposing">истинно, если управляемый ресурс должен быть удален; иначе ложно.</param>
|
||||
protected override void Dispose(bool disposing)
|
||||
{
|
||||
if (disposing && (components != null))
|
||||
{
|
||||
components.Dispose();
|
||||
}
|
||||
base.Dispose(disposing);
|
||||
}
|
||||
|
||||
#region Код, автоматически созданный конструктором компонентов
|
||||
|
||||
/// <summary>
|
||||
/// Требуемый метод для поддержки конструктора — не изменяйте
|
||||
/// содержимое этого метода с помощью редактора кода.
|
||||
/// </summary>
|
||||
private void InitializeComponent()
|
||||
{
|
||||
dateTimePicker = new DateTimePicker();
|
||||
SuspendLayout();
|
||||
//
|
||||
// dateTimePicker
|
||||
//
|
||||
dateTimePicker.Location = new Point(3, 3);
|
||||
dateTimePicker.Name = "dateTimePicker";
|
||||
dateTimePicker.Size = new Size(142, 23);
|
||||
dateTimePicker.TabIndex = 0;
|
||||
dateTimePicker.ValueChanged += dateTimePicker_ValueChanged;
|
||||
dateTimePicker.Enter += dateTimePicker_Enter;
|
||||
dateTimePicker.MaxDate = new DateTime(2024, 12, 31, 0, 0, 0, 0);
|
||||
dateTimePicker.MinDate = new DateTime(2004, 1, 11, 0, 0, 0, 0);
|
||||
//
|
||||
// CustomInputRangeDate
|
||||
//
|
||||
AutoScaleDimensions = new SizeF(7F, 15F);
|
||||
AutoScaleMode = AutoScaleMode.Font;
|
||||
Controls.Add(dateTimePicker);
|
||||
Name = "CustomInputRangeDate";
|
||||
Size = new Size(148, 231);
|
||||
ResumeLayout(false);
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
private DateTimePicker dateTimePicker;
|
||||
}
|
||||
}
|
@ -0,0 +1,91 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel;
|
||||
using System.Data;
|
||||
using System.Drawing;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using System.Windows.Forms;
|
||||
using ToolTip = System.Windows.Forms.ToolTip;
|
||||
|
||||
namespace WinFormsLibraryVolkov
|
||||
{
|
||||
public partial class CustomInputRangeDate : UserControl
|
||||
{
|
||||
private EventHandler _changeEvent;
|
||||
|
||||
// Диапазон
|
||||
private string example;
|
||||
|
||||
// 2 публичных поля для настройки границ диапазона
|
||||
public DateTime MinDate { get; set; }
|
||||
public DateTime MaxDate { get; set; }
|
||||
|
||||
public CustomInputRangeDate()
|
||||
{
|
||||
InitializeComponent();
|
||||
}
|
||||
|
||||
//Ошибка
|
||||
public string Error { get; protected set; } = string.Empty;
|
||||
|
||||
//Публичное свойство для установки и получения введенного значения(set, get).
|
||||
//При получении проводиться проверка,
|
||||
//если введенное значение не входит в диапазон, возвращать
|
||||
//значение null, а в отдельное поле выводить текст ошибки.При
|
||||
//установке должна проводиться проверка, если передаваемое
|
||||
//значение не входит в диапазон, то не заполнять поле компонента.
|
||||
public DateTime Date
|
||||
{
|
||||
get
|
||||
{
|
||||
if (MinDate == null || MaxDate == null)
|
||||
{
|
||||
throw new ArgumentException("Диапазон не задан");
|
||||
}
|
||||
if (dateTimePicker.Value >= MinDate && dateTimePicker.Value <= MaxDate)
|
||||
{
|
||||
return dateTimePicker.Value;
|
||||
}
|
||||
throw new ArgumentException($"Введенная дана лежит вне диапазона {MinDate.ToShortDateString()} - {MaxDate.ToShortDateString()}");
|
||||
}
|
||||
set
|
||||
{
|
||||
if (MinDate == null || MaxDate == null)
|
||||
{
|
||||
Error = "Диапазон не задан";
|
||||
}
|
||||
if (value >= MinDate && value <= MaxDate)
|
||||
{
|
||||
dateTimePicker.Value = value;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void dateTimePicker_Enter(object sender, EventArgs e)
|
||||
{
|
||||
ToolTip tt = new ToolTip();
|
||||
example = "Введите дату от " + MinDate.ToShortDateString() + " до " + MaxDate.ToShortDateString();
|
||||
tt.Show(example, dateTimePicker, 30, -20, 1000);
|
||||
}
|
||||
|
||||
private void dateTimePicker_ValueChanged(object sender, EventArgs e)
|
||||
{
|
||||
_changeEvent?.Invoke(sender, e);
|
||||
}
|
||||
|
||||
//Cобытие, вызываемое при смене значения.
|
||||
public event EventHandler ChangeEvent
|
||||
{
|
||||
add
|
||||
{
|
||||
_changeEvent += value;
|
||||
}
|
||||
remove
|
||||
{
|
||||
_changeEvent -= value;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
@ -0,0 +1,120 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<root>
|
||||
<!--
|
||||
Microsoft ResX Schema
|
||||
|
||||
Version 2.0
|
||||
|
||||
The primary goals of this format is to allow a simple XML format
|
||||
that is mostly human readable. The generation and parsing of the
|
||||
various data types are done through the TypeConverter classes
|
||||
associated with the data types.
|
||||
|
||||
Example:
|
||||
|
||||
... ado.net/XML headers & schema ...
|
||||
<resheader name="resmimetype">text/microsoft-resx</resheader>
|
||||
<resheader name="version">2.0</resheader>
|
||||
<resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader>
|
||||
<resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader>
|
||||
<data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data>
|
||||
<data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data>
|
||||
<data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64">
|
||||
<value>[base64 mime encoded serialized .NET Framework object]</value>
|
||||
</data>
|
||||
<data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
|
||||
<value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value>
|
||||
<comment>This is a comment</comment>
|
||||
</data>
|
||||
|
||||
There are any number of "resheader" rows that contain simple
|
||||
name/value pairs.
|
||||
|
||||
Each data row contains a name, and value. The row also contains a
|
||||
type or mimetype. Type corresponds to a .NET class that support
|
||||
text/value conversion through the TypeConverter architecture.
|
||||
Classes that don't support this are serialized and stored with the
|
||||
mimetype set.
|
||||
|
||||
The mimetype is used for serialized objects, and tells the
|
||||
ResXResourceReader how to depersist the object. This is currently not
|
||||
extensible. For a given mimetype the value must be set accordingly:
|
||||
|
||||
Note - application/x-microsoft.net.object.binary.base64 is the format
|
||||
that the ResXResourceWriter will generate, however the reader can
|
||||
read any of the formats listed below.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.binary.base64
|
||||
value : The object must be serialized with
|
||||
: System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
|
||||
: and then encoded with base64 encoding.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.soap.base64
|
||||
value : The object must be serialized with
|
||||
: System.Runtime.Serialization.Formatters.Soap.SoapFormatter
|
||||
: and then encoded with base64 encoding.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.bytearray.base64
|
||||
value : The object must be serialized into a byte array
|
||||
: using a System.ComponentModel.TypeConverter
|
||||
: and then encoded with base64 encoding.
|
||||
-->
|
||||
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
|
||||
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
|
||||
<xsd:element name="root" msdata:IsDataSet="true">
|
||||
<xsd:complexType>
|
||||
<xsd:choice maxOccurs="unbounded">
|
||||
<xsd:element name="metadata">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" use="required" type="xsd:string" />
|
||||
<xsd:attribute name="type" type="xsd:string" />
|
||||
<xsd:attribute name="mimetype" type="xsd:string" />
|
||||
<xsd:attribute ref="xml:space" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="assembly">
|
||||
<xsd:complexType>
|
||||
<xsd:attribute name="alias" type="xsd:string" />
|
||||
<xsd:attribute name="name" type="xsd:string" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="data">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
|
||||
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
|
||||
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
|
||||
<xsd:attribute ref="xml:space" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="resheader">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" type="xsd:string" use="required" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
</xsd:choice>
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
</xsd:schema>
|
||||
<resheader name="resmimetype">
|
||||
<value>text/microsoft-resx</value>
|
||||
</resheader>
|
||||
<resheader name="version">
|
||||
<value>2.0</value>
|
||||
</resheader>
|
||||
<resheader name="reader">
|
||||
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
<resheader name="writer">
|
||||
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
</root>
|
58
VolkovLabs/WinFormsLibraryVolkov/VisualComponents/CustomSelectedCheckedListBox.Designer.cs
generated
Normal file
58
VolkovLabs/WinFormsLibraryVolkov/VisualComponents/CustomSelectedCheckedListBox.Designer.cs
generated
Normal file
@ -0,0 +1,58 @@
|
||||
namespace WinFormsLibraryVolkov
|
||||
{
|
||||
partial class CustomSelectedCheckedListBox
|
||||
{
|
||||
/// <summary>
|
||||
/// Обязательная переменная конструктора.
|
||||
/// </summary>
|
||||
private System.ComponentModel.IContainer components = null;
|
||||
|
||||
/// <summary>
|
||||
/// Освободить все используемые ресурсы.
|
||||
/// </summary>
|
||||
/// <param name="disposing">истинно, если управляемый ресурс должен быть удален; иначе ложно.</param>
|
||||
protected override void Dispose(bool disposing)
|
||||
{
|
||||
if (disposing && (components != null))
|
||||
{
|
||||
components.Dispose();
|
||||
}
|
||||
base.Dispose(disposing);
|
||||
}
|
||||
|
||||
#region Код, автоматически созданный конструктором компонентов
|
||||
|
||||
/// <summary>
|
||||
/// Требуемый метод для поддержки конструктора — не изменяйте
|
||||
/// содержимое этого метода с помощью редактора кода.
|
||||
/// </summary>
|
||||
private void InitializeComponent()
|
||||
{
|
||||
checkedListBox = new CheckedListBox();
|
||||
SuspendLayout();
|
||||
//
|
||||
// checkedListBox
|
||||
//
|
||||
checkedListBox.FormattingEnabled = true;
|
||||
checkedListBox.Location = new Point(3, 1);
|
||||
checkedListBox.Name = "checkedListBox";
|
||||
checkedListBox.Size = new Size(144, 148);
|
||||
checkedListBox.TabIndex = 0;
|
||||
checkedListBox.Dock = DockStyle.Fill;
|
||||
checkedListBox.ItemCheck += new System.Windows.Forms.ItemCheckEventHandler(this.checkedListBox_ItemCheck);
|
||||
checkedListBox.SelectedIndexChanged += new System.EventHandler(this.checkedListBox_SelectedIndexChanged);
|
||||
//
|
||||
// SelectionListBox
|
||||
//
|
||||
AutoScaleDimensions = new SizeF(7F, 15F);
|
||||
AutoScaleMode = AutoScaleMode.Font;
|
||||
Controls.Add(checkedListBox);
|
||||
Name = "SelectionListBox";
|
||||
ResumeLayout(false);
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
private CheckedListBox checkedListBox;
|
||||
}
|
||||
}
|
@ -0,0 +1,87 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel;
|
||||
using System.Data;
|
||||
using System.Drawing;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using System.Windows.Forms;
|
||||
|
||||
namespace WinFormsLibraryVolkov
|
||||
{
|
||||
public partial class CustomSelectedCheckedListBox : UserControl
|
||||
{
|
||||
public event EventHandler _changeEvent;
|
||||
|
||||
public CustomSelectedCheckedListBox()
|
||||
{
|
||||
InitializeComponent();
|
||||
}
|
||||
|
||||
// Метод для заполнения списка строками
|
||||
public void PopulateList(List<string> items)
|
||||
{
|
||||
if (items == null)
|
||||
throw new ArgumentNullException(nameof(items));
|
||||
|
||||
foreach (var item in items)
|
||||
{
|
||||
checkedListBox.Items.Add(item, false);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
//Cобытие, вызываемое при смене значения в CheckedListBox
|
||||
public event EventHandler ChangeEvent
|
||||
{
|
||||
add
|
||||
{
|
||||
_changeEvent += value;
|
||||
}
|
||||
remove
|
||||
{
|
||||
_changeEvent -= value;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// Метод для очистки списка
|
||||
public void ClearList()
|
||||
{
|
||||
checkedListBox.Items.Clear();
|
||||
}
|
||||
|
||||
// Публичное свойство для получения и установки выбранного значения
|
||||
public string SelectedElement
|
||||
{
|
||||
get
|
||||
{
|
||||
return (checkedListBox.SelectedIndex > -1 && checkedListBox.GetItemChecked(checkedListBox.SelectedIndex)) ? checkedListBox.SelectedItem.ToString() : string.Empty;
|
||||
}
|
||||
set
|
||||
{
|
||||
if (checkedListBox.Items.Contains(value))
|
||||
{
|
||||
checkedListBox.SelectedItem = value;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Обработчик изменения состояния элементов
|
||||
private void checkedListBox_ItemCheck(object sender, ItemCheckEventArgs e)
|
||||
{
|
||||
if (e.NewValue == CheckState.Checked && checkedListBox.CheckedItems.Count > 0)
|
||||
{
|
||||
checkedListBox.ItemCheck -= checkedListBox_ItemCheck;
|
||||
checkedListBox.SetItemChecked(checkedListBox.CheckedIndices[0], value: false);
|
||||
checkedListBox.ItemCheck += checkedListBox_ItemCheck;
|
||||
}
|
||||
}
|
||||
|
||||
private void checkedListBox_SelectedIndexChanged(object sender, EventArgs e)
|
||||
{
|
||||
_changeEvent?.Invoke(sender, e);
|
||||
}
|
||||
}
|
||||
}
|
@ -0,0 +1,120 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<root>
|
||||
<!--
|
||||
Microsoft ResX Schema
|
||||
|
||||
Version 2.0
|
||||
|
||||
The primary goals of this format is to allow a simple XML format
|
||||
that is mostly human readable. The generation and parsing of the
|
||||
various data types are done through the TypeConverter classes
|
||||
associated with the data types.
|
||||
|
||||
Example:
|
||||
|
||||
... ado.net/XML headers & schema ...
|
||||
<resheader name="resmimetype">text/microsoft-resx</resheader>
|
||||
<resheader name="version">2.0</resheader>
|
||||
<resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader>
|
||||
<resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader>
|
||||
<data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data>
|
||||
<data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data>
|
||||
<data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64">
|
||||
<value>[base64 mime encoded serialized .NET Framework object]</value>
|
||||
</data>
|
||||
<data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
|
||||
<value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value>
|
||||
<comment>This is a comment</comment>
|
||||
</data>
|
||||
|
||||
There are any number of "resheader" rows that contain simple
|
||||
name/value pairs.
|
||||
|
||||
Each data row contains a name, and value. The row also contains a
|
||||
type or mimetype. Type corresponds to a .NET class that support
|
||||
text/value conversion through the TypeConverter architecture.
|
||||
Classes that don't support this are serialized and stored with the
|
||||
mimetype set.
|
||||
|
||||
The mimetype is used for serialized objects, and tells the
|
||||
ResXResourceReader how to depersist the object. This is currently not
|
||||
extensible. For a given mimetype the value must be set accordingly:
|
||||
|
||||
Note - application/x-microsoft.net.object.binary.base64 is the format
|
||||
that the ResXResourceWriter will generate, however the reader can
|
||||
read any of the formats listed below.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.binary.base64
|
||||
value : The object must be serialized with
|
||||
: System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
|
||||
: and then encoded with base64 encoding.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.soap.base64
|
||||
value : The object must be serialized with
|
||||
: System.Runtime.Serialization.Formatters.Soap.SoapFormatter
|
||||
: and then encoded with base64 encoding.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.bytearray.base64
|
||||
value : The object must be serialized into a byte array
|
||||
: using a System.ComponentModel.TypeConverter
|
||||
: and then encoded with base64 encoding.
|
||||
-->
|
||||
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
|
||||
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
|
||||
<xsd:element name="root" msdata:IsDataSet="true">
|
||||
<xsd:complexType>
|
||||
<xsd:choice maxOccurs="unbounded">
|
||||
<xsd:element name="metadata">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" use="required" type="xsd:string" />
|
||||
<xsd:attribute name="type" type="xsd:string" />
|
||||
<xsd:attribute name="mimetype" type="xsd:string" />
|
||||
<xsd:attribute ref="xml:space" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="assembly">
|
||||
<xsd:complexType>
|
||||
<xsd:attribute name="alias" type="xsd:string" />
|
||||
<xsd:attribute name="name" type="xsd:string" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="data">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
|
||||
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
|
||||
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
|
||||
<xsd:attribute ref="xml:space" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="resheader">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" type="xsd:string" use="required" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
</xsd:choice>
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
</xsd:schema>
|
||||
<resheader name="resmimetype">
|
||||
<value>text/microsoft-resx</value>
|
||||
</resheader>
|
||||
<resheader name="version">
|
||||
<value>2.0</value>
|
||||
</resheader>
|
||||
<resheader name="reader">
|
||||
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
<resheader name="writer">
|
||||
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
</root>
|
55
VolkovLabs/WinFormsLibraryVolkov/VisualComponents/CustomTreeCell.Designer.cs
generated
Normal file
55
VolkovLabs/WinFormsLibraryVolkov/VisualComponents/CustomTreeCell.Designer.cs
generated
Normal file
@ -0,0 +1,55 @@
|
||||
namespace WinFormsLibraryVolkov
|
||||
{
|
||||
partial class CustomTreeCell
|
||||
{
|
||||
/// <summary>
|
||||
/// Обязательная переменная конструктора.
|
||||
/// </summary>
|
||||
private System.ComponentModel.IContainer components = null;
|
||||
|
||||
/// <summary>
|
||||
/// Освободить все используемые ресурсы.
|
||||
/// </summary>
|
||||
/// <param name="disposing">истинно, если управляемый ресурс должен быть удален; иначе ложно.</param>
|
||||
protected override void Dispose(bool disposing)
|
||||
{
|
||||
if (disposing && (components != null))
|
||||
{
|
||||
components.Dispose();
|
||||
}
|
||||
base.Dispose(disposing);
|
||||
}
|
||||
|
||||
#region Код, автоматически созданный конструктором компонентов
|
||||
|
||||
/// <summary>
|
||||
/// Требуемый метод для поддержки конструктора — не изменяйте
|
||||
/// содержимое этого метода с помощью редактора кода.
|
||||
/// </summary>
|
||||
private void InitializeComponent()
|
||||
{
|
||||
treeView = new TreeView();
|
||||
SuspendLayout();
|
||||
//
|
||||
// treeView
|
||||
//
|
||||
treeView.Location = new Point(3, 3);
|
||||
treeView.Name = "treeView";
|
||||
treeView.Size = new Size(447, 189);
|
||||
treeView.TabIndex = 0;
|
||||
//
|
||||
// CustomTreeCell
|
||||
//
|
||||
AutoScaleDimensions = new SizeF(7F, 15F);
|
||||
AutoScaleMode = AutoScaleMode.Font;
|
||||
Controls.Add(treeView);
|
||||
Name = "CustomTreeCell";
|
||||
Size = new Size(453, 195);
|
||||
ResumeLayout(false);
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
private TreeView treeView;
|
||||
}
|
||||
}
|
@ -0,0 +1,102 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel;
|
||||
using System.Data;
|
||||
using System.Drawing;
|
||||
using System.Linq;
|
||||
using System.Reflection;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using System.Windows.Forms;
|
||||
using WinFormsLibraryVolkov.VisualComponents;
|
||||
|
||||
namespace WinFormsLibraryVolkov
|
||||
{
|
||||
public partial class CustomTreeCell : UserControl
|
||||
{
|
||||
public CustomTreeCell()
|
||||
{
|
||||
InitializeComponent();
|
||||
}
|
||||
|
||||
public void Clear()
|
||||
{
|
||||
treeView.Nodes.Clear();
|
||||
}
|
||||
|
||||
//Публичное свойство для установки и получения индекса выбранной ветки(set, get).
|
||||
protected DataTreeNodeConfig Levels { get; set; }
|
||||
|
||||
public void LoadConfig(DataTreeNodeConfig levels)
|
||||
{
|
||||
if (levels != null)
|
||||
{
|
||||
Levels = levels;
|
||||
}
|
||||
}
|
||||
|
||||
// Метод для добавления элемента в дерево
|
||||
public void AddCell<T>(int columnIndex, T element)
|
||||
{
|
||||
if (Levels == null) throw new ArgumentException("Levels равен null");
|
||||
if (element == null) throw new ArgumentException("element равен null");
|
||||
if (columnIndex < 0) throw new ArgumentException("индекс колонки < 0");
|
||||
if (columnIndex > Levels.NodeNames.Count) throw new ArgumentException("Индекс колонки > чем общее кол-во");
|
||||
|
||||
TreeNodeCollection treeNodeCollection = treeView.Nodes;
|
||||
int num = 0;
|
||||
foreach (string nodeName in Levels.NodeNames)
|
||||
{
|
||||
// Получение значения свойства или поля
|
||||
PropertyInfo property = element.GetType().GetProperty(nodeName);
|
||||
string text = property?.GetValue(element, null)?.ToString() ?? nodeName;
|
||||
|
||||
TreeNode treeNode = null;
|
||||
foreach (TreeNode item in treeNodeCollection)
|
||||
{
|
||||
if (item.Text == text)
|
||||
{
|
||||
treeNode = item;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Если узел не найден, добавляем новый
|
||||
treeNodeCollection = (treeNode == null) ? treeNodeCollection.Add(text).Nodes : treeNode.Nodes;
|
||||
|
||||
if (num >= columnIndex)
|
||||
{
|
||||
break;
|
||||
}
|
||||
|
||||
num++;
|
||||
}
|
||||
}
|
||||
|
||||
public T GetSelectedObject<T>() where T : class, new()
|
||||
{
|
||||
if (treeView.SelectedNode == null) throw new ArgumentException("treeView.SelectedNode == null");
|
||||
if (Levels == null) throw new ArgumentException("Levels равен null");
|
||||
if (treeView.SelectedNode.Nodes.Count > 0) throw new ArgumentException("treeView.SelectedNode.Nodes.Count > 0");
|
||||
|
||||
T val = new T();
|
||||
TreeNode treeNode = treeView.SelectedNode;
|
||||
int i = Levels.NodeNames.ToArray().Length - 1; // Получаем массив из очереди
|
||||
while (treeNode != null && i >= 0)
|
||||
{
|
||||
PropertyInfo property = val.GetType().GetProperty(Levels.NodeNames.ToArray()[i]); // Обращаемся к массиву
|
||||
if (property != null)
|
||||
{
|
||||
property.SetValue(val, Convert.ChangeType(treeNode.Text, property.PropertyType));
|
||||
}
|
||||
treeNode = treeNode.Parent;
|
||||
i--;
|
||||
}
|
||||
if (i >= 0)
|
||||
{
|
||||
return null; // Не все свойства объекта установлены
|
||||
}
|
||||
return val;
|
||||
}
|
||||
}
|
||||
}
|
@ -0,0 +1,120 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<root>
|
||||
<!--
|
||||
Microsoft ResX Schema
|
||||
|
||||
Version 2.0
|
||||
|
||||
The primary goals of this format is to allow a simple XML format
|
||||
that is mostly human readable. The generation and parsing of the
|
||||
various data types are done through the TypeConverter classes
|
||||
associated with the data types.
|
||||
|
||||
Example:
|
||||
|
||||
... ado.net/XML headers & schema ...
|
||||
<resheader name="resmimetype">text/microsoft-resx</resheader>
|
||||
<resheader name="version">2.0</resheader>
|
||||
<resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader>
|
||||
<resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader>
|
||||
<data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data>
|
||||
<data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data>
|
||||
<data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64">
|
||||
<value>[base64 mime encoded serialized .NET Framework object]</value>
|
||||
</data>
|
||||
<data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
|
||||
<value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value>
|
||||
<comment>This is a comment</comment>
|
||||
</data>
|
||||
|
||||
There are any number of "resheader" rows that contain simple
|
||||
name/value pairs.
|
||||
|
||||
Each data row contains a name, and value. The row also contains a
|
||||
type or mimetype. Type corresponds to a .NET class that support
|
||||
text/value conversion through the TypeConverter architecture.
|
||||
Classes that don't support this are serialized and stored with the
|
||||
mimetype set.
|
||||
|
||||
The mimetype is used for serialized objects, and tells the
|
||||
ResXResourceReader how to depersist the object. This is currently not
|
||||
extensible. For a given mimetype the value must be set accordingly:
|
||||
|
||||
Note - application/x-microsoft.net.object.binary.base64 is the format
|
||||
that the ResXResourceWriter will generate, however the reader can
|
||||
read any of the formats listed below.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.binary.base64
|
||||
value : The object must be serialized with
|
||||
: System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
|
||||
: and then encoded with base64 encoding.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.soap.base64
|
||||
value : The object must be serialized with
|
||||
: System.Runtime.Serialization.Formatters.Soap.SoapFormatter
|
||||
: and then encoded with base64 encoding.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.bytearray.base64
|
||||
value : The object must be serialized into a byte array
|
||||
: using a System.ComponentModel.TypeConverter
|
||||
: and then encoded with base64 encoding.
|
||||
-->
|
||||
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
|
||||
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
|
||||
<xsd:element name="root" msdata:IsDataSet="true">
|
||||
<xsd:complexType>
|
||||
<xsd:choice maxOccurs="unbounded">
|
||||
<xsd:element name="metadata">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" use="required" type="xsd:string" />
|
||||
<xsd:attribute name="type" type="xsd:string" />
|
||||
<xsd:attribute name="mimetype" type="xsd:string" />
|
||||
<xsd:attribute ref="xml:space" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="assembly">
|
||||
<xsd:complexType>
|
||||
<xsd:attribute name="alias" type="xsd:string" />
|
||||
<xsd:attribute name="name" type="xsd:string" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="data">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
|
||||
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
|
||||
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
|
||||
<xsd:attribute ref="xml:space" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="resheader">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" type="xsd:string" use="required" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
</xsd:choice>
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
</xsd:schema>
|
||||
<resheader name="resmimetype">
|
||||
<value>text/microsoft-resx</value>
|
||||
</resheader>
|
||||
<resheader name="version">
|
||||
<value>2.0</value>
|
||||
</resheader>
|
||||
<resheader name="reader">
|
||||
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
<resheader name="writer">
|
||||
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
</root>
|
@ -0,0 +1,13 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace WinFormsLibraryVolkov.VisualComponents
|
||||
{
|
||||
public class DataTreeNodeConfig
|
||||
{
|
||||
public Queue<string> NodeNames { get; set; }
|
||||
}
|
||||
}
|
@ -0,0 +1,31 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net6.0-windows</TargetFramework>
|
||||
<Nullable>enable</Nullable>
|
||||
<UseWindowsForms>true</UseWindowsForms>
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<COMReference Include="Microsoft.Office.Interop.Excel">
|
||||
<WrapperTool>tlbimp</WrapperTool>
|
||||
<VersionMinor>9</VersionMinor>
|
||||
<VersionMajor>1</VersionMajor>
|
||||
<Guid>00020813-0000-0000-c000-000000000046</Guid>
|
||||
<Lcid>0</Lcid>
|
||||
<Isolated>false</Isolated>
|
||||
<EmbedInteropTypes>true</EmbedInteropTypes>
|
||||
</COMReference>
|
||||
<COMReference Include="Microsoft.Office.Core">
|
||||
<WrapperTool>tlbimp</WrapperTool>
|
||||
<VersionMinor>8</VersionMinor>
|
||||
<VersionMajor>2</VersionMajor>
|
||||
<Guid>2df8d04c-5bfa-101b-bde5-00aa0044de52</Guid>
|
||||
<Lcid>0</Lcid>
|
||||
<Isolated>false</Isolated>
|
||||
<EmbedInteropTypes>true</EmbedInteropTypes>
|
||||
</COMReference>
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
20
VolkovLabs/WinFormsTestApp/Department.cs
Normal file
20
VolkovLabs/WinFormsTestApp/Department.cs
Normal file
@ -0,0 +1,20 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace WinFormsTestApp
|
||||
{
|
||||
public class Department
|
||||
{
|
||||
public string name;
|
||||
public int sells;
|
||||
|
||||
public Department(string name, int sells)
|
||||
{
|
||||
this.name = name;
|
||||
this.sells = sells;
|
||||
}
|
||||
}
|
||||
}
|
401
VolkovLabs/WinFormsTestApp/FormMain.Designer.cs
generated
Normal file
401
VolkovLabs/WinFormsTestApp/FormMain.Designer.cs
generated
Normal file
@ -0,0 +1,401 @@
|
||||
using WinFormsLibraryVolkov;
|
||||
|
||||
namespace WinFormsTestApp
|
||||
{
|
||||
partial class FormMain
|
||||
{
|
||||
/// <summary>
|
||||
/// Required designer variable.
|
||||
/// </summary>
|
||||
private System.ComponentModel.IContainer components = null;
|
||||
|
||||
/// <summary>
|
||||
/// Clean up any resources being used.
|
||||
/// </summary>
|
||||
/// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
|
||||
protected override void Dispose(bool disposing)
|
||||
{
|
||||
if (disposing && (components != null))
|
||||
{
|
||||
components.Dispose();
|
||||
}
|
||||
base.Dispose(disposing);
|
||||
}
|
||||
|
||||
#region Windows Form Designer generated code
|
||||
|
||||
/// <summary>
|
||||
/// Required method for Designer support - do not modify
|
||||
/// the contents of this method with the code editor.
|
||||
/// </summary>
|
||||
private void InitializeComponent()
|
||||
{
|
||||
components = new System.ComponentModel.Container();
|
||||
buttonCheck = new Button();
|
||||
labelCheckValue = new Label();
|
||||
groupBoxInput = new GroupBox();
|
||||
customInputRangeDate = new CustomInputRangeDate();
|
||||
groupBoxSelected = new GroupBox();
|
||||
customSelectedCheckedListBox = new CustomSelectedCheckedListBox();
|
||||
buttonGetSelected = new Button();
|
||||
labelSelectedValue = new Label();
|
||||
buttonClear = new Button();
|
||||
buttonAdd = new Button();
|
||||
textBoxAdd = new TextBox();
|
||||
groupBoxData = new GroupBox();
|
||||
customTreeCell = new CustomTreeCell();
|
||||
labelTransportType = new Label();
|
||||
labelModel = new Label();
|
||||
labelRegNum = new Label();
|
||||
buttonGetFromTree = new Button();
|
||||
buttonAddToTree = new Button();
|
||||
comboBoxTransportType = new ComboBox();
|
||||
textBoxModel = new TextBox();
|
||||
textBoxRegNumber = new TextBox();
|
||||
tabControl = new TabControl();
|
||||
Visual = new TabPage();
|
||||
NonVisual = new TabPage();
|
||||
buttonExcelDiagram = new Button();
|
||||
buttonExcelImages = new Button();
|
||||
buttonExcelTables = new Button();
|
||||
excelTableComponent = new WinFormsLibraryVolkov.NonVisualComponents.ExcelTableComponent(components);
|
||||
excelImagesComponent = new WinFormsLibraryVolkov.NonVisualComponents.ExcelImagesComponent(components);
|
||||
excelDiagramComponent = new WinFormsLibraryVolkov.NonVisualComponents.ExcelDiagramComponent(components);
|
||||
openFileDialog = new OpenFileDialog();
|
||||
groupBoxInput.SuspendLayout();
|
||||
groupBoxSelected.SuspendLayout();
|
||||
groupBoxData.SuspendLayout();
|
||||
tabControl.SuspendLayout();
|
||||
Visual.SuspendLayout();
|
||||
NonVisual.SuspendLayout();
|
||||
SuspendLayout();
|
||||
//
|
||||
// buttonCheck
|
||||
//
|
||||
buttonCheck.Location = new Point(169, 22);
|
||||
buttonCheck.Name = "buttonCheck";
|
||||
buttonCheck.Size = new Size(126, 23);
|
||||
buttonCheck.TabIndex = 1;
|
||||
buttonCheck.Text = "Check";
|
||||
buttonCheck.UseVisualStyleBackColor = true;
|
||||
buttonCheck.Click += buttonCheck_Click;
|
||||
//
|
||||
// labelCheckValue
|
||||
//
|
||||
labelCheckValue.AutoSize = true;
|
||||
labelCheckValue.Location = new Point(30, 111);
|
||||
labelCheckValue.Name = "labelCheckValue";
|
||||
labelCheckValue.Size = new Size(65, 15);
|
||||
labelCheckValue.TabIndex = 2;
|
||||
labelCheckValue.Text = "Enter value";
|
||||
//
|
||||
// groupBoxInput
|
||||
//
|
||||
groupBoxInput.Controls.Add(labelCheckValue);
|
||||
groupBoxInput.Controls.Add(buttonCheck);
|
||||
groupBoxInput.Controls.Add(customInputRangeDate);
|
||||
groupBoxInput.Location = new Point(6, 6);
|
||||
groupBoxInput.Name = "groupBoxInput";
|
||||
groupBoxInput.Size = new Size(311, 190);
|
||||
groupBoxInput.TabIndex = 9;
|
||||
groupBoxInput.TabStop = false;
|
||||
groupBoxInput.Text = "Input";
|
||||
//
|
||||
// customInputRangeDate
|
||||
//
|
||||
customInputRangeDate.Location = new Point(15, 22);
|
||||
customInputRangeDate.MaxDate = new DateTime(0L);
|
||||
customInputRangeDate.MinDate = new DateTime(0L);
|
||||
customInputRangeDate.Name = "customInputRangeDate";
|
||||
customInputRangeDate.Size = new Size(148, 231);
|
||||
customInputRangeDate.TabIndex = 3;
|
||||
//
|
||||
// groupBoxSelected
|
||||
//
|
||||
groupBoxSelected.Controls.Add(customSelectedCheckedListBox);
|
||||
groupBoxSelected.Controls.Add(buttonGetSelected);
|
||||
groupBoxSelected.Controls.Add(labelSelectedValue);
|
||||
groupBoxSelected.Controls.Add(buttonClear);
|
||||
groupBoxSelected.Controls.Add(buttonAdd);
|
||||
groupBoxSelected.Controls.Add(textBoxAdd);
|
||||
groupBoxSelected.Location = new Point(324, 6);
|
||||
groupBoxSelected.Name = "groupBoxSelected";
|
||||
groupBoxSelected.Size = new Size(311, 190);
|
||||
groupBoxSelected.TabIndex = 10;
|
||||
groupBoxSelected.TabStop = false;
|
||||
groupBoxSelected.Text = "Selected";
|
||||
//
|
||||
// customSelectedCheckedListBox
|
||||
//
|
||||
customSelectedCheckedListBox.Location = new Point(6, 22);
|
||||
customSelectedCheckedListBox.Name = "customSelectedCheckedListBox";
|
||||
customSelectedCheckedListBox.SelectedElement = "";
|
||||
customSelectedCheckedListBox.Size = new Size(150, 150);
|
||||
customSelectedCheckedListBox.TabIndex = 15;
|
||||
//
|
||||
// buttonGetSelected
|
||||
//
|
||||
buttonGetSelected.Location = new Point(174, 139);
|
||||
buttonGetSelected.Name = "buttonGetSelected";
|
||||
buttonGetSelected.Size = new Size(100, 23);
|
||||
buttonGetSelected.TabIndex = 14;
|
||||
buttonGetSelected.Text = "Get Selected";
|
||||
buttonGetSelected.UseVisualStyleBackColor = true;
|
||||
buttonGetSelected.Click += buttonGetSelected_Click;
|
||||
//
|
||||
// labelSelectedValue
|
||||
//
|
||||
labelSelectedValue.AutoSize = true;
|
||||
labelSelectedValue.Location = new Point(178, 111);
|
||||
labelSelectedValue.Name = "labelSelectedValue";
|
||||
labelSelectedValue.Size = new Size(82, 15);
|
||||
labelSelectedValue.TabIndex = 11;
|
||||
labelSelectedValue.Text = "Selected value";
|
||||
//
|
||||
// buttonClear
|
||||
//
|
||||
buttonClear.Location = new Point(174, 81);
|
||||
buttonClear.Name = "buttonClear";
|
||||
buttonClear.Size = new Size(100, 23);
|
||||
buttonClear.TabIndex = 13;
|
||||
buttonClear.Text = "Clear";
|
||||
buttonClear.UseVisualStyleBackColor = true;
|
||||
buttonClear.Click += buttonClear_Click;
|
||||
//
|
||||
// buttonAdd
|
||||
//
|
||||
buttonAdd.Location = new Point(174, 52);
|
||||
buttonAdd.Name = "buttonAdd";
|
||||
buttonAdd.Size = new Size(100, 23);
|
||||
buttonAdd.TabIndex = 12;
|
||||
buttonAdd.Text = "Add or Select";
|
||||
buttonAdd.UseVisualStyleBackColor = true;
|
||||
buttonAdd.Click += buttonAdd_Click;
|
||||
//
|
||||
// textBoxAdd
|
||||
//
|
||||
textBoxAdd.Location = new Point(162, 23);
|
||||
textBoxAdd.Name = "textBoxAdd";
|
||||
textBoxAdd.Size = new Size(140, 23);
|
||||
textBoxAdd.TabIndex = 11;
|
||||
//
|
||||
// groupBoxData
|
||||
//
|
||||
groupBoxData.Controls.Add(customTreeCell);
|
||||
groupBoxData.Controls.Add(labelTransportType);
|
||||
groupBoxData.Controls.Add(labelModel);
|
||||
groupBoxData.Controls.Add(labelRegNum);
|
||||
groupBoxData.Controls.Add(buttonGetFromTree);
|
||||
groupBoxData.Controls.Add(buttonAddToTree);
|
||||
groupBoxData.Controls.Add(comboBoxTransportType);
|
||||
groupBoxData.Controls.Add(textBoxModel);
|
||||
groupBoxData.Controls.Add(textBoxRegNumber);
|
||||
groupBoxData.Location = new Point(6, 202);
|
||||
groupBoxData.Name = "groupBoxData";
|
||||
groupBoxData.Size = new Size(629, 230);
|
||||
groupBoxData.TabIndex = 11;
|
||||
groupBoxData.TabStop = false;
|
||||
groupBoxData.Text = "Data";
|
||||
//
|
||||
// customTreeCell
|
||||
//
|
||||
customTreeCell.Location = new Point(0, 23);
|
||||
customTreeCell.Name = "customTreeCell";
|
||||
customTreeCell.Size = new Size(413, 195);
|
||||
customTreeCell.TabIndex = 9;
|
||||
//
|
||||
// labelTransportType
|
||||
//
|
||||
labelTransportType.AutoSize = true;
|
||||
labelTransportType.Location = new Point(432, 116);
|
||||
labelTransportType.Name = "labelTransportType";
|
||||
labelTransportType.Size = new Size(93, 15);
|
||||
labelTransportType.TabIndex = 8;
|
||||
labelTransportType.Text = "Тип транспорта";
|
||||
//
|
||||
// labelModel
|
||||
//
|
||||
labelModel.AutoSize = true;
|
||||
labelModel.Location = new Point(432, 72);
|
||||
labelModel.Name = "labelModel";
|
||||
labelModel.Size = new Size(50, 15);
|
||||
labelModel.TabIndex = 7;
|
||||
labelModel.Text = "Модель";
|
||||
//
|
||||
// labelRegNum
|
||||
//
|
||||
labelRegNum.AutoSize = true;
|
||||
labelRegNum.Location = new Point(432, 28);
|
||||
labelRegNum.Name = "labelRegNum";
|
||||
labelRegNum.Size = new Size(146, 15);
|
||||
labelRegNum.TabIndex = 6;
|
||||
labelRegNum.Text = "Регистрационный номер";
|
||||
//
|
||||
// buttonGetFromTree
|
||||
//
|
||||
buttonGetFromTree.Location = new Point(432, 195);
|
||||
buttonGetFromTree.Name = "buttonGetFromTree";
|
||||
buttonGetFromTree.Size = new Size(188, 23);
|
||||
buttonGetFromTree.TabIndex = 5;
|
||||
buttonGetFromTree.Text = "Get Selected";
|
||||
buttonGetFromTree.UseVisualStyleBackColor = true;
|
||||
buttonGetFromTree.Click += buttonGetFromTree_Click;
|
||||
//
|
||||
// buttonAddToTree
|
||||
//
|
||||
buttonAddToTree.Location = new Point(432, 166);
|
||||
buttonAddToTree.Name = "buttonAddToTree";
|
||||
buttonAddToTree.Size = new Size(188, 23);
|
||||
buttonAddToTree.TabIndex = 4;
|
||||
buttonAddToTree.Text = "Add";
|
||||
buttonAddToTree.UseVisualStyleBackColor = true;
|
||||
buttonAddToTree.Click += buttonAddToTree_Click;
|
||||
//
|
||||
// comboBoxTransportType
|
||||
//
|
||||
comboBoxTransportType.FormattingEnabled = true;
|
||||
comboBoxTransportType.Location = new Point(432, 134);
|
||||
comboBoxTransportType.Name = "comboBoxTransportType";
|
||||
comboBoxTransportType.Size = new Size(188, 23);
|
||||
comboBoxTransportType.TabIndex = 3;
|
||||
//
|
||||
// textBoxModel
|
||||
//
|
||||
textBoxModel.Location = new Point(432, 90);
|
||||
textBoxModel.Name = "textBoxModel";
|
||||
textBoxModel.Size = new Size(188, 23);
|
||||
textBoxModel.TabIndex = 2;
|
||||
//
|
||||
// textBoxRegNumber
|
||||
//
|
||||
textBoxRegNumber.Location = new Point(432, 46);
|
||||
textBoxRegNumber.Name = "textBoxRegNumber";
|
||||
textBoxRegNumber.Size = new Size(188, 23);
|
||||
textBoxRegNumber.TabIndex = 1;
|
||||
//
|
||||
// tabControl
|
||||
//
|
||||
tabControl.Controls.Add(Visual);
|
||||
tabControl.Controls.Add(NonVisual);
|
||||
tabControl.Location = new Point(12, 12);
|
||||
tabControl.Name = "tabControl";
|
||||
tabControl.SelectedIndex = 0;
|
||||
tabControl.Size = new Size(653, 466);
|
||||
tabControl.TabIndex = 12;
|
||||
//
|
||||
// Visual
|
||||
//
|
||||
Visual.Controls.Add(groupBoxData);
|
||||
Visual.Controls.Add(groupBoxInput);
|
||||
Visual.Controls.Add(groupBoxSelected);
|
||||
Visual.Location = new Point(4, 24);
|
||||
Visual.Name = "Visual";
|
||||
Visual.Padding = new Padding(3);
|
||||
Visual.Size = new Size(645, 438);
|
||||
Visual.TabIndex = 0;
|
||||
Visual.Text = "Visual";
|
||||
Visual.UseVisualStyleBackColor = true;
|
||||
//
|
||||
// NonVisual
|
||||
//
|
||||
NonVisual.Controls.Add(buttonExcelDiagram);
|
||||
NonVisual.Controls.Add(buttonExcelImages);
|
||||
NonVisual.Controls.Add(buttonExcelTables);
|
||||
NonVisual.Location = new Point(4, 24);
|
||||
NonVisual.Name = "NonVisual";
|
||||
NonVisual.Size = new Size(645, 438);
|
||||
NonVisual.TabIndex = 1;
|
||||
NonVisual.Text = "NonVisual";
|
||||
NonVisual.UseVisualStyleBackColor = true;
|
||||
//
|
||||
// buttonExcelDiagram
|
||||
//
|
||||
buttonExcelDiagram.Location = new Point(446, 126);
|
||||
buttonExcelDiagram.Name = "buttonExcelDiagram";
|
||||
buttonExcelDiagram.Size = new Size(177, 148);
|
||||
buttonExcelDiagram.TabIndex = 2;
|
||||
buttonExcelDiagram.Text = "Excel (диаграмма)";
|
||||
buttonExcelDiagram.UseVisualStyleBackColor = true;
|
||||
buttonExcelDiagram.Click += buttonExcelDiagram_Click;
|
||||
//
|
||||
// buttonExcelImages
|
||||
//
|
||||
buttonExcelImages.Location = new Point(38, 126);
|
||||
buttonExcelImages.Name = "buttonExcelImages";
|
||||
buttonExcelImages.Size = new Size(177, 148);
|
||||
buttonExcelImages.TabIndex = 1;
|
||||
buttonExcelImages.Text = "Excel (картинки)";
|
||||
buttonExcelImages.UseVisualStyleBackColor = true;
|
||||
buttonExcelImages.Click += buttonExcelImages_Click;
|
||||
//
|
||||
// buttonExcelTables
|
||||
//
|
||||
buttonExcelTables.Location = new Point(242, 126);
|
||||
buttonExcelTables.Name = "buttonExcelTables";
|
||||
buttonExcelTables.Size = new Size(177, 148);
|
||||
buttonExcelTables.TabIndex = 0;
|
||||
buttonExcelTables.Text = "Excel (таблица)";
|
||||
buttonExcelTables.UseVisualStyleBackColor = true;
|
||||
buttonExcelTables.Click += buttonExcelTables_Click;
|
||||
//
|
||||
// openFileDialog
|
||||
//
|
||||
openFileDialog.FileName = "openFileDialog1";
|
||||
openFileDialog.Filter = "Image Files|*.jpg;*.jpeg;*png";
|
||||
openFileDialog.Multiselect = true;
|
||||
//
|
||||
// FormMain
|
||||
//
|
||||
AutoScaleDimensions = new SizeF(7F, 15F);
|
||||
AutoScaleMode = AutoScaleMode.Font;
|
||||
ClientSize = new Size(675, 486);
|
||||
Controls.Add(tabControl);
|
||||
Name = "FormMain";
|
||||
Text = "FormMain";
|
||||
groupBoxInput.ResumeLayout(false);
|
||||
groupBoxInput.PerformLayout();
|
||||
groupBoxSelected.ResumeLayout(false);
|
||||
groupBoxSelected.PerformLayout();
|
||||
groupBoxData.ResumeLayout(false);
|
||||
groupBoxData.PerformLayout();
|
||||
tabControl.ResumeLayout(false);
|
||||
Visual.ResumeLayout(false);
|
||||
NonVisual.ResumeLayout(false);
|
||||
ResumeLayout(false);
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
private Button buttonCheck;
|
||||
private Label labelCheckValue;
|
||||
private GroupBox groupBoxInput;
|
||||
private GroupBox groupBoxSelected;
|
||||
private Button buttonGetSelected;
|
||||
private Label labelSelectedValue;
|
||||
private Button buttonClear;
|
||||
private Button buttonAdd;
|
||||
private TextBox textBoxAdd;
|
||||
private GroupBox groupBoxData;
|
||||
private Button buttonGetFromTree;
|
||||
private Button buttonAddToTree;
|
||||
private ComboBox comboBoxTransportType;
|
||||
private TextBox textBoxModel;
|
||||
private TextBox textBoxRegNumber;
|
||||
private Label labelTransportType;
|
||||
private Label labelModel;
|
||||
private Label labelRegNum;
|
||||
private TabControl tabControl;
|
||||
private TabPage Visual;
|
||||
private TabPage NonVisual;
|
||||
private Button buttonExcelDiagram;
|
||||
private Button buttonExcelImages;
|
||||
private Button buttonExcelTables;
|
||||
private WinFormsLibraryVolkov.NonVisualComponents.ExcelTableComponent excelTableComponent;
|
||||
private WinFormsLibraryVolkov.NonVisualComponents.ExcelImagesComponent excelImagesComponent;
|
||||
private WinFormsLibraryVolkov.NonVisualComponents.ExcelDiagramComponent excelDiagramComponent;
|
||||
private OpenFileDialog openFileDialog;
|
||||
private CustomInputRangeDate customInputRangeDate;
|
||||
private CustomSelectedCheckedListBox customSelectedCheckedListBox;
|
||||
private CustomTreeCell customTreeCell;
|
||||
}
|
||||
}
|
167
VolkovLabs/WinFormsTestApp/FormMain.cs
Normal file
167
VolkovLabs/WinFormsTestApp/FormMain.cs
Normal file
@ -0,0 +1,167 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel;
|
||||
using System.Data;
|
||||
using System.Drawing;
|
||||
using System.Linq;
|
||||
using System.Reflection;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using System.Windows.Forms;
|
||||
using WinFormsLibraryVolkov.VisualComponents;
|
||||
using WinFormsLibraryVolkov.NonVisualComponents;
|
||||
using WinFormsLibraryVolkov.Exceptions;
|
||||
|
||||
namespace WinFormsTestApp
|
||||
{
|
||||
public partial class FormMain : Form
|
||||
{
|
||||
readonly List<Transport> transports = new()
|
||||
{
|
||||
new Transport { Id = 1, Fuel="Авиакеросин", Mileage=239000, Owner="Аэрофлот", Price=70000000, State="Эксплуатируется", RegNumber = "EW-009EC", TransportType = "Воздушный транспорт", Model = "Ан-30" },
|
||||
new Transport { Id = 2, Fuel="Авиакеросин", Mileage=452005, Owner="Азимут", Price=95000000, State="Не эксплуатируется", RegNumber = "EW-987ZY", TransportType = "Воздушный транспорт", Model = "Ан-28" },
|
||||
new Transport { Id = 3, Fuel="Мазут", Mileage=790222, Owner="ВМФ США", Price=100000000, State="Эксплуатируется", RegNumber = "SSH-988", TransportType = "Морской транспорт", Model = "авианосец 'Нимиц'" },
|
||||
new Transport { Id = 4, Fuel="92", Mileage=105777, Owner="Ползунова Татьяна Михайловна",State="Не эксплуатируется", Price=400000, RegNumber = "B901AУ74", TransportType = "Наземный транспорт", Model = "Renault Logan" },
|
||||
new Transport { Id = 5, Fuel="Газ", Mileage=66782, Owner="Аветесян Сергей Георгиевич", State="Эксплуатируется", Price=160000, RegNumber = "Р187КН73", TransportType = "Наземный транспорт", Model = "Daewoo Matiz" },
|
||||
};
|
||||
public FormMain()
|
||||
{
|
||||
InitializeComponent();
|
||||
var list = new List<string>() { "Значение 1", "Значение 2", "Значение 3", "Значение 4", "Значение 5" };
|
||||
customSelectedCheckedListBox.PopulateList(list);
|
||||
|
||||
comboBoxTransportType.Items.Add("Наземный транспорт");
|
||||
comboBoxTransportType.Items.Add("Воздушный транспорт");
|
||||
comboBoxTransportType.Items.Add("Морской транспорт");
|
||||
|
||||
var nodeNames = new Queue<string>();
|
||||
nodeNames.Enqueue("TransportType");
|
||||
nodeNames.Enqueue("Model");
|
||||
nodeNames.Enqueue("RegNumber");
|
||||
var treeConfig = new DataTreeNodeConfig { NodeNames = nodeNames };
|
||||
|
||||
customTreeCell.LoadConfig(treeConfig);
|
||||
|
||||
int counter = 0;
|
||||
foreach (var transport in transports)
|
||||
{
|
||||
|
||||
customTreeCell.AddCell(0, transport);
|
||||
customTreeCell.AddCell(1, transport);
|
||||
customTreeCell.AddCell(2, transport);
|
||||
customTreeCell.AddCell(3, transport);
|
||||
|
||||
counter++;
|
||||
}
|
||||
}
|
||||
|
||||
private void buttonCheck_Click(object sender, EventArgs e)
|
||||
{
|
||||
labelCheckValue.Text = customInputRangeDate.Date.ToString();
|
||||
if (labelCheckValue.Text == "")
|
||||
{
|
||||
labelCheckValue.Text = customInputRangeDate.Error;
|
||||
}
|
||||
}
|
||||
|
||||
private void buttonAdd_Click(object sender, EventArgs e)
|
||||
{
|
||||
string newItem = textBoxAdd.Text.Trim();
|
||||
|
||||
if (!string.IsNullOrEmpty(newItem))
|
||||
{
|
||||
var itemsToAdd = new List<string> { newItem };
|
||||
|
||||
// Добавляем новый элемент в список
|
||||
customSelectedCheckedListBox.PopulateList(itemsToAdd);
|
||||
}
|
||||
else
|
||||
{
|
||||
MessageBox.Show("Введите элемент для добавления.", "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Warning);
|
||||
}
|
||||
}
|
||||
|
||||
private void buttonClear_Click(object sender, EventArgs e)
|
||||
{
|
||||
customSelectedCheckedListBox.ClearList();
|
||||
}
|
||||
|
||||
private void buttonGetSelected_Click(object sender, EventArgs e)
|
||||
{
|
||||
labelSelectedValue.Text = customSelectedCheckedListBox.SelectedElement;
|
||||
if (labelSelectedValue.Text == "")
|
||||
{
|
||||
labelSelectedValue.Text = "Значение \nне выбрано";
|
||||
}
|
||||
}
|
||||
|
||||
private void buttonAddToTree_Click(object sender, EventArgs e)
|
||||
{
|
||||
if (textBoxRegNumber.Text == null || textBoxModel.Text == null || comboBoxTransportType.SelectedItem == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
customTreeCell.AddCell<Transport>(2, new(textBoxRegNumber.Text, comboBoxTransportType.SelectedItem.ToString(), textBoxModel.Text));
|
||||
customTreeCell.Update();
|
||||
}
|
||||
|
||||
private void buttonGetFromTree_Click(object sender, EventArgs e)
|
||||
{
|
||||
Transport tp = customTreeCell.GetSelectedObject<Transport>();
|
||||
if (tp == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
textBoxRegNumber.Text = tp.RegNumber;
|
||||
textBoxModel.Text = tp.Model;
|
||||
comboBoxTransportType.SelectedItem = tp.TransportType;
|
||||
}
|
||||
|
||||
private void buttonExcelDiagram_Click(object sender, EventArgs e)
|
||||
{
|
||||
List<Department> departments = new List<Department>();
|
||||
|
||||
departments.Add(new Department("Dep 1", 330));
|
||||
departments.Add(new Department("Dep 2", 500));
|
||||
departments.Add(new Department("Dep 3", 170));
|
||||
string path = AppDomain.CurrentDomain.BaseDirectory + "DiagramTesting.xlsx";
|
||||
if (excelDiagramComponent.createWithDiagram(path, "DiagramTest", "Продажи", DiagramLegendEnum.TopRight, departments, "name", "sells")) MessageBox.Show("Успех");
|
||||
else MessageBox.Show("Fail :(");
|
||||
}
|
||||
|
||||
private void buttonExcelTables_Click(object sender, EventArgs e)
|
||||
{
|
||||
List<OfficeWorker> workers = new List<OfficeWorker>();
|
||||
|
||||
workers.Add(new OfficeWorker(1, "Иванов", "Иван", 20, "Отдел продаж", "Бухгалтер", 25, "+7(834)234-03-49"));
|
||||
workers.Add(new OfficeWorker(1, "Петров", "Петр", 25, "Отдел продаж", "Менеджер", 20, "+7(834)123-03-49"));
|
||||
workers.Add(new OfficeWorker(1, "Сидоров", "Сергей", 27, "Отдел кадров", "HR", 2, "+7(834)593-03-49", true));
|
||||
string path = AppDomain.CurrentDomain.BaseDirectory + "ExcelTableTesting.xlsx";
|
||||
List<(int, int)> merges = new List<(int, int)>();
|
||||
merges.Add((1, 3));
|
||||
merges.Add((4, 6));
|
||||
List<int> heights = Enumerable.Repeat(20, 9).ToList();
|
||||
|
||||
List<(string, string)> headers = new List<(string, string)> { ("id", "id"), ("", "Личные данные"),
|
||||
("lastName", "Фамилия"), ("firstName", "Имя"),
|
||||
("age", "Возраст"), ("", "Работа"),
|
||||
("department", "Отдел"), ("position", "Должность"),
|
||||
("boxNumber", "Номер бокса"), ("phoneNumber", "Телефон"),
|
||||
("isInVacation", "В отпуске"), };
|
||||
|
||||
if (excelTableComponent.createWithTable(path, "ExcelTable", merges, heights, headers, workers)) MessageBox.Show("Успех");
|
||||
}
|
||||
|
||||
private void buttonExcelImages_Click(object sender, EventArgs e)
|
||||
{
|
||||
var res = openFileDialog.ShowDialog(this);
|
||||
if (res != DialogResult.OK) return;
|
||||
var files = openFileDialog.FileNames;
|
||||
openFileDialog.Dispose();
|
||||
List<Bitmap> images = new List<Bitmap>();
|
||||
string path = AppDomain.CurrentDomain.BaseDirectory + "ImageTesting.xlsx";
|
||||
if (excelImagesComponent.createWithImages(new ExcelImageInfo(path, "Header", files))) MessageBox.Show("Успех!");
|
||||
else MessageBox.Show("Ошибка, проверьте консоль");
|
||||
}
|
||||
}
|
||||
}
|
132
VolkovLabs/WinFormsTestApp/FormMain.resx
Normal file
132
VolkovLabs/WinFormsTestApp/FormMain.resx
Normal file
@ -0,0 +1,132 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<root>
|
||||
<!--
|
||||
Microsoft ResX Schema
|
||||
|
||||
Version 2.0
|
||||
|
||||
The primary goals of this format is to allow a simple XML format
|
||||
that is mostly human readable. The generation and parsing of the
|
||||
various data types are done through the TypeConverter classes
|
||||
associated with the data types.
|
||||
|
||||
Example:
|
||||
|
||||
... ado.net/XML headers & schema ...
|
||||
<resheader name="resmimetype">text/microsoft-resx</resheader>
|
||||
<resheader name="version">2.0</resheader>
|
||||
<resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader>
|
||||
<resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader>
|
||||
<data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data>
|
||||
<data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data>
|
||||
<data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64">
|
||||
<value>[base64 mime encoded serialized .NET Framework object]</value>
|
||||
</data>
|
||||
<data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
|
||||
<value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value>
|
||||
<comment>This is a comment</comment>
|
||||
</data>
|
||||
|
||||
There are any number of "resheader" rows that contain simple
|
||||
name/value pairs.
|
||||
|
||||
Each data row contains a name, and value. The row also contains a
|
||||
type or mimetype. Type corresponds to a .NET class that support
|
||||
text/value conversion through the TypeConverter architecture.
|
||||
Classes that don't support this are serialized and stored with the
|
||||
mimetype set.
|
||||
|
||||
The mimetype is used for serialized objects, and tells the
|
||||
ResXResourceReader how to depersist the object. This is currently not
|
||||
extensible. For a given mimetype the value must be set accordingly:
|
||||
|
||||
Note - application/x-microsoft.net.object.binary.base64 is the format
|
||||
that the ResXResourceWriter will generate, however the reader can
|
||||
read any of the formats listed below.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.binary.base64
|
||||
value : The object must be serialized with
|
||||
: System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
|
||||
: and then encoded with base64 encoding.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.soap.base64
|
||||
value : The object must be serialized with
|
||||
: System.Runtime.Serialization.Formatters.Soap.SoapFormatter
|
||||
: and then encoded with base64 encoding.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.bytearray.base64
|
||||
value : The object must be serialized into a byte array
|
||||
: using a System.ComponentModel.TypeConverter
|
||||
: and then encoded with base64 encoding.
|
||||
-->
|
||||
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
|
||||
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
|
||||
<xsd:element name="root" msdata:IsDataSet="true">
|
||||
<xsd:complexType>
|
||||
<xsd:choice maxOccurs="unbounded">
|
||||
<xsd:element name="metadata">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" use="required" type="xsd:string" />
|
||||
<xsd:attribute name="type" type="xsd:string" />
|
||||
<xsd:attribute name="mimetype" type="xsd:string" />
|
||||
<xsd:attribute ref="xml:space" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="assembly">
|
||||
<xsd:complexType>
|
||||
<xsd:attribute name="alias" type="xsd:string" />
|
||||
<xsd:attribute name="name" type="xsd:string" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="data">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
|
||||
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
|
||||
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
|
||||
<xsd:attribute ref="xml:space" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="resheader">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" type="xsd:string" use="required" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
</xsd:choice>
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
</xsd:schema>
|
||||
<resheader name="resmimetype">
|
||||
<value>text/microsoft-resx</value>
|
||||
</resheader>
|
||||
<resheader name="version">
|
||||
<value>2.0</value>
|
||||
</resheader>
|
||||
<resheader name="reader">
|
||||
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
<resheader name="writer">
|
||||
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
<metadata name="excelTableComponent.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
|
||||
<value>17, 17</value>
|
||||
</metadata>
|
||||
<metadata name="excelImagesComponent.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
|
||||
<value>195, 17</value>
|
||||
</metadata>
|
||||
<metadata name="excelDiagramComponent.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
|
||||
<value>384, 17</value>
|
||||
</metadata>
|
||||
<metadata name="openFileDialog.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
|
||||
<value>574, 17</value>
|
||||
</metadata>
|
||||
</root>
|
34
VolkovLabs/WinFormsTestApp/OfficeWorker.cs
Normal file
34
VolkovLabs/WinFormsTestApp/OfficeWorker.cs
Normal file
@ -0,0 +1,34 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace WinFormsTestApp
|
||||
{
|
||||
public class OfficeWorker
|
||||
{
|
||||
public OfficeWorker(int id, string lastName, string firstName, int age, string department, string position, int boxNumber, string phoneNumber, bool isInVacation = false)
|
||||
{
|
||||
this.id = id;
|
||||
this.lastName = lastName;
|
||||
this.firstName = firstName;
|
||||
this.age = age;
|
||||
this.department = department;
|
||||
this.position = position;
|
||||
this.boxNumber = boxNumber;
|
||||
this.phoneNumber = phoneNumber;
|
||||
this.isInVacation = isInVacation;
|
||||
}
|
||||
|
||||
public int id;
|
||||
public string lastName;
|
||||
public string firstName;
|
||||
public int age;
|
||||
public string department;
|
||||
public string position;
|
||||
public int boxNumber;
|
||||
public string phoneNumber;
|
||||
public bool isInVacation;
|
||||
}
|
||||
}
|
17
VolkovLabs/WinFormsTestApp/Program.cs
Normal file
17
VolkovLabs/WinFormsTestApp/Program.cs
Normal file
@ -0,0 +1,17 @@
|
||||
namespace WinFormsTestApp
|
||||
{
|
||||
internal static class Program
|
||||
{
|
||||
/// <summary>
|
||||
/// The main entry point for the application.
|
||||
/// </summary>
|
||||
[STAThread]
|
||||
static void Main()
|
||||
{
|
||||
// To customize application configuration such as set high DPI settings or default font,
|
||||
// see https://aka.ms/applicationconfiguration.
|
||||
ApplicationConfiguration.Initialize();
|
||||
Application.Run(new FormMain());
|
||||
}
|
||||
}
|
||||
}
|
37
VolkovLabs/WinFormsTestApp/Transport.cs
Normal file
37
VolkovLabs/WinFormsTestApp/Transport.cs
Normal file
@ -0,0 +1,37 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace WinFormsTestApp
|
||||
{
|
||||
public class Transport
|
||||
{
|
||||
public int Id { get; set; }
|
||||
|
||||
public string RegNumber { get; set; }
|
||||
|
||||
public string State { get; set; }
|
||||
|
||||
public int Mileage { get; set; }
|
||||
|
||||
public int Price { get; set; }
|
||||
|
||||
public string TransportType { get; set; }
|
||||
|
||||
public string Model { get; set; }
|
||||
|
||||
public string Owner { get; set; }
|
||||
|
||||
public string Fuel { get; set; }
|
||||
|
||||
public Transport(string regNumber, string transportType, string model)
|
||||
{
|
||||
RegNumber = regNumber;
|
||||
TransportType = transportType;
|
||||
Model = model;
|
||||
}
|
||||
public Transport() { }
|
||||
}
|
||||
}
|
15
VolkovLabs/WinFormsTestApp/WinFormsTestApp.csproj
Normal file
15
VolkovLabs/WinFormsTestApp/WinFormsTestApp.csproj
Normal file
@ -0,0 +1,15 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<OutputType>WinExe</OutputType>
|
||||
<TargetFramework>net6.0-windows</TargetFramework>
|
||||
<Nullable>enable</Nullable>
|
||||
<UseWindowsForms>true</UseWindowsForms>
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\WinFormsLibraryVolkov\WinFormsLibraryVolkov.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
Loading…
Reference in New Issue
Block a user