PIbd-21_SagirovM.M_Liner_Base/Liner/FormLinerCollection.cs

277 lines
12 KiB
C#
Raw Permalink Normal View History

2023-11-24 12:39:11 +04:00
using Liner.Drawing;
using Liner.Generics;
using Liner.MovingStrategies;
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 Microsoft.Extensions.Logging;
using Liner.Exceptions;
using System.Xml.Linq;
2023-11-24 12:39:11 +04:00
namespace Liner
{
/// <summary>
/// Форма для работы с набором объектов класса DrawingLiner
/// </summary>
public partial class FormLinerCollection : Form
{
/// <summary>
/// Набор объектов
/// </summary>
2023-11-24 12:49:48 +04:00
private readonly LinersGenericStorage _storage;
2023-11-24 12:39:11 +04:00
/// <summary>
/// Логер
/// </summary>
private readonly ILogger _logger;
/// <summary>
2023-11-24 12:39:11 +04:00
/// Конструктор
/// </summary>
public FormLinerCollection(ILogger<FormLinerCollection> logger)
2023-11-24 12:39:11 +04:00
{
InitializeComponent();
2023-11-24 12:49:48 +04:00
_storage = new LinersGenericStorage(pictureBoxCollection.Width, pictureBoxCollection.Height);
_logger = logger;
2023-11-24 12:39:11 +04:00
}
/// <summary>
/// Добавление объекта в набор
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
2023-11-24 12:49:48 +04:00
private void ButtonAddLiner_Click(object sender, EventArgs e)
2023-11-24 12:39:11 +04:00
{
2023-11-24 12:49:48 +04:00
if (listBoxStorages.SelectedIndex == -1)
{
_logger.LogWarning($"Добавление лайнера не удалось (индекс вне границ)");
2023-11-24 12:49:48 +04:00
return;
}
2023-11-24 15:14:59 +04:00
var formLinerConfig = new FormLinerConfig();
formLinerConfig.AddEvent(AddLiner);
formLinerConfig.Show();
}
private void AddLiner(DrawingLiner liner)
{
if (listBoxStorages.SelectedIndex == -1)
{
_logger.LogWarning($"Добавление лайнера не удалось (индекс вне границ)");
2023-11-24 15:14:59 +04:00
return;
}
var obj = _storage[listBoxStorages.SelectedItem.ToString() ?? string.Empty];
2023-11-24 12:49:48 +04:00
if (obj == null)
{
_logger.LogWarning($"Добавление лайнера не удалось (нет хранилища)");
2023-11-24 12:49:48 +04:00
return;
}
try
2023-11-24 12:39:11 +04:00
{
if ((obj + liner) != -1)
{
MessageBox.Show("Объект добавлен");
_logger.LogInformation($"Добавление лайнера успешно {listBoxStorages.SelectedItem.ToString()}");
pictureBoxCollection.Image = obj.ShowLiners();
}
else
{
MessageBox.Show("Не удалось добавить объект");
}
2023-11-24 15:14:59 +04:00
}
catch (ApplicationException ex)
2023-11-24 15:14:59 +04:00
{
2023-12-18 15:00:17 +04:00
_logger.LogWarning($"Добавление лайнера в {listBoxStorages.SelectedItem.ToString()} не удалось (переполнение коллекции)");
MessageBox.Show(ex.Message);
2023-11-24 12:39:11 +04:00
}
}
/// <summary>
/// Удаление объекта из набора
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
2023-11-24 12:49:48 +04:00
private void ButtonRemoveLiner_Click(object sender, EventArgs e)
2023-11-24 12:39:11 +04:00
{
int pos = 0; //фикс недосмотра
2023-11-24 12:49:48 +04:00
if (listBoxStorages.SelectedIndex == -1)
{
_logger.LogWarning($"Удаление лайнера не удалось (индекс вне границ)");
2023-11-24 12:49:48 +04:00
return;
}
var obj = _storage[listBoxStorages.SelectedItem.ToString() ?? string.Empty];
if (obj == null)
{
_logger.LogWarning($"Удаление лайнера не удалось (нет хранилища)");
2023-11-24 12:49:48 +04:00
return;
}
2023-11-24 12:39:11 +04:00
if (MessageBox.Show("Удалить объект?", "Удаление",
MessageBoxButtons.YesNo, MessageBoxIcon.Question) == DialogResult.No)
{
_logger.LogWarning($"Удаление лайнера не удалось (выбран вариант 'Нет')");
2023-11-24 12:39:11 +04:00
return;
}
if (textBoxNumber.Text != "") //улучшил проверку
2023-11-24 15:27:59 +04:00
{
if(!int.TryParse(textBoxNumber.Text, out pos))
{
_logger.LogWarning($"Удаление лайнера не удалось (неверный формат)");
return;
}
2023-11-24 15:27:59 +04:00
}
else
{
_logger.LogWarning($"Удаление лайнера не удалось (пустое поле ввода)");
2023-11-24 15:27:59 +04:00
MessageBox.Show("Не удалось удалить объект");
return;
}
try
2023-11-24 12:39:11 +04:00
{
if (obj - pos)
{
_logger.LogInformation($"Удаление лайнера успешно {listBoxStorages.SelectedItem.ToString()} {pos}");
MessageBox.Show("Объект удален");
pictureBoxCollection.Image = obj.ShowLiners();
}
else
{
_logger.LogWarning($"Удаление лайнера не удалось(обьект не найден)");
MessageBox.Show("Не удалось удалить объект");
}
2023-11-24 12:39:11 +04:00
}
catch (LinerNotFoundException ex)
2023-11-24 12:39:11 +04:00
{
_logger.LogWarning($"Удаление лайнера не удалось {ex.Message}");
MessageBox.Show(ex.Message);
2023-11-24 12:39:11 +04:00
}
}
/// <summary>
2023-11-24 12:49:48 +04:00
/// Добавление набора в коллекцию
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void ButtonAddObject_Click(object sender, EventArgs e)
{
if (string.IsNullOrEmpty(textBoxStorageName.Text))
{
_logger.LogWarning($"Обновление набора не удалось (не все данные заполнены)");
2023-11-24 12:49:48 +04:00
MessageBox.Show("Не все данные заполнены", "Ошибка",
MessageBoxButtons.OK, MessageBoxIcon.Error);
return;
}
_storage.AddSet(textBoxStorageName.Text);
_logger.LogInformation($"Добавлен набор: {textBoxStorageName.Text} ");
2023-11-24 12:49:48 +04:00
ReloadObjects();
}
/// <summary>
/// Выбор набора
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void ListBoxObjects_SelectedIndexChanged(object sender, EventArgs e)
{
pictureBoxCollection.Image =
_storage[listBoxStorages.SelectedItem?.ToString() ?? string.Empty]?.ShowLiners();
}
/// <summary>
/// Удаление набора
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void ButtonRemoveObject_Click(object sender, EventArgs e)
{
if (listBoxStorages.SelectedIndex == -1)
{
_logger.LogWarning($"Удаление набора не удалось (индекс вне границ)");
2023-11-24 12:49:48 +04:00
return;
}
if (MessageBox.Show($"Удалить объект {listBoxStorages.SelectedItem}?", "Удаление",
MessageBoxButtons.YesNo, MessageBoxIcon.Question) == DialogResult.Yes)
{
string name = listBoxStorages.SelectedItem.ToString() ?? string.Empty;
_storage.DelSet(name);
_logger.LogInformation($"Удаление набора успешно: {name}");
2023-11-24 12:49:48 +04:00
ReloadObjects();
}
}
/// <summary>
2023-11-24 12:39:11 +04:00
/// Обновление рисунка по набору
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
2023-11-24 15:22:12 +04:00
private void ButtonRefreshCollection_Click(object sender, EventArgs e)
2023-11-24 12:49:48 +04:00
{
if (listBoxStorages.SelectedIndex == -1)
{
_logger.LogWarning($"Обновление объектов не удалось (индекс вне границ)");
2023-11-24 12:49:48 +04:00
return;
}
var obj = _storage[listBoxStorages.SelectedItem.ToString() ?? string.Empty];
if (obj == null)
{
_logger.LogWarning($"Обновление объектов не удалось (нет хранилища)");
2023-11-24 12:49:48 +04:00
return;
}
_logger.LogInformation($"Обновление объектов успешно");
2023-11-24 12:49:48 +04:00
pictureBoxCollection.Image = obj.ShowLiners();
}
/// <summary>
/// Заполнение listBoxObjects
/// </summary>
private void ReloadObjects()
2023-11-24 12:39:11 +04:00
{
2023-11-24 12:49:48 +04:00
int index = listBoxStorages.SelectedIndex;
listBoxStorages.Items.Clear();
for (int i = 0; i < _storage.Keys.Count; i++)
{
listBoxStorages.Items.Add(_storage.Keys[i]);
}
if (listBoxStorages.Items.Count > 0 && (index == -1 || index >= listBoxStorages.Items.Count))
{
listBoxStorages.SelectedIndex = 0;
}
else if (listBoxStorages.Items.Count > 0 && index > -1 && index < listBoxStorages.Items.Count)
{
listBoxStorages.SelectedIndex = index;
}
2023-11-24 12:39:11 +04:00
}
private void SaveToolStripMenuItem_Click(object sender, EventArgs e)
{
if (saveFileDialog.ShowDialog() == DialogResult.OK)
{
try
{
_storage.SaveData(saveFileDialog.FileName);
_logger.LogInformation($"Cохранение успешно");
MessageBox.Show("Сохранение прошло успешно",
"Результат", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
catch(Exception ex)
{
MessageBox.Show($"Не сохранилось: {ex.Message}", "Результат", MessageBoxButtons.OK, MessageBoxIcon.Error);
_logger.LogWarning($"Сохранение не удалось {ex.Message}");
}
}
}
private void LoadToolStripMenuItem_Click(object sender, EventArgs e)
{
if (openFileDialog.ShowDialog() == DialogResult.OK)
{
try
{
_storage.LoadData(openFileDialog.FileName);
_logger.LogInformation($"Загрузка успешна");
MessageBox.Show("Загрузка прошла успешно", "Результат", MessageBoxButtons.OK, MessageBoxIcon.Information);
ReloadObjects();
}
catch (Exception ex)
{
MessageBox.Show($"Не загрузилось: {ex.Message}", "Результат",
MessageBoxButtons.OK, MessageBoxIcon.Error);
_logger.LogWarning($"Загрузка не удалась {ex.Message}");
}
}
}
2023-11-24 12:39:11 +04:00
}
}