好程序员web前端培训分享用CSS和JS打造一个简单的图片编辑器

简介:   好程序员web前端培训分享用CSS和JS打造一个简单的图片编辑器,本文主要是利用CSS的 filter和简单的Jquery代码来实现一个简单的图片编辑器,包括对图片的透明度,黑白,图片亮度等调节。

  好程序员web前端培训分享用CSS和JS打造一个简单的图片编辑器,本文主要是利用CSS的 filter和简单的Jquery代码来实现一个简单的图片编辑器,包括对图片的透明度,黑白,图片亮度等调节。

  CSS filter

  我们首先来探讨一下filter。

  首先来说明一下filter,在CSS里面要实现filter,其实很简单,使用类似下面的声明方式:
  
1..example {
2.  filter: [];
3.  }

  
             比如说,我们给图片添加一点灰度(grayscale)特效,就可以这样:
1.  .example {
2.  filter: grayscale(90%);
3.  }

  当然,为了浏览器兼容,我们最好这样写:
1..example {
2.  -webkit-filter: grayscale(90%);
3.  filter: grayscale(90%);
4.  }

  需要注意的是:filter的属性值的单位通常可能是从0到1之间,但是有些不是这样的,比如blur是使用像素'px'来作为单位的,而hue-rotate则使用角度deg来作为基本单位;
1. .example {
2.  filter: blur(10px);
3.  }
4.  .example-2 {
5.  filter: hue-rotate(90deg);
6.  }

  但是如果每次只能使用一个filter就比较麻烦了,所以CSS提供了更加方便的书写形式,直接并排着写:
1. .example {
2.  filter: grayscale(0.5) blur(10px);
3.  }

  这样就可以实现对一个元素添加多个filter属性。

  简单地说完filter之后,我们来动手创建一个简单的图片编辑器。

  创建基本的HTML文件

  在这里我们创建一个index.html,代码也比较简单:
1. Image Editor
2.  Grayscale
3.  Blur
4.  Brightness
5.  Contrast
6.  Hue Rotate
7.  Opacity
8.  Invert
9.  Saturate
10.  Sepia

  这个文件里,我们引入了main.css和main.js,main.css其实是对编辑器的一些排版起的作用,并没有对图片的filter效果做出实际的影响,我们做的是编辑器,所以在用户改变某个filter的值的时候,我们可以实时让用户看到效果,于是这些实现filter的代码应该就放在main.js里面。

  上面的每一个

  下面的

  元素下面的input都是filter的一个属性设置,因为我们可以同时用多个filter来对图片产生特效,所以我每个filter的属性值都设置为可以调节的状态。

  上面的index.html还要说明的是,在最上面我们提供一个输入框,用于给用户输入图片的URL,当用户点击回车的时候,我们就将这张图片显示到编辑区域。使用的是下面的简单js代码:
1. function addImage(e) {
2.  var imgUrl = $("#imgUrl").val();
3.  if (imgUrl.length) {
4.  $("#imageContainer img").attr("src", imgUrl);
5.  }
6.  e.preventDefault();
7.  }
8.  //on pressing return, addImage() will be called
9.  $("#urlBox").submit(addImage);

  上面的js代码也是写到main.js当中。有了可以用户自己添加图片之后,我们就可以实现对图片的编辑了:

  每次用户在滑动进度条的时候,我们就可以将效果展示给用户看,于是我们来监听用户的mousemove事件:
1. $("input[type=range]").mousemove(editImage);

  也就是说,每次用户在移动控制条的时候,我们都执行editImage函数。

  但是这样的体验可能还不是最好,因为在最后用户的鼠标离开控制条的时候,我们还可以监听change事件,把这一刻的变化也交给editImage函数处理,所以可以将上面的代码写成这样:
1.font size="3">$("input[type=range]").mousemove(editImage).change(editImage);
2.  复制代码编写editImage函数
3.  上面我们将input[type=range]的mousemove和change事件交给了editImage函数处理,所以,我们来编写一下editImage的函数代码:
4.  function editImage() {
5.  var gs = $("#gs").val(); // grayscale
6.  var blur = $("#blur").val(); // blur
7.  var br = $("#br").val(); // brightness
8.  var ct = $("#ct").val(); // contrast
9.  var huer = $("#huer").val(); //hue-rotate
10.  var opacity = $("#opacity").val(); //opacity
11.  var invert = $("#invert").val(); //invert
12.  var saturate = $("#saturate").val(); //saturate
13.  var sepia = $("#sepia").val(); //sepia
14.  $("#imageContainer img").css("filter", 'grayscale(' + gs+
15.  '%) blur(' + blur +
16.  'px) brightness(' + br +
17.  '%) contrast(' + ct +
18.  '%) hue-rotate(' + huer +
19.  'deg) opacity(' + opacity +
20.  '%) invert(' + invert +
21.  '%) saturate(' + saturate +
22.  '%) sepia(' + sepia + '%)');
23.  $("#imageContainer img").css("-webkit-filter", 'grayscale(' + gs+
24.  '%) blur(' + blur +
25.  'px) brightness(' + br +
26.  '%) contrast(' + ct +
27.  '%) hue-rotate(' + huer +
28.  'deg) opacity(' + opacity +
29.  '%) invert(' + invert +
30.  '%) saturate(' + saturate +
31.  '%) sepia(' + sepia + '%)');
32.  }

  其实很简单,我们在每次用户滑动控制条的时候,我们就通过类似var gs = $("#gs").val();的语句取得相对应地值,然后通过Jquery的css()方法直接为图片加上filter效果,而且相信你也看得出来,这个函数的后半段就是实现浏览器兼容的
