Skip to content

Commit

Permalink
GR: Draw all gridlines before axis (JuliaPlots#4945)
Browse files Browse the repository at this point in the history
Separates grid drawing from the remainder of gr_draw_axis, so that all
gridlines are drawn below the axis. Previously, y-axis gridlines were
drawn after the x-axis and could overlap it.

Fixes issue JuliaPlots#4202 for GR.
  • Loading branch information
dd0 authored Jul 13, 2024
1 parent fd6eaa3 commit 8b9bcf2
Showing 1 changed file with 28 additions and 4 deletions.
32 changes: 28 additions & 4 deletions src/backends/gr.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1407,26 +1407,52 @@ function gr_draw_axes(sp, vp)
x_bg, y_bg = RecipesPipeline.unzip(GR.wc3towc.(area_x, area_y, area_z))
GR.fillarea(x_bg, y_bg)

foreach(letter -> gr_draw_axis_minorgrid_3d(sp, letter, vp), (:x, :y, :z))
foreach(letter -> gr_draw_axis_grid_3d(sp, letter, vp), (:x, :y, :z))
foreach(letter -> gr_draw_axis_3d(sp, letter, vp), (:x, :y, :z))
elseif ispolar(sp)
r = gr_set_viewport_polar(vp)
# rmin, rmax = GR.adjustrange(ignorenan_minimum(r), ignorenan_maximum(r))
rmin, rmax = axis_limits(sp, :y)
gr_polaraxes(rmin, rmax, sp)
elseif sp[:framestyle] !== :none
foreach(letter -> gr_draw_axis_minorgrid(sp, letter, vp), (:x, :y))
foreach(letter -> gr_draw_axis_grid(sp, letter, vp), (:x, :y))
foreach(letter -> gr_draw_axis(sp, letter, vp), (:x, :y))
end
GR.settransparency(1.0)
nothing
end

function gr_draw_axis_minorgrid_3d(sp, letter, vp)
ax = axis_drawing_info_3d(sp, letter)
axis = sp[get_attr_symbol(letter, :axis)]
gr_draw_minorgrid(sp, axis, ax.minorgrid_segments, gr_polyline3d)
end

function gr_draw_axis_grid_3d(sp, letter, vp)
ax = axis_drawing_info_3d(sp, letter)
axis = sp[get_attr_symbol(letter, :axis)]
gr_draw_grid(sp, axis, ax.grid_segments, gr_polyline3d)
end

function gr_draw_axis_minorgrid(sp, letter, vp)
ax = axis_drawing_info(sp, letter)
axis = sp[get_attr_symbol(letter, :axis)]
gr_draw_minorgrid(sp, axis, ax.minorgrid_segments)
end

function gr_draw_axis_grid(sp, letter, vp)
ax = axis_drawing_info(sp, letter)
axis = sp[get_attr_symbol(letter, :axis)]
gr_draw_grid(sp, axis, ax.grid_segments)
end

function gr_draw_axis(sp, letter, vp)
ax = axis_drawing_info(sp, letter)
axis = sp[get_attr_symbol(letter, :axis)]

# draw segments
gr_draw_grid(sp, axis, ax.grid_segments)
gr_draw_minorgrid(sp, axis, ax.minorgrid_segments)
gr_draw_spine(sp, axis, ax.segments)
gr_draw_border(sp, axis, ax.border_segments)
gr_draw_ticks(sp, axis, ax.tick_segments)
Expand All @@ -1442,8 +1468,6 @@ function gr_draw_axis_3d(sp, letter, vp)
axis = sp[get_attr_symbol(letter, :axis)]

# draw segments
gr_draw_grid(sp, axis, ax.grid_segments, gr_polyline3d)
gr_draw_minorgrid(sp, axis, ax.minorgrid_segments, gr_polyline3d)
gr_draw_spine(sp, axis, ax.segments, gr_polyline3d)
gr_draw_border(sp, axis, ax.border_segments, gr_polyline3d)
gr_draw_ticks(sp, axis, ax.tick_segments, gr_polyline3d)
Expand Down

0 comments on commit 8b9bcf2

Please sign in to comment.