Практическое руководство. Определение параметров, поддерживаемых кодировщиком
Обновлен: Ноябрь 2007
Параметры изображения, например его качество или уровень сжатия, можно менять, но для этого необходимо знать, какие параметры поддерживает выбранный кодировщик. У класса Image имеется метод GetEncoderParameterList, позволяющие определять список параметров, поддерживаемых тем или иным кодировщиком. Кодировщик определяется идентификатором GUID. Метод GetEncoderParameterList возвращает массив объектов EncoderParameter.
Пример
Результатом выполнения следующего примера кода будет список параметров, поддерживаемых кодировщиком JPEG. Чтобы определить категорию каждого параметра, используйте список категорий параметров и связанные с ними идентификаторы GUID в классе Encoder.
Private Sub GetSupportedParameters(ByVal e As PaintEventArgs)
Dim bitmap1 As New Bitmap(1, 1)
Dim jpgEncoder As ImageCodecInfo = GetEncoder(ImageFormat.Jpeg)
Dim paramList As EncoderParameters = _
bitmap1.GetEncoderParameterList(jpgEncoder.Clsid)
Dim encParams As EncoderParameter() = paramList.Param
Dim paramInfo As New StringBuilder()
Dim i As Integer
For i = 0 To encParams.Length - 1
paramInfo.Append("Param " & i & " holds " & _
encParams(i).NumberOfValues & " items of type " & _
encParams(i).Type.ToString() & vbCr & vbLf & "Guid category: " & _
encParams(i).Encoder.Guid.ToString() & vbCr & vbLf)
Next i
e.Graphics.DrawString(paramInfo.ToString(), _
Me.Font, Brushes.Red, 10.0F, 10.0F)
End Sub
Private Function GetEncoder(ByVal format As ImageFormat) As ImageCodecInfo
Dim codecs As ImageCodecInfo() = ImageCodecInfo.GetImageDecoders()
Dim codec As ImageCodecInfo
For Each codec In codecs
If codec.FormatID = format.Guid Then
Return codec
End If
Next codec
Return Nothing
End Function
private void GetSupportedParameters(PaintEventArgs e)
{
Bitmap bitmap1 = new Bitmap(1, 1);
ImageCodecInfo jpgEncoder = GetEncoder(ImageFormat.Jpeg);
EncoderParameters paramList = bitmap1.GetEncoderParameterList(jpgEncoder.Clsid);
EncoderParameter[] encParams = paramList.Param;
StringBuilder paramInfo = new StringBuilder();
for (int i = 0; i < encParams.Length; i++)
{
paramInfo.Append("Param " + i + " holds " + encParams[i].NumberOfValues +
" items of type " +
encParams[i].ValueType + "\r\n" + "Guid category: " + encParams[i].Encoder.Guid + "\r\n");
}
e.Graphics.DrawString(paramInfo.ToString(), this.Font, Brushes.Red, 10.0F, 10.0F);
}
private ImageCodecInfo GetEncoder(ImageFormat format)
{
ImageCodecInfo[] codecs = ImageCodecInfo.GetImageDecoders();
foreach (ImageCodecInfo codec in codecs)
{
if (codec.FormatID == format.Guid)
{
return codec;
}
}
return null;
}
Компиляция кода
Для этого примера требуются следующие компоненты.
Приложение Windows Forms.
Объект PaintEventArgs, являющийся параметром PaintEventHandler.
См. также
Задачи
Практическое руководство. Получение списка установленных кодировщиков
Основные понятия
Другие ресурсы
Применение кодировщиков и декодеров изображений в управляемом GDI+