Blame view

node_modules/stylus/lib/functions/blend.js 896 Bytes
ce4c83ff   wxy   初始提交
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
  var utils = require('../utils')
    , nodes = require('../nodes');
  
  /**
   * Blend the `top` color over the `bottom`
   *
   * Examples:
   *
   *     blend(rgba(#FFF, 0.5), #000)
   *     // => #808080
   * 
   *     blend(rgba(#FFDE00,.42), #19C261)
   *     // => #7ace38
   * 
   *     blend(rgba(lime, 0.5), rgba(red, 0.25))
   *     // => rgba(128,128,0,0.625)
   *
   * @param {RGBA|HSLA} top
   * @param {RGBA|HSLA} [bottom=#fff]
   * @return {RGBA}
   * @api public
   */
  
  module.exports = function blend(top, bottom){
    // TODO: different blend modes like overlay etc.
    utils.assertColor(top);
    top = top.rgba;
    bottom = bottom || new nodes.RGBA(255, 255, 255, 1);
    utils.assertColor(bottom);
    bottom = bottom.rgba;
  
    return new nodes.RGBA(
      top.r * top.a + bottom.r * (1 - top.a),
      top.g * top.a + bottom.g * (1 - top.a),
      top.b * top.a + bottom.b * (1 - top.a),
      top.a + bottom.a - top.a * bottom.a);
  };