-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathCustomDocumentOperationService.cs
More file actions
52 lines (42 loc) · 2.05 KB
/
CustomDocumentOperationService.cs
File metadata and controls
52 lines (42 loc) · 2.05 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
using DevExpress.XtraReports.Web.WebDocumentViewer;
using DevExpress.XtraReports.Web.WebDocumentViewer.DataContracts;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using DevExpress.XtraPrinting;
using DevExpress.XtraPrinting.Drawing;
using System.Drawing;
using System.Data.SqlClient;
namespace WebApplication1 {
public class CustomDocumentOperationService : DocumentOperationService {
public override bool CanPerformOperation(DocumentOperationRequest request) {
return true;
}
public override DocumentOperationResponse PerformOperation(DocumentOperationRequest request, PrintingSystemBase initialPrintingSystem, PrintingSystemBase printingSystemWithEditingFields) {
ImageSource imageSource = printingSystemWithEditingFields.EditingFields[0].EditValue as ImageSource;
if (imageSource != null) {
var img = imageSource.Image;
byte[] arr = ImageToByte(img);
SaveToDataBase(arr);
}
return base.PerformOperation(request, initialPrintingSystem, printingSystemWithEditingFields);
}
public static byte[] ImageToByte(Image img) {
ImageConverter converter = new ImageConverter();
return (byte[])converter.ConvertTo(img, typeof(byte[]));
}
public void SaveToDataBase(byte[] arr) {
string connectionString = System.Configuration.ConfigurationManager
.ConnectionStrings["SignatureDBConnectionString"].ConnectionString;
using (SqlConnection connection = new SqlConnection(connectionString))
using (SqlCommand command = connection.CreateCommand()) {
command.CommandText = "Update SignatureTable SET Signature = @arr Where Id='1'";
command.Parameters.AddWithValue("@arr", arr);
connection.Open();
command.ExecuteNonQuery();
connection.Close();
}
}
}
}