400 028 6601

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

JavaScript实现Ps滤镜效果的方法

这篇文章主要介绍了JavaScript实现Ps滤镜效果的方法,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。

创新互联是一家以重庆网站建设公司、网页设计、品牌设计、软件运维、成都网站营销、小程序App开发等移动开发为一体互联网公司。已累计为湿喷机等众行业中小客户提供优质的互联网建站和软件开发服务。

思路

其实非常非常赶单~
CSS3多了一个filter的属性,非常强大(兼容性一般)!
我们只要根据输入的值/滑块滑动的值来动态更改css中filter属性的值即可

filter

使用直接就这样

img {
    -webkit-filter: contrast(200%); /* Chrome, Safari, Opera */
    filter: contrast(200%) opacity(0.5) //要多少属性加多少;
}

开始操作

//html
     
  • //js //注册过滤器 function filter(type) { //获取滤镜类型关联的dom节点 //绑定change事件,还有回车按键事件 let ele = document.getElementById(type); let ele_val = document.getElementById(type + '-val'); //输入框输入值按下回车,把值更新到滑块上 ele_val.addEventListener('keyup',function(e){ if(e.keyCode == 13){ ele.value = ele_val.value; //同时更新滤镜效果 setCss(type, ele_val.value); } }) //滑块滑动的时候,把值更新在右边的输入框中 ele.addEventListener('change', function() { ele_val.value = ele.value; //同时更新滤镜效果 setCss(type, ele_val.value); }); }
    //html
    
    
    

    //选择文件 function fileSelect() { let img = document.getElementById('img'); document.getElementById('file').onchange = function() { var reader = new FileReader(); reader.onload = function(e) { img.src = e.target.result; } reader.readAsDataURL(this.files[0]); } }
    //更新css属性
    function setCss(type, val) {
      let img = document.getElementById('img');
      //已经存在某个滤镜,更改滤镜数值
      if (img.style.filter.indexOf(type) > -1) {
        //利用正则则出滤镜名称更改其值
        let reg = new RegExp("(?<=" + type + ")" + "\\(.*\\)", "g")
        img.style.filter = img.style.filter.replace(reg, function(match) { return `(${val/100})` });
      } else {
        //直接添加新滤镜
        img.style.filter += `${type}(${val/100})`
      }
    }

    注意

    由于这个demo只是随便写写,只是前几天用到这个filter属性感觉有点厉害,就拿来玩玩,文中的代码写得很丑,也没什么规范,只适用于‘写来玩玩’的范畴,一些输入验证,节流,参数的规范都没有做,见谅。
    本来还打算做一个导出使用滤镜后的照片的,用的html2canvas来截图导出,然后发现,它不支持!!!不支持这个css属性!!截出来的图是原图!这可是真的难受啊马飞,现在还没有解决方案,如果有大佬知道如何保存使用滤镜后的图片到本地的,请在评论区留下您的想法,非常感谢!

    辣鸡源码

    
    
    
    
      
      photoshop-web
    
    
    
      

    感谢你能够认真阅读完这篇文章,希望小编分享JavaScript实现Ps滤镜效果的方法内容对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,遇到问题就找创新互联,详细的解决方法等着你来学习!


    当前标题:JavaScript实现Ps滤镜效果的方法
    当前路径:http://www.bluegullmedia.com/article/gjohpp.html

    其他资讯

    让你的专属顾问为你服务

    0.4072s