2

我正在使用 CamanJS,除了对比度之外,效果都很好。我不知道为什么,但它搞砸了图像。

这是我的 HTML 和 JavaScript,这里还有一个 jsFiddle 示例:http: //jsfiddle.net/6sE2x/

      <div id="Content">
            <div class="row" style="margin:0 auto;text-align:center">
                <img id="camanImage"      src="" />
            </div>
            <hr />
            <div id="Filters">
                <table style="width:100%">
                    <tr class="Filter">
                        <td class="FilterName" style="width:20%">
                            <label>Brightness:</label>
                        </td>
                        <td class="FilterSetting" style="width:60%">
                            <input type="range" min="-100" max="100" step="1" value="0" data-filter="brightness">
                        </td>
                        <td class="FilterValue" style="width:20%;padding-left:5%">
                           <label>0</label>
                        </td>
                    </tr>
                    <tr class="Filter">
                        <td class="FilterName" style="width:20%">
                            <label>Contrast:</label>
                        </td>
                        <td class="FilterSetting" style="width:60%">
                            <input type="range" min="-100" max="100" step="1" value="0" data-filter="contrast">
                        </td>
                        <td class="FilterValue" style="width:20%;padding-left:5%">
                            <label>0</label>
                        </td>
                    </tr>
                    <tr class="Filter">
                        <td class="FilterName" style="width:20%">
                            <label>Sharpen:</label>
                        </td>
                        <td class="FilterSetting" style="width:60%">
                            <input type="range" min="-100" max="100" step="1" value="0" data-filter="sharpen">
                        </td>
                        <td class="FilterValue" style="width:20%;padding-left:5%">
                            <label>0</label>
                        </td>
                    </tr>
                </table>
            </div>
        </div>    

  var filters = []; 
   $(function () {

            $(".FilterSetting input").each(function () {
                filters.push({
                    "name": $(this).data("filter"),
                    "value": $(this).val()
                });
            });
            $("#Filters").on("mouseup", ".FilterSetting input", function () {
                var filter = $(this).data("filter");
                var value = $(this).val();
                      $(this).parent().parent().find(".FilterValue").children("label").html(value);
                for (var i = 0; i < filters.length; i++) {
                    if (filters[i].name == filter) {
                        filters[i].value = value;

                    }
                }
                changeImageFeatures();
            });
        });

   function changeImageFeatures() {
        var brightnessValue = filters[0].value;
        var contrastValue = filters[1].value;
        var sharpenValue = filters[2].value;

        Caman("#camanImage", function () {
            this.revert(false);

                this.brightness(brightnessValue);


                this.contrast(contrastValue);


                this.sharpen(sharpenValue);

            this.render();
        });
        Caman.Event.listen(Caman("#camanImage"), "processComplete", function (job) {
            console.log("Finished:", job.name);
        });
    }
4

1 回答 1

1

正如 Ömer Akyol 评论的那样,只需将您的值解析为整数。为我工作。

parseInt(contrastValue);
于 2015-07-09T13:42:01.590 回答