mirror of
https://github.com/mattrberry/crab.git
synced 2025-01-27 19:58:12 +01:00
memes?
This commit is contained in:
parent
71dba46e8b
commit
5d3f3bcac7
1 changed files with 63 additions and 36 deletions
|
@ -324,7 +324,19 @@ module GBA
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def bgr16_from_color(color : Color) : BGR16
|
||||||
|
BGR16.new(@pram, color)
|
||||||
|
end
|
||||||
|
|
||||||
|
@fresh_log = true
|
||||||
|
|
||||||
def calculate_color(col : Int) : UInt16
|
def calculate_color(col : Int) : UInt16
|
||||||
|
log = @vcount == 50 && 60 < col < 180
|
||||||
|
if log && @fresh_log
|
||||||
|
puts "\n\n\n\n LOG \n\n\n\n"
|
||||||
|
@fresh_log = false
|
||||||
|
end
|
||||||
|
@fresh_log = true if !log
|
||||||
enable_flags, effects_enabled = get_enables(col)
|
enable_flags, effects_enabled = get_enables(col)
|
||||||
top_color = nil
|
top_color = nil
|
||||||
colors = uninitialized Color[5]
|
colors = uninitialized Color[5]
|
||||||
|
@ -345,47 +357,55 @@ module GBA
|
||||||
false, # not a sprite
|
false, # not a sprite
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
blending_mode = @bldcnt.blending_mode
|
||||||
4.times do |priority|
|
4.times do |priority|
|
||||||
colors.each do |color|
|
colors.each do |color|
|
||||||
if bit?(enable_flags, color.target_bit) # check that layer is enabled
|
if bit?(enable_flags, color.target_bit) && color.priority == priority # check that layer is enabled and priorities match
|
||||||
if color.priority == priority # check that priority matches (effectively orders backgrounds)
|
if top_color.nil?
|
||||||
if top_color.nil?
|
if color.palette > 0
|
||||||
if color.palette > 0 # check that color is opaque
|
if !effects_enabled || !color.blends # if effects are disabled, always take the first opaque color
|
||||||
if !effects_enabled || !color.blends # if effects are disabled, always take the first opaque color
|
return bgr16_from_color(color).value
|
||||||
return BGR16.new(@pram, color).value
|
elsif @bldcnt.is_bg_target(color.target_bit, target: 1)
|
||||||
elsif @bldcnt.is_bg_target(color.target_bit, target: 1)
|
if color.sprite || blending_mode == 1 # pass along to blending routine
|
||||||
top_color = color
|
top_color = color
|
||||||
|
elsif blending_mode == 0 # don't blend
|
||||||
|
return bgr16_from_color(color).value
|
||||||
|
elsif blending_mode == 2 # blend with white
|
||||||
|
|
||||||
|
else # blend with black
|
||||||
end
|
end
|
||||||
|
else # pixel is not a blending target
|
||||||
|
return bgr16_from_color(color).value # todo: condense with previous condition
|
||||||
end
|
end
|
||||||
else # top color has been selected
|
end
|
||||||
top_color_u16 = BGR16.new(@pram, top_color).value
|
else # top color has been selected
|
||||||
if !@bldcnt.is_bg_target(color.target_bit, target: 2) # second layer isn't set in bldcnt, don't blend
|
top_color_u16 = bgr16_from_color(top_color).value
|
||||||
|
if !@bldcnt.is_bg_target(color.target_bit, target: 2) # second layer isn't set in bldcnt, don't blend
|
||||||
|
return top_color_u16
|
||||||
|
elsif color.palette > 0 # is a target and color is opaque
|
||||||
|
if blending_mode == 1 || top_color.sprite
|
||||||
|
return (bgr16_from_color(top_color) * (Math.min(16, @bldalpha.eva_coefficient) / 16) +
|
||||||
|
bgr16_from_color(color) * (Math.min(16, @bldalpha.evb_coefficient) / 16)).value
|
||||||
|
elsif blending_mode == 0
|
||||||
return top_color_u16
|
return top_color_u16
|
||||||
elsif color.palette > 0 # is a target and color is opaque
|
elsif blending_mode == 2 # blend with white
|
||||||
if @bldcnt.blending_mode == 1 || top_color.sprite
|
bgr16 = bgr16_from_color(top_color)
|
||||||
return (BGR16.new(@pram, top_color) * (Math.min(16, @bldalpha.eva_coefficient) / 16) +
|
return (bgr16 + (BGR16.new(0xFFFF) - bgr16) * (Math.min(16, @bldy.evy_coefficient) / 16)).value
|
||||||
BGR16.new(@pram, color) * (Math.min(16, @bldalpha.evb_coefficient) / 16)).value
|
elsif blending_mode == 3 # blend with black
|
||||||
elsif @bldcnt.blending_mode == 0
|
bgr16 = bgr16_from_color(top_color)
|
||||||
return top_color_u16
|
return (bgr16 - bgr16 * (Math.min(16, @bldy.evy_coefficient) / 16)).value
|
||||||
elsif @bldcnt.blending_mode == 2
|
end
|
||||||
# blend with white
|
elsif top_color.sprite # is a target and color is transparent
|
||||||
return top_color_u16 # todo
|
if blending_mode == 0
|
||||||
elsif @bldcnt.blending_mode == 3
|
return top_color_u16
|
||||||
# blend with black
|
elsif blending_mode == 1
|
||||||
return top_color_u16 # todo
|
return top_color_u16
|
||||||
end
|
elsif blending_mode == 2 # blend with white
|
||||||
else # is a target and color is transparent
|
bgr16 = bgr16_from_color(top_color)
|
||||||
if @bldcnt.blending_mode == 0
|
return (bgr16 + (BGR16.new(0xFFFF) - bgr16) * (Math.min(16, @bldy.evy_coefficient) / 16)).value
|
||||||
return top_color_u16
|
elsif blending_mode == 3 # blend with black
|
||||||
elsif @bldcnt.blending_mode == 1
|
bgr16 = bgr16_from_color(top_color)
|
||||||
return top_color_u16
|
return (bgr16 - bgr16 * (Math.min(16, @bldy.evy_coefficient) / 16)).value
|
||||||
elsif @bldcnt.blending_mode == 2
|
|
||||||
# blend with white
|
|
||||||
return top_color_u16 # todo
|
|
||||||
elsif @bldcnt.blending_mode == 3
|
|
||||||
# blend with black
|
|
||||||
return top_color_u16 # todo
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -393,7 +413,14 @@ module GBA
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
backdrop_color = @pram.to_unsafe.as(UInt16*)[0]
|
backdrop_color = @pram.to_unsafe.as(UInt16*)[0]
|
||||||
return top_color.nil? ? backdrop_color : BGR16.new(@pram, top_color).value
|
if log
|
||||||
|
if top_color.nil?
|
||||||
|
puts "No top color, returning backdrop"
|
||||||
|
else
|
||||||
|
puts " Didn't find second layer, returning top color"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return top_color.nil? ? backdrop_color : bgr16_from_color(top_color).value
|
||||||
|
|
||||||
4.times do |priority|
|
4.times do |priority|
|
||||||
if bit?(enable_flags, 4)
|
if bit?(enable_flags, 4)
|
||||||
|
|
Loading…
Add table
Reference in a new issue