VintaSoft Twain .NET SDK 14.1: Руководство для .NET разработчика
Vintasoft.Sane Namespace / SaneAcquiredImage Class / Save Methods / Save(String) Method
Синтаксис Exceptions Ремарки Example Требования Смотрите также
В этом разделе
    Save(String) Метод (SaneAcquiredImage)
    В этом разделе
    Сохраняет это изображение в файл.
    Синтаксис
    'Declaration
    
    Public Overloads Sub Save( _
    ByVal filename
    Имя файла, в который необходимо сохранить изображение.
    As String _
    )
    public void Save(
    string filename
    )
    public: void Save(
    string* filename
    )
    public:
    void Save(
    string^ filename
    )

    Parameters

    filename
    Имя файла, в который необходимо сохранить изображение.
    Исключения
    ИсключениеОписание
    Выбрасывается, если filename равно null.
    Ремарки

    Изображение может быть:
    - сохранено как файл изображения (BMP, JPEG, PNG, TIFF)
    - добавлено в многостраничный TIFF файл
    - сохранено в новый PDF или PDF/A документ
    - добавляется к существующему документу PDF или PDF/A

    Доступные типы сжатия для изображений, сохраненных в файле TIFF:
    - без сжатия
    - CCITT Group 4 Fax сжатие
    - LZW сжатие
    - ZIP сжатие
    - JPEG сжатие

    Доступные варианты сжатия для изображений, сохраняемых в PDF документ:
    - без сжатия
    - CCITT Group 4 Fax сжатие
    - Сжатие LZW
    - Сжатие ZIP
    - Сжатие JPEG

    Изображение может быть добавлено в PDF документ, совместимый с версией 1.4 или более ранней версии стандарта PDF.

    Изображение будет сохранено как файл BMP, если путь имеет расширение "bmp".
    Изображение будет сохранено как файл PNG, если путь имеет расширение "png".
    Изображение будет сохранено как новый TIFF файл или добавлено к существующему файлу TIFF, если путь имеет расширение "tif" или "tiff".
    Изображение будет сохранено в новый PDF файл или добавлено в существующий PDF файл, если путь имеет расширение "pdf". '.
    Изображение будет сохранено как JPEG файл для всех других расширений.

    Пример

    Вот C#/VB.NET код, который демонстрирует, как получить изображение с SANE устройства и сохранить изображение в JPEG файл.

    
    ''' <summary>
    ''' Acquires image from SANE device and saves image to a JPEG file.
    ''' </summary>
    Public Sub AcquireImageFromSaneDeviceAndSaveImageToJpegFile()
            ' create SANE device manager
            Using deviceManager As New Vintasoft.Sane.SaneLocalDeviceManager()
                    ' open SANE device manager
                    deviceManager.Open()
    
                    ' get count of SANE devices
                    Dim deviceCount As Integer = deviceManager.Devices.Count
                    If deviceCount = 0 Then
                            System.Console.WriteLine("Devices are not found.")
                            Return
                    End If
    
                    ' select the first SANE device
                    Dim device As Vintasoft.Sane.SaneLocalDevice = deviceManager.Devices(0)
    
                    ' open SANE device
                    device.Open()
    
                    Dim acquiredImage As Vintasoft.Sane.SaneAcquiredImage
                    Do
                            Try
                                    ' acquire image from SANE device
                                    acquiredImage = device.AcquireImageSync()
                                    ' if image is received
                                    If acquiredImage IsNot Nothing Then
                                            System.Console.WriteLine("Image is acquired.")
    
                                            ' create JPEG encoder settings
                                            Dim jpegEncoderSettings As New Vintasoft.Sane.ImageEncoders.SaneJpegEncoderSettings()
                                            ' specify quality for JPEG image
                                            jpegEncoderSettings.JpegQuality = 70
    
                                            ' process acquired image
                                            acquiredImage.Save("test.jpg", jpegEncoderSettings)
                                    Else
                                            ' if image is not received
                                            System.Console.WriteLine("Scan is completed.")
                                            Exit Try
                                    End If
                            Catch ex As System.Exception
                                    System.Console.WriteLine(String.Format("Scan is failed: {0}", ex.Message))
                                    Exit Try
                            End Try
                    ' while device has more images to scan
                    Loop While device.HasMoreImagesToScan
    
                    ' close SANE device
                    device.Close()
    
                    ' close SANE device manager
                    deviceManager.Close()
            End Using
    
            System.Console.ReadLine()
    End Sub
    
    
    
    /// <summary>
    /// Acquires image from SANE device and saves image to a JPEG file.
    /// </summary>
    public void AcquireImageFromSaneDeviceAndSaveImageToJpegFile()
    {
        // create SANE device manager
        using (Vintasoft.Sane.SaneLocalDeviceManager deviceManager = new Vintasoft.Sane.SaneLocalDeviceManager())
        {
            // open SANE device manager
            deviceManager.Open();
    
            // get count of SANE devices
            int deviceCount = deviceManager.Devices.Count;
            if (deviceCount == 0)
            {
                System.Console.WriteLine("Devices are not found.");
                return;
            }
    
            // select the first SANE device
            Vintasoft.Sane.SaneLocalDevice device = deviceManager.Devices[0];
    
            // open SANE device
            device.Open();
    
            Vintasoft.Sane.SaneAcquiredImage acquiredImage;
            do
            {
                try
                {
                    // acquire image from SANE device
                    acquiredImage = device.AcquireImageSync();
                    // if image is received
                    if (acquiredImage != null)
                    {
                        System.Console.WriteLine("Image is acquired.");
    
                        // create JPEG encoder settings
                        Vintasoft.Sane.ImageEncoders.SaneJpegEncoderSettings jpegEncoderSettings =
                            new Vintasoft.Sane.ImageEncoders.SaneJpegEncoderSettings();
                        // specify quality for JPEG image
                        jpegEncoderSettings.JpegQuality = 70;
    
                        // process acquired image
                        acquiredImage.Save("test.jpg", jpegEncoderSettings);
                    }
                    // if image is not received
                    else
                    {
                        System.Console.WriteLine("Scan is completed.");
                        break;
                    }
                }
                catch (System.Exception ex)
                {
                    System.Console.WriteLine(string.Format("Scan is failed: {0}", ex.Message));
                    break;
                }
            }
            // while device has more images to scan
            while (device.HasMoreImagesToScan);
    
            // close SANE device
            device.Close();
    
            // close SANE device manager
            deviceManager.Close();
        }
    
        System.Console.ReadLine();
    }
    
    

    Требования

    Целевые платформы: .NET 8; .NET 7; .NET 6

    Смотрите также