cwebp
名称

cwebp -压缩图像文件为的WebP文件
概要

cwebp [选项] INPUT_FILE -o output_file.webp
描述

cwebp压缩使用的WebP格式的图像。输入格式可以是PNG,JPEG,TIFF的WebP或生在Y'CbCr样品。
选项

基本的选项是:

-o串

指定输出的WebP文件的名称。如果省略,cwebp将进行压缩,但只报告统计数据。使用“ - ”作为输出名称将直接输出到“标准输出”。
- 字符串

显式地指定输入文件。如果输入的文件与启动此选项很有用“ - ”号实例。此选项必须出现最后。任何其他选项以后将被忽略。
-h,-help

一个简短的使用说明。
-H,-longhelp

所有可能的选项的摘要。
-版

打印的版本号(如major.minor.revision)并退出。
-q浮动

指定之间RGB通道的压缩系数0和100。默认值是75。

在有损压缩(默认)的情况下,一个小的因子产生具有较低质量的更小的文件。最好的质量是通过使用一个值达到100。

在无损压缩(由指定的情况下-lossless选项),一个小的因子能更快的压缩速度,但产生较大的文件。最大压缩是通过使用一个值达到100。
-alpha_q INT

指定之间阿尔法压缩的压缩系数0和 100。阿尔法无损压缩是使用的值达到100,而较低的值导致一个有损压缩。默认值是 100。
-f INT

指定去块效应滤波器的实力,与0(无过滤)和100(最大滤波)。值为0将关闭任何过滤。较高的值将增加图像解码之后施加的滤波处理的强度。该值越高,画面将出现在更顺畅。典型值通常的范围20至50。
-PRESET串

指定一组预先定义的参数,以适应特定类型的源材料。可能的值有:默认情况下,照片,图片, 绘图,图标,文本。

由于-PRESET覆盖其他参数值(除-q 之一),这个选项最好先出现在参数的顺序。
-sns INT

指定空间噪声整形的幅度。空间噪声整形(或简称为SNS)是指用于决定该图像的区域应使用相对较少的位的内置算法的一般集合,并且其中别的更好传送这些比特。可能的范围内变为 0(算法是关闭的)到100(最大效果)。默认值是 80。
-m INT

指定要使用的压缩方法。此参数控制了编码速度和压缩文件大小和质量之间的平衡。可能值的范围从0到6。默认值为4。当使用较高的值,编码器将花费更多的时间检查额外的编码可能性,并决定质量增益。较低的值可能会导致在较大的文件大小和较低的压缩质量为代价更快的处理时间。
-jpeg_like

改变内部参数映射,以更好地匹配JPEG压缩的预期大小。这个标志通常会产生类似大小的输出文件以它的JPEG当量(对于相同-q设置),但具有更少视觉失真。
-公吨

如果可能的话使用多线程编码。与透明通道源使用有损压缩时,此选项才有效。
-记忆不足

通过保存压缩后大小的四倍(典型值)减少有损编码的内存使用情况。这将使得在编码慢和输出的大小和失真略有不同。此标志仅方法3和建立有效的,并且默认是关闭的。注意,离开这个标志关闭将对比特流一些副作用:它迫使某些位流的功能,如分区(强制的号码1)。需要注意的是比特流大小的更详细的报告是由打印cwebp使用此选项时。
-af

开启自动过滤。这个算法将花费额外的时间优化滤波强度以达到良好的平衡质量。

其他选项

更高级的选项有:

-sharpness INT

指定过滤的锐度(如果使用的话)。范围为0(锐度)到7(最锐利)。默认值为0。
-strong

使用强过滤(如过滤被用来感谢-f 选项)。强大的过滤功能默认是开启的。
-nostrong

禁用强滤波(如果滤波被用来感谢-f 选项),并使用简单的过滤来代替。
-segments INT

改变的分区数的SNS算法的分割过程中使用。段应在范围1至4。默认值为4。此选项对方法第3及以上没有影响,除非-low_memory使用。
-partition_limit INT

