我正在使用 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);
});
}