zoukankan      html  css  js  c++  java
  • 解决ecshop缩略图以及产品页图模糊的方法

     


     ecshop上传商品图片默认生成jpg缩略图或商品图的质量是80,这些图片看起来有点模糊,客户非常不满意,现提供调整生成jpg图片的质量,解决Ecshop商品缩略图不清晰的方法。

    找到includes/cls_image.php文件,在大约250行
           /* 生成文件 */
           if (function_exists(‘imagejpeg’))
           {
             $filename .= ‘.jpg’;
             imagejpeg($img_thumb, $dir . $filename);
           }
           改为
           /* 生成文件 */
           if (function_exists(‘imagejpeg’))
           {
             $filename .= ‘.jpg’;
             imagejpeg($img_thumb, $dir . $filename, 96);
           }
           这样应该足够清晰了,这里允许0-100的范围,不写默认是80的质量。修改后图像质量有所提高,但和原图还有区别,

    还要修改admin/goods.php 文件,大约在613行:


            // 如果系统支持GD,缩放商品图片,且给商品图片和相册图片加水印
            if ($proc_thumb && $image->gd_version() > 0 && $image->check_img_function($_FILES['goods_img']['type']))
            {
                // 如果设置大小不为0,缩放图片
                if ($_CFG['image_width'] != 0 || $_CFG['image_height'] != 0)
                {
                    $goods_img = $image->make_thumb(‘../’. $goods_img , $GLOBALS['_CFG']['image_width'],  $GLOBALS['_CFG']['image_height']);
                    if ($goods_img === false)
                    {
                        sys_msg($image->error_msg(), 1, array(), false);
                    }
                }

           改为:


    // 如果系统支持GD,缩放商品图片,且给商品图片和相册图片加水印
            if ($image->gd_version() > 0 && $image->check_img_function($_FILES['goods_img']['type']) &&$_FILES['goods_img']['width'] > $GLOBALS['_CFG']['image_width'] &&$_FILES['goods_img']['height'] > $GLOBALS['_CFG']['image_height'])
            {
                // 如果设置大小不为0,缩放图片
                if ($_CFG['image_width'] != 0 || $_CFG['image_height'] != 0)
                {
                    $goods_img = $image->make_thumb(‘../’. $goods_img , $GLOBALS['_CFG']['image_width'], $GLOBALS['_CFG']['image_height']);
                    if ($goods_img === false)
                    {
                        sys_msg($image->error_msg(), 1, array(), false);
                    }
                }


            同时到后台,系统设置-》商店设置-》显示设置:把商品图片宽度,高度设置成一样,图像质量就不会变化了。
            产品页第一张图片模糊的问题主要是由后台开启了上传商品自动生成相册图功能引起的。商店设置--显示设置里面有一项  上传商品是否自动生成相册图: 这个选项默认是打开的,也就是默认是选择 是 ;这样的话您在上传商品图片时就在商品相册里面自动生成一张相册图片(跟你上传的原图是同一张图,只是图片质量不同而已);选择否的话在商品相册里面就不生成此图,如果该商品有商品相册图片,那需要您单独上传;如果您不单独上传商品相册图(且将上传商品是否自动生成相册图:设置为否),那么在模版中系统就认为此商品没有商品相册,(实际确实是没有,因为默认生成的开关你关了而且你有没单独上传相册图,哪儿来的相册图了?)所以商品相册模块就不显示!所以在后台 商店设置--显示设置里面 上传商品是否自动生成相册图: 设置为否; 然后单独上传上传图片就可以解决商品第一张图片模糊的问题。
            另一种解决产品页第一张图片模糊的问题的方法是修改代码,用原始图替代这张缩略图来显示。在模板文件夹下的goods.dwt文件,找到


    <div class="good_img">
                            <a href="javascript:;" onclick="window.open('gallery.php?id={$goods.goods_id}'); return false;" >
          <img src="{$goods.goods_img}" alt="{$goods.goods_name|escape:html}" id="goodsimg" style="340px;" />
                            </a>
                            </div>

           改成
    <div class="good_img">
                            <a href="javascript:;" onclick="window.open('gallery.php?id={$goods.goods_id}'); return false;" >
          <img src="{$goods.original_img}" alt="{$goods.goods_name|escape:html}" id="goodsimg" style="340px;" />
                            </a>
                            </div>
           这样产品页第一张图片模糊问题可以解决了。
     

  • 相关阅读:
    JavaScript中trim 方法实现
    面向对象设计的SOLID原则
    对项目的了解差点儿为零?怎样高速上手一个新项目
    计算一个序列的移动平均线序列的模板,可实现均线的均线
    HTML5学习笔记简明版(10):废弃的元素和属性
    Using Swift with Cocoa and Objective-C下载
    实战Java虚拟机之中的一个“堆溢出处理”
    Delphi导出数据的多种方法
    Delphi+DBGrid导出Excel
    delphi try except语句 和 try finally语句用法以及区别
  • 原文地址:https://www.cnblogs.com/helloyb/p/2918808.html
Copyright © 2011-2022 走看看