diff --git a/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images.sln b/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images.sln
new file mode 100644
index 000000000..eba720cb0
--- /dev/null
+++ b/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images.sln
@@ -0,0 +1,22 @@
+
+Microsoft Visual Studio Solution File, Format Version 12.00
+# Visual Studio Version 17
+VisualStudioVersion = 17.12.35527.113 d17.12
+MinimumVisualStudioVersion = 10.0.40219.1
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Extract-charts-as-images", "Extract-charts-as-images\Extract-charts-as-images.csproj", "{5B0540C8-1A4D-4BB4-A0B9-10028D140E00}"
+EndProject
+Global
+ GlobalSection(SolutionConfigurationPlatforms) = preSolution
+ Debug|Any CPU = Debug|Any CPU
+ Release|Any CPU = Release|Any CPU
+ EndGlobalSection
+ GlobalSection(ProjectConfigurationPlatforms) = postSolution
+ {5B0540C8-1A4D-4BB4-A0B9-10028D140E00}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+ {5B0540C8-1A4D-4BB4-A0B9-10028D140E00}.Debug|Any CPU.Build.0 = Debug|Any CPU
+ {5B0540C8-1A4D-4BB4-A0B9-10028D140E00}.Release|Any CPU.ActiveCfg = Release|Any CPU
+ {5B0540C8-1A4D-4BB4-A0B9-10028D140E00}.Release|Any CPU.Build.0 = Release|Any CPU
+ EndGlobalSection
+ GlobalSection(SolutionProperties) = preSolution
+ HideSolutionNode = FALSE
+ EndGlobalSection
+EndGlobal
diff --git a/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images/Data/Template.docx b/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images/Data/Template.docx
new file mode 100644
index 000000000..9583726ca
Binary files /dev/null and b/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images/Data/Template.docx differ
diff --git a/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images/Extract-charts-as-images.csproj b/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images/Extract-charts-as-images.csproj
new file mode 100644
index 000000000..abaf7a073
--- /dev/null
+++ b/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images/Extract-charts-as-images.csproj
@@ -0,0 +1,24 @@
+
+
+
+ Exe
+ net8.0
+ Extract_charts_as_images
+ enable
+ enable
+
+
+
+
+
+
+
+
+ Always
+
+
+ Always
+
+
+
+
diff --git a/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images/Output/.gitkeep b/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images/Output/.gitkeep
new file mode 100644
index 000000000..5f282702b
--- /dev/null
+++ b/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images/Output/.gitkeep
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images/Program.cs b/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images/Program.cs
new file mode 100644
index 000000000..08d57a556
--- /dev/null
+++ b/Charts/Extract-charts-as-images/.NET/Extract-charts-as-images/Program.cs
@@ -0,0 +1,30 @@
+using Syncfusion.DocIO.DLS;
+using Syncfusion.DocIORenderer;
+
+// Load the Word document.
+using (WordDocument document = new WordDocument(Path.GetFullPath(@"Data/Template.docx")))
+{
+ // Find all chart elements in the Word document by EntityType.
+ List charts = document.FindAllItemsByProperty(EntityType.Chart, null, null);
+
+ // Create an instance of DocIORenderer.
+ using (DocIORenderer renderer = new DocIORenderer())
+ {
+ // Loop through each chart found in the document.
+ for (int i = 0; i < charts.Count; i++)
+ {
+ WChart chart = charts[i] as WChart;
+
+ // Convert the chart to an image stream.
+ using (Stream stream = chart.SaveAsImage())
+ {
+ // Create a file stream to save the image to disk.
+ using (FileStream fileStreamOutput = File.Create(Path.GetFullPath(@"Output/Chart" + i + ".jpeg")))
+ {
+ // Copy the image stream to the output file.
+ stream.CopyTo(fileStreamOutput);
+ }
+ }
+ }
+ }
+}