176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
|
# File 'lib/psd/renderer/compose.rb', line 176
def soft_light(fg, bg, opacity)
return apply_opacity(fg, opacity) if fully_transparent?(bg)
return bg if fully_transparent?(fg)
mix_alpha, dst_alpha = calculate_alphas(fg, bg, opacity)
calculate_foreground = Proc.new do |b, f|
c1 = b * f >> 8
c2 = 255 - ((255 - b) * (255 - f) >> 8)
((255 - b) * c1 >> 8) + (b * c2 >> 8)
end
new_r = blend_channel(r(bg), calculate_foreground.call(r(bg), r(fg)), mix_alpha)
new_g = blend_channel(g(bg), calculate_foreground.call(g(bg), g(fg)), mix_alpha)
new_b = blend_channel(b(bg), calculate_foreground.call(b(bg), b(fg)), mix_alpha)
rgba(new_r, new_g, new_b, dst_alpha)
end
|