barLevel: Reverse direction in RTL
Rework drawing and calculations to reverse the bar direction when the bar is Right-to-Left. Part-of: <https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/2943>
This commit is contained in:
parent
ba46a1cf54
commit
c777425d39
@ -100,6 +100,7 @@ export const BarLevel = GObject.registerClass({
|
|||||||
let cr = this.get_context();
|
let cr = this.get_context();
|
||||||
let themeNode = this.get_theme_node();
|
let themeNode = this.get_theme_node();
|
||||||
let [width, height] = this.get_surface_size();
|
let [width, height] = this.get_surface_size();
|
||||||
|
const rtl = this.get_text_direction() === Clutter.TextDirection.RTL;
|
||||||
|
|
||||||
let barLevelHeight = themeNode.get_length('-barlevel-height');
|
let barLevelHeight = themeNode.get_length('-barlevel-height');
|
||||||
let barLevelBorderRadius = Math.min(width, barLevelHeight) / 2;
|
let barLevelBorderRadius = Math.min(width, barLevelHeight) / 2;
|
||||||
@ -126,20 +127,36 @@ export const BarLevel = GObject.registerClass({
|
|||||||
const TAU = Math.PI * 2;
|
const TAU = Math.PI * 2;
|
||||||
|
|
||||||
let endX = 0;
|
let endX = 0;
|
||||||
if (this._maxValue > 0)
|
if (this._maxValue > 0) {
|
||||||
endX = barLevelBorderRadius + (width - 2 * barLevelBorderRadius) * this._value / this._maxValue;
|
let progress = this._value / this._maxValue;
|
||||||
|
if (rtl)
|
||||||
|
progress = 1 - progress;
|
||||||
|
endX = barLevelBorderRadius + (width - 2 * barLevelBorderRadius) * progress;
|
||||||
|
}
|
||||||
|
|
||||||
|
let overdriveRatio = this._overdriveStart / this._maxValue;
|
||||||
|
if (rtl)
|
||||||
|
overdriveRatio = 1 - overdriveRatio;
|
||||||
|
let overdriveSeparatorX = barLevelBorderRadius + (width - 2 * barLevelBorderRadius) * overdriveRatio;
|
||||||
|
|
||||||
let overdriveSeparatorX = barLevelBorderRadius + (width - 2 * barLevelBorderRadius) * this._overdriveStart / this._maxValue;
|
|
||||||
let overdriveActive = this._overdriveStart !== this._maxValue;
|
let overdriveActive = this._overdriveStart !== this._maxValue;
|
||||||
let overdriveSeparatorWidth = 0;
|
let overdriveSeparatorWidth = 0;
|
||||||
if (overdriveActive)
|
if (overdriveActive)
|
||||||
overdriveSeparatorWidth = themeNode.get_length('-barlevel-overdrive-separator-width');
|
overdriveSeparatorWidth = themeNode.get_length('-barlevel-overdrive-separator-width');
|
||||||
|
|
||||||
|
let xcArcStart = barLevelBorderRadius + barLevelBorderWidth;
|
||||||
|
let xcArcEnd = width - xcArcStart;
|
||||||
|
if (rtl)
|
||||||
|
[xcArcStart, xcArcEnd] = [xcArcEnd, xcArcStart];
|
||||||
|
|
||||||
/* background bar */
|
/* background bar */
|
||||||
cr.arc(width - barLevelBorderRadius - barLevelBorderWidth, height / 2, barLevelBorderRadius, TAU * (3 / 4), TAU * (1 / 4));
|
if (!rtl)
|
||||||
|
cr.arc(xcArcEnd, height / 2, barLevelBorderRadius, TAU * (3 / 4), TAU * (1 / 4));
|
||||||
|
else
|
||||||
|
cr.arcNegative(xcArcEnd, height / 2, barLevelBorderRadius, TAU * (3 / 4), TAU * (1 / 4));
|
||||||
cr.lineTo(endX, (height + barLevelHeight) / 2);
|
cr.lineTo(endX, (height + barLevelHeight) / 2);
|
||||||
cr.lineTo(endX, (height - barLevelHeight) / 2);
|
cr.lineTo(endX, (height - barLevelHeight) / 2);
|
||||||
cr.lineTo(width - barLevelBorderRadius - barLevelBorderWidth, (height - barLevelHeight) / 2);
|
cr.lineTo(xcArcEnd, (height - barLevelHeight) / 2);
|
||||||
Clutter.cairo_set_source_color(cr, barLevelColor);
|
Clutter.cairo_set_source_color(cr, barLevelColor);
|
||||||
cr.fillPreserve();
|
cr.fillPreserve();
|
||||||
Clutter.cairo_set_source_color(cr, barLevelBorderColor);
|
Clutter.cairo_set_source_color(cr, barLevelBorderColor);
|
||||||
@ -147,11 +164,17 @@ export const BarLevel = GObject.registerClass({
|
|||||||
cr.stroke();
|
cr.stroke();
|
||||||
|
|
||||||
/* normal progress bar */
|
/* normal progress bar */
|
||||||
let x = Math.min(endX, overdriveSeparatorX - overdriveSeparatorWidth / 2);
|
let x = 0;
|
||||||
cr.arc(barLevelBorderRadius + barLevelBorderWidth, height / 2, barLevelBorderRadius, TAU * (1 / 4), TAU * (3 / 4));
|
if (!rtl) {
|
||||||
|
x = Math.min(endX, overdriveSeparatorX - overdriveSeparatorWidth / 2);
|
||||||
|
cr.arc(xcArcStart, height / 2, barLevelBorderRadius, TAU * (1 / 4), TAU * (3 / 4));
|
||||||
|
} else {
|
||||||
|
x = Math.max(endX, overdriveSeparatorX + overdriveSeparatorWidth / 2);
|
||||||
|
cr.arcNegative(xcArcStart, height / 2, barLevelBorderRadius, TAU * (1 / 4), TAU * (3 / 4));
|
||||||
|
}
|
||||||
cr.lineTo(x, (height - barLevelHeight) / 2);
|
cr.lineTo(x, (height - barLevelHeight) / 2);
|
||||||
cr.lineTo(x, (height + barLevelHeight) / 2);
|
cr.lineTo(x, (height + barLevelHeight) / 2);
|
||||||
cr.lineTo(barLevelBorderRadius + barLevelBorderWidth, (height + barLevelHeight) / 2);
|
cr.lineTo(xcArcStart, (height + barLevelHeight) / 2);
|
||||||
if (this._value > 0)
|
if (this._value > 0)
|
||||||
Clutter.cairo_set_source_color(cr, barLevelActiveColor);
|
Clutter.cairo_set_source_color(cr, barLevelActiveColor);
|
||||||
cr.fillPreserve();
|
cr.fillPreserve();
|
||||||
@ -160,7 +183,10 @@ export const BarLevel = GObject.registerClass({
|
|||||||
cr.stroke();
|
cr.stroke();
|
||||||
|
|
||||||
/* overdrive progress barLevel */
|
/* overdrive progress barLevel */
|
||||||
|
if (!rtl)
|
||||||
x = Math.min(endX, overdriveSeparatorX) + overdriveSeparatorWidth / 2;
|
x = Math.min(endX, overdriveSeparatorX) + overdriveSeparatorWidth / 2;
|
||||||
|
else
|
||||||
|
x = Math.max(endX, overdriveSeparatorX) - overdriveSeparatorWidth / 2;
|
||||||
if (this._value > this._overdriveStart) {
|
if (this._value > this._overdriveStart) {
|
||||||
cr.moveTo(x, (height - barLevelHeight) / 2);
|
cr.moveTo(x, (height - barLevelHeight) / 2);
|
||||||
cr.lineTo(endX, (height - barLevelHeight) / 2);
|
cr.lineTo(endX, (height - barLevelHeight) / 2);
|
||||||
@ -180,9 +206,15 @@ export const BarLevel = GObject.registerClass({
|
|||||||
Clutter.cairo_set_source_color(cr, barLevelActiveColor);
|
Clutter.cairo_set_source_color(cr, barLevelActiveColor);
|
||||||
else
|
else
|
||||||
Clutter.cairo_set_source_color(cr, barLevelOverdriveColor);
|
Clutter.cairo_set_source_color(cr, barLevelOverdriveColor);
|
||||||
|
if (!rtl) {
|
||||||
cr.arc(endX, height / 2, barLevelBorderRadius, TAU * (3 / 4), TAU * (1 / 4));
|
cr.arc(endX, height / 2, barLevelBorderRadius, TAU * (3 / 4), TAU * (1 / 4));
|
||||||
cr.lineTo(Math.floor(endX), (height + barLevelHeight) / 2);
|
cr.lineTo(Math.floor(endX), (height + barLevelHeight) / 2);
|
||||||
cr.lineTo(Math.floor(endX), (height - barLevelHeight) / 2);
|
cr.lineTo(Math.floor(endX), (height - barLevelHeight) / 2);
|
||||||
|
} else {
|
||||||
|
cr.arcNegative(endX, height / 2, barLevelBorderRadius, TAU * (3 / 4), TAU * (1 / 4));
|
||||||
|
cr.lineTo(Math.ceil(endX), (height + barLevelHeight) / 2);
|
||||||
|
cr.lineTo(Math.ceil(endX), (height - barLevelHeight) / 2);
|
||||||
|
}
|
||||||
cr.lineTo(endX, (height - barLevelHeight) / 2);
|
cr.lineTo(endX, (height - barLevelHeight) / 2);
|
||||||
cr.fillPreserve();
|
cr.fillPreserve();
|
||||||
cr.setLineWidth(barLevelBorderWidth);
|
cr.setLineWidth(barLevelBorderWidth);
|
||||||
|
Loading…
Reference in New Issue
Block a user