Added excel image component
This commit is contained in:
parent
a6a79d0213
commit
8364484ce7
25
AbazovApp/AbazovAppView/FormTest.Designer.cs
generated
25
AbazovApp/AbazovAppView/FormTest.Designer.cs
generated
@ -28,6 +28,7 @@
|
||||
/// </summary>
|
||||
private void InitializeComponent()
|
||||
{
|
||||
this.components = new System.ComponentModel.Container();
|
||||
this.abazovCheckedListBox = new AbazovViewComponents.Components.AbazovCheckedListBox();
|
||||
this.buttonAdd = new System.Windows.Forms.Button();
|
||||
this.buttonClear = new System.Windows.Forms.Button();
|
||||
@ -42,6 +43,9 @@
|
||||
this.buttonGetValue = new System.Windows.Forms.Button();
|
||||
this.buttonGetIndex = new System.Windows.Forms.Button();
|
||||
this.buttonSetIndex = new System.Windows.Forms.Button();
|
||||
this.excelImagesComponent = new AbazovViewComponents.LogicalComponents.ExcelImagesComponent(this.components);
|
||||
this.buttonExcelImages = new System.Windows.Forms.Button();
|
||||
this.openFileDialog = new System.Windows.Forms.OpenFileDialog();
|
||||
this.SuspendLayout();
|
||||
//
|
||||
// abazovCheckedListBox
|
||||
@ -91,6 +95,7 @@
|
||||
this.abazovDatePicker.Name = "abazovDatePicker";
|
||||
this.abazovDatePicker.Size = new System.Drawing.Size(275, 48);
|
||||
this.abazovDatePicker.TabIndex = 4;
|
||||
this.abazovDatePicker.Value = null;
|
||||
this.abazovDatePicker.DateChange += new System.Action<System.DateTime>(this.abazovDatePicker_DateChange);
|
||||
this.abazovDatePicker.AutoSizeChanged += new System.EventHandler(this.abazovDatePicker_DateChange);
|
||||
//
|
||||
@ -182,11 +187,28 @@
|
||||
this.buttonSetIndex.UseVisualStyleBackColor = true;
|
||||
this.buttonSetIndex.Click += new System.EventHandler(this.buttonSetIndex_Click);
|
||||
//
|
||||
// buttonExcelImages
|
||||
//
|
||||
this.buttonExcelImages.Location = new System.Drawing.Point(12, 327);
|
||||
this.buttonExcelImages.Name = "buttonExcelImages";
|
||||
this.buttonExcelImages.Size = new System.Drawing.Size(150, 29);
|
||||
this.buttonExcelImages.TabIndex = 14;
|
||||
this.buttonExcelImages.Text = "Excel (картинки)";
|
||||
this.buttonExcelImages.UseVisualStyleBackColor = true;
|
||||
this.buttonExcelImages.Click += new System.EventHandler(this.buttonExcelImages_Click);
|
||||
//
|
||||
// openFileDialog
|
||||
//
|
||||
this.openFileDialog.Filter = "Изображения|*.png;*.jpg;";
|
||||
this.openFileDialog.Multiselect = true;
|
||||
this.openFileDialog.Title = "Выберте изображения";
|
||||
//
|
||||
// FormTest
|
||||
//
|
||||
this.AutoScaleDimensions = new System.Drawing.SizeF(8F, 20F);
|
||||
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
|
||||
this.ClientSize = new System.Drawing.Size(850, 450);
|
||||
this.Controls.Add(this.buttonExcelImages);
|
||||
this.Controls.Add(this.buttonSetIndex);
|
||||
this.Controls.Add(this.buttonGetIndex);
|
||||
this.Controls.Add(this.buttonGetValue);
|
||||
@ -223,5 +245,8 @@
|
||||
private Button buttonGetValue;
|
||||
private Button buttonGetIndex;
|
||||
private Button buttonSetIndex;
|
||||
private AbazovViewComponents.LogicalComponents.ExcelImagesComponent excelImagesComponent;
|
||||
private Button buttonExcelImages;
|
||||
private OpenFileDialog openFileDialog;
|
||||
}
|
||||
}
|
@ -1,11 +1,13 @@
|
||||
using AbazovViewComponents.Components;
|
||||
using AbazovViewComponents.Exceptions;
|
||||
using AbazovViewComponents.LogicalComponents;
|
||||
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;
|
||||
@ -127,5 +129,18 @@ namespace AbazovAppView
|
||||
{
|
||||
abazovTreeView.SelectedNodeIndex = 0;
|
||||
}
|
||||
|
||||
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 + "test.xlsx";
|
||||
MessageBox.Show(path);
|
||||
if (excelImagesComponent.createWithImages(new ExcelImageInfo(path, "Header", files))) MessageBox.Show("Успех!");
|
||||
else MessageBox.Show("Ошибка, проверьте консоль");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -57,4 +57,10 @@
|
||||
<resheader name="writer">
|
||||
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
<metadata name="excelImagesComponent.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
|
||||
<value>17, 17</value>
|
||||
</metadata>
|
||||
<metadata name="openFileDialog.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
|
||||
<value>233, 17</value>
|
||||
</metadata>
|
||||
</root>
|
@ -7,4 +7,27 @@
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<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>
|
||||
<Private>true</Private>
|
||||
</COMReference>
|
||||
<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>
|
||||
<Private>true</Private>
|
||||
</COMReference>
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
||||
|
@ -0,0 +1,22 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace AbazovViewComponents.LogicalComponents
|
||||
{
|
||||
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
AbazovApp/AbazovViewComponents/LogicalComponents/ExcelImagesComponent.Designer.cs
generated
Normal file
36
AbazovApp/AbazovViewComponents/LogicalComponents/ExcelImagesComponent.Designer.cs
generated
Normal file
@ -0,0 +1,36 @@
|
||||
namespace AbazovViewComponents.LogicalComponents
|
||||
{
|
||||
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,74 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel;
|
||||
using System.Diagnostics;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using Microsoft.Office.Interop.Excel;
|
||||
using Microsoft.Office.Core;
|
||||
|
||||
namespace AbazovViewComponents.LogicalComponents
|
||||
{
|
||||
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;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user