1. $("#imageContainer img").css("-webkit-filter",...)
2.  复制代码
3.  这段代码其实就是在img元素实现了类似下面的效果;
4.  
5.img=28,30

  最后,如果你不想将某些特效加到图片上面去,你可以点reset然后将图片重置到原始状态:
1.
2.  $('#imageEditor').on('reset', function () {

3.  setTimeout(function() {
4.  editImage();
5.  },0);
6.  });

  这里需要说明一下的是,这里的setTimeout函数就是为了将reset的效果最快地展现出来,如果写成下面的形式:
1.$('#imageEditor').on('reset', function () {
2.  editImage();
3.  });
 

  这个时候,reset效果执行起来其实是有一点延迟的,你明显可以看到等待的时候,它并不是很快。

  浏览器打开index.html,就可以看到相应的调节效果了。你可以拖动一些设置项的控制条来查看效果。

相关文章
|
6月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
伪类:伪类这个叫法源自于它们跟类相似,但实际上并没有类会附加到标记中的标签上。 伪类分为两种(以及新增的伪类选择器): UI伪类:会在HTML元素处于某种状态时(例如:鼠标指针位于连接上),为该元素应用CSS样式。 :hover 结构化伪类:会在标记中存在某种结构上的关系时 例如: 某元素是一组元素中的第一个或最后一个,为该元素应用CSS样式。 :not和:target(CSS3新增的两个特殊的伪类选择器)
634 2
|
6月前
|
前端开发 JavaScript 算法
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
transform变形 css3在原来的基础上新增了变形和动画相关属性,通过这些属性可以实现以前需要大段JavaScript才能实现的 功能。 CSS3的变形功能可以对HTML组件执行位移、旋转、缩放、倾斜4种几何变换,这样的变换可以控制HTML组件 呈现出丰富的外观。 借助于位移、旋转、缩放、倾斜这4种几何变换,CSS3提供了transition动画。 transition动画比较简单,只要指定HTML组件的哪些CSS属性需要使用动画效果来执行变化,并指定动画时间,就可保证动画播放。 比transitio
311 1
|
6月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
Flex 布局 布局的传统解决方案,基于盒状模型,依赖 display 属性 + position属性 + float属性。它对于那些特殊布局非常不方便,比如,垂直居中就不容易实现。 2009年,W3C 提出了一种新的方案----Flex 布局,可以简便、完整、响应式地实现各种页面布局。目前,它已经得到了所有浏览器的支持,这意味着,现在就能很安全地使用这项功能。 一、Flex 布局是什么? Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。
426 0
|
6月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
盒模型 盒模型: 所谓盒模型,就是浏览器为页面中的每个HTML元素生成的矩形盒子。 这些盒子们都要按照可见板式模型在页面上排布。 可见的板式模型主要由三个属性控制:position 属性、display 属性和 float属性。 position属性控制页面上元素间的位置关系。 display属性控制元素是堆叠、并排或者不在页面上显示。 float属性提供控制的方法,以便于把元素组成成多栏布局。 盒模型讲解: 在默认的情况下,每个盒子的边框是不可见的,背景也是透明的。 所以我们 不能直接的看到页面中的盒
787 1
|
6月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
Animation属性 css3为Animation动画提供的几个属性如下: 属性名 属性值 animation-name 指定动画名称,该属性指定一个已有的关键帧定义。 animation-duration 指定动画持续时间。 animation-timing-funtion 指定动画变化速度。 animation-delay 指定动画延迟多长时间才开始执行。 animation-iteration-count 指定动画的循环执行次数。 animation:这是一个复合属性。
421 3
|
6月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
position定位(核心) 我们讲盒模型的时候,提到了3个属性可以用来控制页面排版。 三大属性:position属性,display属性,float属性。 position 属性控制页面上元素间的位置关系。 display 属性控制页面元素是否显示或者是堆叠还是并排显示。 float 属性提供控制方法。 通过float这种控制方法,可以实现多栏布局,导航菜单等等。 position属性是干嘛用的?怎么用?有哪些属性值? position属性控制页面上元素间的位置关系,也就是排版。 怎么用?要知道怎么用
609 1
|
6月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
继承 我们的CSS中很多的属性也是可以继承的,其中相当一部分是跟文字的相关的,比如说颜色、字体、字号。 当然还有一部分是不能继承的。 例如边框、内外边距。 层叠 层叠是CSS的核心机制。 层叠的工作机制: 当元素的同一个样式属性有多种样式值的时候,CSS就是靠层叠机制来决定最终应用哪种样式。 层叠规则: 层叠规则一:找到应用给每个元素和属性的声明。 说明:浏览器在加载每个页面时,都会据此查找到每条CSS规则, 并标识出所有受到影响的HTML元素。
216 0
|
10月前
|
存储 前端开发 JavaScript
仿真银行app下载安装, 银行卡虚拟余额制作app,用html+css+js实现逼真娱乐工具
这是一个简单的银行账户模拟器项目,用于学习前端开发基础。用户可进行存款、取款操作,所有数据存储于浏览器内存中
|
12月前
|
前端开发 JavaScript 数据可视化
58K star!这个让网页动起来的JS库,前端工程师直呼真香!
Anime.js 是一款轻量级但功能强大的JavaScript动画引擎,它能够以最简单的方式为网页元素添加令人惊艳的动效。这个项目在GitHub上已经获得58,000+星标,被广泛应用于电商页面、数据可视化、游戏开发等场景。
441 8
|
JavaScript 前端开发

热门文章

最新文章