Skip to content

Commit ab4e6f1

Browse files
Merge pull request #199 from SyncfusionExamples/Convert_all_pages_to_images
Convert_all_pages_to_images
2 parents 8fc48ab + 1abb0a9 commit ab4e6f1

File tree

7 files changed

+225
-0
lines changed

7 files changed

+225
-0
lines changed
Lines changed: 25 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
2+
Microsoft Visual Studio Solution File, Format Version 12.00
3+
# Visual Studio Version 17
4+
VisualStudioVersion = 17.9.34622.214
5+
MinimumVisualStudioVersion = 10.0.40219.1
6+
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Convert_all_pages_to_images", "Convert_all_pages_to_images\Convert_all_pages_to_images.csproj", "{F6FB6C86-7B45-4A79-92C0-0235DAC44E96}"
7+
EndProject
8+
Global
9+
GlobalSection(SolutionConfigurationPlatforms) = preSolution
10+
Debug|Any CPU = Debug|Any CPU
11+
Release|Any CPU = Release|Any CPU
12+
EndGlobalSection
13+
GlobalSection(ProjectConfigurationPlatforms) = postSolution
14+
{F6FB6C86-7B45-4A79-92C0-0235DAC44E96}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
15+
{F6FB6C86-7B45-4A79-92C0-0235DAC44E96}.Debug|Any CPU.Build.0 = Debug|Any CPU
16+
{F6FB6C86-7B45-4A79-92C0-0235DAC44E96}.Release|Any CPU.ActiveCfg = Release|Any CPU
17+
{F6FB6C86-7B45-4A79-92C0-0235DAC44E96}.Release|Any CPU.Build.0 = Release|Any CPU
18+
EndGlobalSection
19+
GlobalSection(SolutionProperties) = preSolution
20+
HideSolutionNode = FALSE
21+
EndGlobalSection
22+
GlobalSection(ExtensibilityGlobals) = postSolution
23+
SolutionGuid = {88CD8C1D-ABD8-4B5D-9383-3FD89CDA1A35}
24+
EndGlobalSection
25+
EndGlobal
Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,6 @@
1+
<?xml version="1.0" encoding="utf-8" ?>
2+
<configuration>
3+
<startup>
4+
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.6.2" />
5+
</startup>
6+
</configuration>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,80 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<Project ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
3+
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
4+
<PropertyGroup>
5+
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
6+
<Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
7+
<ProjectGuid>{F6FB6C86-7B45-4A79-92C0-0235DAC44E96}</ProjectGuid>
8+
<OutputType>Exe</OutputType>
9+
<RootNamespace>Convert_all_pages_to_images</RootNamespace>
10+
<AssemblyName>Convert_all_pages_to_images</AssemblyName>
11+
<TargetFrameworkVersion>v4.6.2</TargetFrameworkVersion>
12+
<FileAlignment>512</FileAlignment>
13+
<AutoGenerateBindingRedirects>true</AutoGenerateBindingRedirects>
14+
<Deterministic>true</Deterministic>
15+
</PropertyGroup>
16+
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
17+
<PlatformTarget>AnyCPU</PlatformTarget>
18+
<DebugSymbols>true</DebugSymbols>
19+
<DebugType>full</DebugType>
20+
<Optimize>false</Optimize>
21+
<OutputPath>bin\Debug\</OutputPath>
22+
<DefineConstants>DEBUG;TRACE</DefineConstants>
23+
<ErrorReport>prompt</ErrorReport>
24+
<WarningLevel>4</WarningLevel>
25+
</PropertyGroup>
26+
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
27+
<PlatformTarget>AnyCPU</PlatformTarget>
28+
<DebugType>pdbonly</DebugType>
29+
<Optimize>true</Optimize>
30+
<OutputPath>bin\Release\</OutputPath>
31+
<DefineConstants>TRACE</DefineConstants>
32+
<ErrorReport>prompt</ErrorReport>
33+
<WarningLevel>4</WarningLevel>
34+
</PropertyGroup>
35+
<ItemGroup>
36+
<Reference Include="Syncfusion.Compression.Base, Version=26.1462.41.0, Culture=neutral, PublicKeyToken=3d67ed1f87d44c89, processorArchitecture=MSIL">
37+
<HintPath>..\packages\Syncfusion.Compression.Base.26.1.41\lib\net462\Syncfusion.Compression.Base.dll</HintPath>
38+
</Reference>
39+
<Reference Include="Syncfusion.DocIO.Base, Version=26.1462.41.0, Culture=neutral, PublicKeyToken=3d67ed1f87d44c89, processorArchitecture=MSIL">
40+
<HintPath>..\packages\Syncfusion.DocIO.WinForms.26.1.41\lib\net462\Syncfusion.DocIO.Base.dll</HintPath>
41+
</Reference>
42+
<Reference Include="Syncfusion.DocToPdfConverter.Base, Version=26.1462.41.0, Culture=neutral, PublicKeyToken=3d67ed1f87d44c89, processorArchitecture=MSIL">
43+
<HintPath>..\packages\Syncfusion.DocToPDFConverter.WinForms.26.1.41\lib\net462\Syncfusion.DocToPdfConverter.Base.dll</HintPath>
44+
</Reference>
45+
<Reference Include="Syncfusion.Licensing, Version=26.1462.41.0, Culture=neutral, PublicKeyToken=632609b4d040f6b4, processorArchitecture=MSIL">
46+
<HintPath>..\packages\Syncfusion.Licensing.26.1.41\lib\net462\Syncfusion.Licensing.dll</HintPath>
47+
</Reference>
48+
<Reference Include="Syncfusion.OfficeChart.Base, Version=26.1462.41.0, Culture=neutral, PublicKeyToken=3d67ed1f87d44c89, processorArchitecture=MSIL">
49+
<HintPath>..\packages\Syncfusion.OfficeChart.Base.26.1.41\lib\net462\Syncfusion.OfficeChart.Base.dll</HintPath>
50+
</Reference>
51+
<Reference Include="Syncfusion.OfficeChartToImageConverter.Wpf, Version=26.1462.41.0, Culture=neutral, PublicKeyToken=3d67ed1f87d44c89, processorArchitecture=MSIL">
52+
<HintPath>..\packages\Syncfusion.OfficeChartToImageConverter.WPF.26.1.41\lib\net462\Syncfusion.OfficeChartToImageConverter.Wpf.dll</HintPath>
53+
</Reference>
54+
<Reference Include="Syncfusion.Pdf.Base, Version=26.1462.41.0, Culture=neutral, PublicKeyToken=3d67ed1f87d44c89, processorArchitecture=MSIL">
55+
<HintPath>..\packages\Syncfusion.Pdf.WinForms.26.1.41\lib\net462\Syncfusion.Pdf.Base.dll</HintPath>
56+
</Reference>
57+
<Reference Include="Syncfusion.SfChart.WPF, Version=26.1462.41.0, Culture=neutral, PublicKeyToken=3d67ed1f87d44c89, processorArchitecture=MSIL">
58+
<HintPath>..\packages\Syncfusion.SfChart.WPF.26.1.41\lib\net462\Syncfusion.SfChart.WPF.dll</HintPath>
59+
</Reference>
60+
<Reference Include="System" />
61+
<Reference Include="System.Core" />
62+
<Reference Include="System.Drawing" />
63+
<Reference Include="System.IO.Compression" />
64+
<Reference Include="System.Xml.Linq" />
65+
<Reference Include="System.Data.DataSetExtensions" />
66+
<Reference Include="Microsoft.CSharp" />
67+
<Reference Include="System.Data" />
68+
<Reference Include="System.Net.Http" />
69+
<Reference Include="System.Xml" />
70+
</ItemGroup>
71+
<ItemGroup>
72+
<Compile Include="Program.cs" />
73+
<Compile Include="Properties\AssemblyInfo.cs" />
74+
</ItemGroup>
75+
<ItemGroup>
76+
<None Include="App.config" />
77+
<None Include="packages.config" />
78+
</ItemGroup>
79+
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
80+
</Project>
Lines changed: 67 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,67 @@
1+
using System;
2+
using System.Drawing;
3+
using System.Drawing.Imaging;
4+
using System.IO;
5+
using Syncfusion.DocIO.DLS;
6+
using Syncfusion.DocIO;
7+
using Syncfusion.Compression.Zip;
8+
using Syncfusion.OfficeChart;
9+
using Syncfusion.OfficeChartToImageConverter;
10+
using System.IO.Compression;
11+
using ZipArchive = Syncfusion.Compression.Zip.ZipArchive;
12+
13+
namespace WordToImageConsoleApp
14+
{
15+
class Program
16+
{
17+
static void Main(string[] args)
18+
{
19+
// Load an existing Word document from the specified path.
20+
using (WordDocument wordDocument = new WordDocument(Path.GetFullPath(@"../../Data/Template.docx"), FormatType.Docx))
21+
{
22+
// Initialize the ChartToImageConverter for converting charts during Word to image conversion.
23+
wordDocument.ChartToImageConverter = new ChartToImageConverter();
24+
// Set the scaling mode for charts (Normal mode reduces the file size).
25+
wordDocument.ChartToImageConverter.ScalingMode = ScalingMode.Normal;
26+
27+
// Convert the entire Word document to images.
28+
Image[] images = wordDocument.RenderAsImages(ImageType.Bitmap);
29+
30+
// Initialize a ZipArchive to store the converted images.
31+
using (ZipArchive zipArchive = new ZipArchive())
32+
{
33+
// Set the compression level to the fastest.
34+
zipArchive.DefaultCompressionLevel = (Syncfusion.Compression.CompressionLevel)CompressionLevel.Fastest;
35+
36+
int i = 0; // Initialize an index for naming the images.
37+
foreach (Image image in images)
38+
{
39+
// Create a memory stream to hold the image data.
40+
MemoryStream imageStream = new MemoryStream();
41+
42+
// Save the image to the memory stream in JPEG format.
43+
image.Save(imageStream, ImageFormat.Jpeg);
44+
imageStream.Position = 0;
45+
46+
// Create a ZipArchiveItem with the image stream.
47+
string imageName = $"WordToImage_{i}.jpeg";
48+
ZipArchiveItem item = new ZipArchiveItem(zipArchive, imageName, imageStream, true, FileAttributes.Normal);
49+
zipArchive.AddItem(item);
50+
51+
i++; // Increment the index for the next image.
52+
}
53+
54+
// Save the ZipArchive to a memory stream.
55+
using (MemoryStream zipStream = new MemoryStream())
56+
{
57+
zipArchive.Save(zipStream, false);
58+
zipStream.Position = 0;
59+
60+
// Write the zipStream to a file.
61+
File.WriteAllBytes(Path.GetFullPath(@"../../Data/Images.zip"), zipStream.ToArray());
62+
}
63+
}
64+
}
65+
}
66+
}
67+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,36 @@
1+
using System.Reflection;
2+
using System.Runtime.CompilerServices;
3+
using System.Runtime.InteropServices;
4+
5+
// General Information about an assembly is controlled through the following
6+
// set of attributes. Change these attribute values to modify the information
7+
// associated with an assembly.
8+
[assembly: AssemblyTitle("Convert_all_pages_to_images")]
9+
[assembly: AssemblyDescription("")]
10+
[assembly: AssemblyConfiguration("")]
11+
[assembly: AssemblyCompany("")]
12+
[assembly: AssemblyProduct("Convert_all_pages_to_images")]
13+
[assembly: AssemblyCopyright("Copyright © 2024")]
14+
[assembly: AssemblyTrademark("")]
15+
[assembly: AssemblyCulture("")]
16+
17+
// Setting ComVisible to false makes the types in this assembly not visible
18+
// to COM components. If you need to access a type in this assembly from
19+
// COM, set the ComVisible attribute to true on that type.
20+
[assembly: ComVisible(false)]
21+
22+
// The following GUID is for the ID of the typelib if this project is exposed to COM
23+
[assembly: Guid("f6fb6c86-7b45-4a79-92c0-0235dac44e96")]
24+
25+
// Version information for an assembly consists of the following four values:
26+
//
27+
// Major Version
28+
// Minor Version
29+
// Build Number
30+
// Revision
31+
//
32+
// You can specify all the values or you can default the Build and Revision Numbers
33+
// by using the '*' as shown below:
34+
// [assembly: AssemblyVersion("1.0.*")]
35+
[assembly: AssemblyVersion("1.0.0.0")]
36+
[assembly: AssemblyFileVersion("1.0.0.0")]
Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<packages>
3+
<package id="Syncfusion.Compression.Base" version="26.1.41" targetFramework="net462" />
4+
<package id="Syncfusion.DocIO.WinForms" version="26.1.41" targetFramework="net462" />
5+
<package id="Syncfusion.DocToPDFConverter.WinForms" version="26.1.41" targetFramework="net462" />
6+
<package id="Syncfusion.Licensing" version="26.1.41" targetFramework="net462" />
7+
<package id="Syncfusion.OfficeChart.Base" version="26.1.41" targetFramework="net462" />
8+
<package id="Syncfusion.OfficeChartToImageConverter.WPF" version="26.1.41" targetFramework="net462" />
9+
<package id="Syncfusion.Pdf.WinForms" version="26.1.41" targetFramework="net462" />
10+
<package id="Syncfusion.SfChart.WPF" version="26.1.41" targetFramework="net462" />
11+
</packages>

0 commit comments

Comments
 (0)