通过限制由一些宏块中使用的比特数降低质量。范围为0(无降解,默认值)到100(完全降解)。有用的数值通常大约是30 - 70中度高画质图像。在VP8格式中,所谓的控制分区具有512K的一个限制,用于存储以下信息:该宏块是否被跳过,它所属的段,它是否被编码为内4×4或内16×16模式,并且最后的预测模式,以用于每个子块。对于一个非常大的图象,512k的仅留下了空间,以每16×16宏块少的比特。绝对最小是每宏块4位。跳过,段,和模式信息最多可以使用几乎所有的这些4位(虽然壳体是不大可能的),这对于非常大的图像问题。所述partition_limit因子控制的频率最比特昂贵模式(内4×4)将被使用。这是有用的情况下达到了512K限制,并显示以下信息:错误代码:6(PARTITION0_OVERFLOW:分区#0太大,以适应512K)。如果使用 -partition_limit不足以满足512k的约束,应该以每宏块节省更多的头比特使用更少的段。见-segments选项。
-size INT

指定目标大小(以字节为单位),以试图达到的压缩输出。压缩机将进行部分编码的几通,以获得尽可能接近这一目标。
-psnr浮动

指定目标PSNR(单位为dB),试图达到的压缩输出。压缩机将进行部分编码的几通,以获得尽可能接近这一目标。
-pass INT

设置的推移选项一起使用二分法期间使用的最大数量 -size或-psnr。最大值是10。
调整大小宽高

调整源与大小的矩形宽度点¯x 高度。如果(但不是两者)的宽度或高度的参数是0,值将保持纵横比来计算。
-crop x_position y_position宽度高度

裁剪源在坐标与左上角的矩形(x_position,y_position),大小宽点¯x 高度。这复种面积必须在源矩形中完全包含。
-s宽度高度

指定输入文件实际上是由继ITU-R BT.601推荐生在Y'CbCr样品,在4:2:0线性格式。亮度平面大小为宽点¯x 高度。
-Map INT

输出附加ASCII地图编码信息。可能映射值的范围是1至6。这只是为了帮助调试。
-pre INT

指定一些预处理步骤。使用值2将触发RGBA-在质量相关的伪随机抖动> YUVA转换(仅适用于有损压缩)。
-alpha_filter串

指定阿尔法飞机的预测滤波方法。一个 没有,快或最好,在日益复杂和缓慢秩序。默认为快。在内部,阿尔法过滤是使用四种可能的预测(无,水平,垂直梯度)进行。的最佳 模式将尝试依次在每个模式并挑选一个这使较小的大小。在快速模式将只是试图形成一个先验的猜测没有测试所有的模式。
-alpha_method INT

指定用于阿尔法压缩算法:0或1。算法 0表示不压缩,1使用的WebP无损格式进行压缩。默认值是1。
-alpha_cleanup

修改看不见的RGB值下的全透明区域,以帮助压缩。默认是关闭的。
-blend_alpha INT

这个选项共混alpha通道(如果存在)用十六进制作为为0xRRGGBB指定背景颜色的来源。Alpha通道之后被重置为不透明值255。
-noalpha

使用此选项将丢弃Alpha通道。
-lossless

编码图像而没有任何损失。
-hint串

指定有关输入图像类型的提示。可能的值有:照片, 图片或图形。
- 元数据串

逗号分隔的元数据的列表中,如果存在从输入复制到输出。有效值:全部,无,EXIF,ICC,XMP。默认为无。

请注意,每个输入格式可能不支持所有组合。
-noasm

禁用所有组件的优化。
-v

打印额外的信息(尤其是编码时间)。
-print_psnr

计算并报告平均PSNR(峰信噪比)。
-print_ssim

计算并报告平均SSIM(结构相似度指标,请参阅 http://en.wikipedia.org/wiki/SSIM了解更多详细信息)。
-print_lsim

计算并报告当地的相似性指标(最小误差之和并置的像素邻居之间)。
-quiet

不打印任何东西。
例子

cwebp -q 50 -lossless picture.png -o picture_lossless.webp<br>
cwebp -q 70 picture_with_alpha.png -o picture_with_alpha.webp<br>
cwebp -sns 70 -f 50 -size 60000 picture.png -o picture.webp<br>
cwebp -o picture.webp -- ---picture.png

 
标签: <无>
 

代码片段(1)[全屏查看所有代码]

1. [代码][PHP]代码     跳至 [1] [全屏预览]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
<?php
/**
 * Created by PhpStorm.
 * User: liuft
 * Date: 2016/1/22
 * Time: 11:51
 */
 
date_default_timezone_set('PRC');
 
 
/**
 * jpg压缩成webp格式
 * @param string $dir [webp图片的存储路径]
 * @param int $n [压缩图片的张数]
 * @param int $prefix [图片名称的后缀]
 * @param int $type [裁剪图片的类型]
 */
function start_multi_jpg_transform_webp($dir = '', $n = 1, $prefix = '_a', $type = 6)
{
    global $jpg_dir;
    if (!is_dir($dir)) {
        mkdir($dir, 0755);
        chmod($dir, 0755);
    }
    if (strrchr($jpg_dir, '/') != '/') {
 
        $jpg_dir = $jpg_dir . '/';
    }
    if (strrchr($dir, '/') != '/') {
 
        $dir = $dir . '/';
    }
    for ($j = 1; $j <= $n; $j++) {
        $file_name = $jpg_dir . $j . '.jpg';//要裁剪的图片
        $new_jpg_path = $dir . $j . '_' . $prefix;//新的图片路径
        createImg($file_name, $new_jpg_path . '.jpg', $type, 0);//裁剪生成jpg图片
        //生成webp格式的图片
        $new_q = 0;
        $m = 0;
        for ($i = 11; $i <= 18; ++$i) {
            $m = $i * 5;
            $m_q = $m / 100;//新的压缩百分比
            $q = get_img_quality($new_jpg_path . '.jpg');//原图的质量
            $new_q = $q * $m_q;//新的图片质量
            //开始压缩
            do_jpg_transform_webp($new_jpg_path . '.jpg', $new_jpg_path . '_' . $m . '.webp', $new_q);
        }
    }
}
 
 
/**
 * @param $jpg_file_name_path [jpg图片的路径]
 * @param string $new_jpg_filename_path [裁剪后jpg图片路径,不设置会将默认的jpg图片覆盖]
 * @param bool $type [裁剪图片类型]
 * @param int $is_compression
 */
function createImg($jpg_file_name_path, $new_jpg_filename_path = '', $type = false, $is_compression = 0)
{
    $resource = new Imagick($jpg_file_name_path);
    if ($type) {
        try {
            $size = $resource->getImageGeometry();
            if ($size['width'] > $size['height']) {
                $left = round(($size['width'] - $size['height']) / 2);
                $resource->cropImage($size['height'], $size['height'], $left, 0);
            } else if ($size['width'] < $size['height']) {
 
                $top = round(($size['height'] - $size['width']) / 2);
                $resource->cropImage($size['width'], $size['width'], 0, $top);
            }
 
            if ($type == 1) {
                $resource->resizeImage(210, 210, Imagick::FILTER_CATROM, 1.0, true);
            } elseif ($type == 2) {
                $resource->resizeImage(720, 268, Imagick::FILTER_CATROM, 1.0, true);
            } elseif ($type == 3) {
                $resource->resizeImage(298, 198, Imagick::FILTER_CATROM, 1.0, true);
            } elseif ($type == 4) {
                $resource->resizeImage(338, 365, Imagick::FILTER_CATROM, 1.0, true);
            } elseif ($type == 5) {
                $resource->resizeImage(425, 425, Imagick::FILTER_CATROM, 1.0, true);
            } elseif ($type == 6) {
                $resource->resizeImage(150, 150, Imagick::FILTER_CATROM, 1.0, true);
            } elseif ($type == 7) {
                $resource->resizeImage(640, 640, Imagick::FILTER_CATROM, 1.0, true);
            } elseif ($type == 8) {
                $resource->resizeImage(32, 32, Imagick::FILTER_CATROM, 1.0, true);
            }
        } catch (Exception $e) {
            echo $e->getMessage();
            exit;
        }
    }
 
    $resource->setImageCompression(Imagick::COMPRESSION_JPEG);
    $current = $resource->getImageCompressionQuality();
    if ($is_compression) {
        $resource->setImageCompressionQuality($current);//压缩质量
    }
    if (!empty($new_jpg_filename_path)) {
        $jpg_file_name_path = $new_jpg_filename_path;
    }
    $resource->writeImage($jpg_file_name_path);
    $resource->clear();
    $resource->destroy();
 
 
}
 
/**
 * jpg格式转换成webp格式
 * @param $jpg_img_path [jpg图片的真实路径]
 * @param $webp_img_path [webp图片的真实路径]
 * @param int $q [图片的压缩质量]
 */
function do_jpg_transform_webp($jpg_img_path, $webp_img_path, $q = 65)
{
    exec("cwebp -q {$q} {$jpg_img_path} -o $webp_img_path");
}
 
 
/**
 * 获取图片的质量
 * @param $fileName [图片的具体路径]
 * @return int[图片的质量]
 */
function get_img_quality($fileName)
{
    $resource = new Imagick($fileName);
    $resource->setImageCompression(Imagick::COMPRESSION_JPEG);
    $current = $resource->getImageCompressionQuality();
    $resource->clear();
    $resource->destroy();
    if (empty($current)) {
        $current = 65;
    }
    $resource->clear();
    $resource->destroy();
    return $current;
 
}
 
 
//调用方式
//原始图片,连续用数字命名 !如 1~10张图片,就1.jpg~10.jpg
$jpg_dir = './image/';//[准备压缩的jpg图片路径,必须设置!]
//压缩出webp格式的图片
start_multi_jpg_transform_webp('./webp', 1, '_a', 0);
start_multi_jpg_transform_webp('./webp1', 1, '_a', 1);
start_multi_jpg_transform_webp('./webp2', 1, '_a', 2);
start_multi_jpg_transform_webp('./webp3', 1, '_a', 3);

将jpg压缩成webp格式的图片的更多相关文章

  1. centos下 将(jgp、png)图片转换成webp格式

    由于项目要求需要将jpg.png类型的图片  转换成webp格式,最开始使用了php gd类库里 imagewebp 方法实现,结果发现转换成的webp格式文件会偶尔出现空白内容的情况.像创建了一个透 ...

  2. java实现将文件压缩成zip格式

    以下是将文件压缩成zip格式的工具类(复制后可以直接使用): zip4j.jar包下载地址:http://www.lingala.net/zip4j/download.php package util ...

  3. 火狐不支持webp格式的图片

    <!DOCTYPE html> <html lang="en"> <style> ul{list-style: none;} li{float: ...

  4. 在html中如何兼容使用WebP格式的图片【图片升级到WebP】

    把已有的图片转换为WebP格式 要使用WebP格式,需要将你网站用到的图片都制作一份WebP格式的版本,如果你使用CDN服务商,它们一般都会提供转码到WebP格式的选项.如又拍云: 增加这样的配置后, ...

  5. 批量将webp格式的图片转成png的图片 https://cn.office-converter.com/WEBP-to-PNG

    https://cn.office-converter.com/WEBP-to-PNG

  6. java转换图片压缩生成webp格式

    http://blog.csdn.net/xu_san_duo/article/details/79085718

  7. Linux下php+imagemagick支持webp格式的图片

    摘要 ImageMagick是一款功能强大的图片处理工具包,很多互联网应用中都会涉及到图片处理工作,比如切割.缩放.水印.格式转换等.ImageMagick就是一个理想的工具包. 安装基础依赖 先检查 ...

  8. python(49):把文件压缩成zip格式的文件

    有时需要用到压缩文件,网上搜集了一段代码: 分享一下: import os import zipfile def make_zip(localPath, pname): zipf = zipfile. ...

  9. 列出zip文件内全部内容 当前目录下的所有文件压缩成zip格式的文件(file.zip)

    [root@ok Desktop]# zip -r image.zip ./*.jpg adding: 20161007_113743.jpg (deflated 0%) adding: 201610 ...

随机推荐

  1. Servlet 网页重定向

    当文档移动到新的位置,我们需要向客户端发送这个新位置时,我们需要用到网页重定向.当然,也可能是为了负载均衡,或者只是为了简单的随机,这些情况都有可能用到网页重定向. 重定向请求到另一个网页的最简单的方 ...

  2. 撩课-Java每天5道面试题第23天

    146.什么是Spring MVC ?简单介绍下你对springMVC的理解? Spring MVC是一个基于MVC架构的 用来简化web应用程序开发的应用开发框架, 它是Spring的一个模块, 无 ...

  3. gRPC版本的 Google APIs

    gRPC将是未来google所有客户端的库标准(DevoxxFR), 这句话的出处: https://twitter.com/chanezon/status/585724143003402240    ...

  4. 开包即食的教程带你浅尝最新开源的C# Web引擎Blazor

    在今年年初,恰逢新春佳节临近的时候.微软给全球的C#开发者们,着实的送上了一分惊喜.微软正式开源Blazor,将.NET带回到浏览器.     这个小惊喜,迅速的在dotnet开发者中间传开了.201 ...

  5. 动态计算area位置

    window.onresize = adjuest; function adjuest(){ var picw = $(".imgbox img").width(); var pi ...

  6. js-权威指南学习笔记16

    1.元素的style属性可以用来设置样式,但是不适合用来查询样式(只能查询到内联样式). 2.CSS里的层叠指示了应用于文档中任何给定元素的样式规则是各个来源的层叠效果:Web浏览器的默认样式表.文档 ...

  7. Django基础五之django模型层(一)单表操作

    一 ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人 ...

  8. Django之WSGI浅谈

    一.什么是Web框架 框架,即framework,特指为解决一个开放性问题而设计的具有一定约束性的支撑结构,使用框架可以帮你快速开发特定的系统. 浏览器与服务器之间发起HTTP请求: 1.浏览器发送一 ...

  9. jquery3.0移除了.load()方法

    参考链接:新版jquery去掉load事件了吗? 今天也遇到了这个问题,查了一下文档,确实从3.0开始移除了load.unload.error事件方法.不过依然可以用on方法绑定这些事件. Break ...

  10. SwipeRefreshLayout的高度测量

    感谢此作者的分享 http://www.cnblogs.com/linjzong/p/5221604.html 若SwipeRefreshLayout的子布局为一个线性布局LinearLayout, ...