--- title: CanvasRenderingContext2D.globalAlpha slug: Web/API/CanvasRenderingContext2D/globalAlpha tags: - API - Canvas - CanvasRenderingContext2D - Property - Reference - Свойства - Ссылки translation_of: Web/API/CanvasRenderingContext2D/globalAlpha ---
Свойство CanvasRenderingContext2D
.globalAlpha
Canvas 2D API определяет альфа-(прозрачность) значение, которое будет применено к фигурам и картинкам до того как они будут отрисованы на холсте.
Смотрите также Applying styles and color в Canvas Tutorial.
ctx.globalAlpha = value;
value
0.0
(полная прозрачность) и 1.0
(полная непрозрачность), включительно. Дефолтное значение 1.0
. Значение, не входящее в указанный диапазон, включая {{jsxref("Infinity")}} и {{jsxref("NaN")}}, не будут применены, и globalAlpha
сохранит предыдущее значение или значение по-умолчанию.В этом примере используется свойство globalAlpha
для отрисовки двух полупрозрачных прямоугольников.
<canvas id="canvas"></canvas>
const canvas = document.getElementById('canvas'); const ctx = canvas.getContext('2d'); ctx.globalAlpha = 0.5; ctx.fillStyle = 'blue'; ctx.fillRect(10, 10, 100, 100); ctx.fillStyle = 'red'; ctx.fillRect(50, 50, 100, 100);
{{ EmbedLiveSample('Drawing_translucent_shapes', 700, 180) }}
Этот пример демонстрирует эффект наложения нескольних прозрачных фигур друг на друга. Мы начнем с отрисовки непрозрачного фона, состоящего из четырех разноцветных квадратов. Далее мы устанавливаем свойство globalAlpha
равное 0.2
(20% прозрачности); Уровень прозрачности будет применен ко всем прозрачным фигурам. Затем мы используем цикл for
для отрисовки нескольких кругов с увеличивающимися радиусами.
Для каждого нового круга прозрачность кругов, находящихся под ним, уменьшается. Если вы увеличите количество шагов, тем самым увеличив количество кругов, фон в конечном итоге полностью исчезнет в центре изображения.
<canvas id="canvas" width="150" height="150"></canvas>
const canvas = document.getElementById('canvas'); const ctx = canvas.getContext('2d'); // Рисуем фон ctx.fillStyle = '#FD0'; ctx.fillRect(0, 0, 75, 75); ctx.fillStyle = '#6C0'; ctx.fillRect(75, 0, 75, 75); ctx.fillStyle = '#09F'; ctx.fillRect(0, 75, 75, 75); ctx.fillStyle = '#F30'; ctx.fillRect(75, 75, 75, 75); ctx.fillStyle = '#FFF'; // Устанавливаем уровень прозрачности ctx.globalAlpha = 0.2; // Рисуем круги for (let i = 0; i < 7; i++) { ctx.beginPath(); ctx.arc(75, 75, 10 + 10 * i, 0, Math.PI * 2, true); ctx.fill(); }
{{EmbedLiveSample("Overlaying_transparent_shapes", "180", "180", "https://mdn.mozillademos.org/files/232/Canvas_globalalpha.png")}}
Specification | Status | Comment |
---|---|---|
{{SpecName('HTML WHATWG', "scripting.html#dom-context-2d-globalalpha", "CanvasRenderingContext2D.globalAlpha")}} | {{Spec2('HTML WHATWG')}} |
{{Compat("api.CanvasRenderingContext2D.globalAlpha")}}
globalAlpha
no longer throws a SYNTAX_ERR
exception; these are now correctly silently ignored.ctx.setAlpha()
is implemented in addition to this property.