Библиотека .NET или C # для формата CGM (метафайл компьютерной графики)? - PullRequest
3 голосов
/ 27 января 2011

Кто-нибудь знает библиотеку .NET C # для отображения файлов CGM в WinForms и Microsoft Service Reports / CrystalReports, так что она также пригодна для печати?

Было бы также очень полезно, если бы можно было также конвертировать файл в графический формат, такой как jpeg, gif, png и т. Д.

Вероятно, это повторяющийся вопрос из .NET Library для преобразования файлов CGM , но этот OP не пометил ответ, равно как и предложенные решения .NET-совместимы.

Так что я снова пытаюсь испытать удачу. Спасибо за помощь.

1 Ответ

3 голосов
/ 27 января 2011

Я просто хочу поделиться этим временным хаком с SO.Я все еще нуждаюсь в надлежащей библиотеке, если это возможно (спасибо всем, кто делает учебники по .NET Excel доступными в Интернете):

using System;
using Excel = Microsoft.Office.Interop.Excel;
using Microsoft.Office.Core;
using System.Drawing;

namespace CGM

{
    public class CGMConverter 
    {
        Image _mImage;

        public Image Image { get { return _mImage; } }

        public CGMConverter(string cgm, float width, float height)
        {
            object misValue = System.Reflection.Missing.Value;
            Excel.Application xlsApp = null;
            Excel.Workbook xlsWorkBook = null;
            Excel.Worksheet xlsWorkSheet = null;

            try
            {
                xlsApp = new Excel.ApplicationClass();
                xlsWorkBook = xlsApp.Workbooks.Add(misValue);
                xlsWorkSheet = (Excel.Worksheet)xlsWorkBook.Sheets["sheet1"];
                xlsWorkSheet.Shapes.AddPicture(cgm, MsoTriState.msoFalse, MsoTriState.msoTrue, 50, 50, width, height);
                xlsWorkSheet.Shapes.Item(0).Copy();
                _mImage = System.Windows.Forms.Clipboard.GetImage();
            }
            catch(Exception e)
            {
                throw (e);
            }
            finally
            {
                xlsApp.DisplayAlerts = false;
                xlsApp.Quit();
                releaseObject(xlsWorkSheet);
                releaseObject(xlsWorkBook);
                releaseObject(xlsApp);
            }
        }

        private void releaseObject(object obj)
        {
            try
            {
                System.Runtime.InteropServices.Marshal.ReleaseComObject(obj);
                obj = null;
            }
            catch (Exception ex)
            {
                obj = null;
            }
            finally
            {
                GC.Collect();
            }
        }
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...