Знакомимся с CSS3. Секреты прозрачного фона и модель RGBa
Продолжим знакомство с некоторыми, не совсем очевидными, свойствами CSS3. Одно из таких свойств — прозрачность фонового цвета, заданная в формате RGBa или HSLa.
Не пугайтесь последнего названия HSLa — Hue (оттенок), Saturate (насыщенность) и Lightness (яркость). Буква «A» на конце аббревиатуры означает «альфа» (хорошо знакомо любителям Photoshop) и отвечает за величину прозрачности цвета.
Напрашивается резонный вопрос, для чего в таком случае нужно свойство оpacity (прозрачность) и в чем разница?
На многих ресурсах встречается заблуждение, что при установке свойства opacity оно полностью и навсегда наследуется всеми вложенными элементами.
Однако это не совсем так и тут есть довольно тонкий момент при использовании свойства opacity. Действительно, создавая полупрозрачный div (opacity:0.5), любой вложенный в этот div элемент будет также полупрозрачным. Тонкость в том, что у вложенных элементов непрозрачность идет относительно предка, а не абсолютная. То есть, дочерний элемент не может получить абсолютную видимость выше, чем у предка. Итоговая opacity для элемента вычисляется как произведение opacity этого элемента и opacity всех его предков.
Пример ниже наглядно демонстрирует работу свойства opacity: (в div-блок с белым фоном и прозрачностью 50%, вложена картинка и текст, кроме того у блока задана рамка в 1px белого цвета)
opacity:0.5
Свойство opacity (прозрачность) родительского блока <div> наследуется всеми дочерними элементами.
А теперь смотрим этот же пример, но фон у div-блока задан через CSS3-свойство background-color: rgba(255,255,255,0.5)
background-color: rgba(255,255,255,0.5)
Фоновый цвет блока <div> задан в формате RGBA, который не наследуется дочерними элементами.
На этот раз, все наши элементы, кроме div-блока, остались непрозрачными.
Естественно, данный способ сработает только в тех браузерах, которые поддерживают данные возможности CSS3. В очередной раз надеюсь, что парни из Редмонда перестанут изобретать велосипед и присоединятся к большинству. Подписывайтесь на канал Яндекс.Дзен и узнавайте первыми о новых материалах, опубликованных на сайте.Если считаете статью полезной,
не ленитесь ставить лайки и делиться с друзьями.
java — Как создать заставку с прозрачным фоном в JavaFX
Попробуйте этот пример заставки JavaFX , созданный для вопроса Stackoverflow: Разработка заставки (java) . И дополнительный пример , который также предоставляет обратную связь о ходе инициализации приложения.
JavaFX предлагает интерфейс Preloader для плавного перехода от заставки к приложению, но приведенные выше примеры не используют его.
В приведенных выше примерах заставки эффект прозрачности также отсутствует, но этот пример диалогового окна показывает, как это сделать, и вы можете объединить его с предыдущими примерами заставки, чтобы получить желаемый эффект.
Прозрачный эффект создается:
-
stage.initStyle(StageStyle.TRANSPARENT)
литий> -
scene.setFill(Color.TRANSPARENT)
литий> - Убедитесь, что ваш корневой узел не является непрозрачным квадратным прямоугольником.
Что все продемонстрировано в образце Сергея.
Схожий вопрос:
Обновление за апрель 2016 г. на основе дополнительных вопросов
изображение перед загрузчиком не на переднем плане. Я пробовал stage.toFront (), но это не помогает.
Новый API был создан в Java 8u20 stage.setAlwaysOnTop (true) . Я обновил связанный образец , чтобы использовать его на начальном экране-заставке, что поможет сгладить переход на главный экран.
Для Java8 +
Для modena.css (определение стиля JavaFX по умолчанию в Java 8) был добавлен слегка затененный фон для всех элементов управления (а также для панелей, если элемент управления загружен).
Вы можете удалить это, указав, что фон по умолчанию является прозрачным. Это можно сделать, добавив следующую строку в файл CSS вашего приложения:
.root { -fx-background-color: transparent; }
При желании вы можете использовать классы и правила стилей CSS или вызов setStyle (как показано в ответе Сергея), чтобы убедиться, что этот параметр применяется только к корню заставки, а не ко всем экранам приложения.
Смотрите похожие:
Прозрачный логотип – что это такое и как получить?
Vasyl Holiney Обновлено Loading…1.Где используют логотип на прозрачном фоне?
2.Форматы логотипов с прозрачным фоном
3.Как сделать логотип прозрачным?
4.Создать прозрачный логотип c Логастер
Современные логотипы обладают целым рядом особенностей, отличающих их от других видов графических изображений. Прежде всего, к ним относят широкую сферу применения – как в печатном, так и в веб-формате. Во многих случаях лого является зависимым элементом, который должен оптимально разместиться на фоне страницы сайта или каких-либо полиграфических материалов. Чтобы добиться такого результата, предварительно нужно избавиться от цветного фона, сделав логотип полностью прозрачным.
Где используют логотип на прозрачном фоне?
Особенно часто логотипы с прозрачным фоном используются на сайтах или в социальных сетях (на страницах или в группах компании, бренда, продукта).
Главное их преимущество – это универсальность, позволяющая оптимально вписаться в дизайн с любым расположением элементов и цветов. Такую графику можно легко и быстро загружать на различные сайты, не беспокоясь о том, как встроить ее в фон каждого из них.
Кроме того, прозрачные логотипы нередко применяют в качестве водяного знака для картинок – товаров в каталогах интернет магазинов и т.д.
С их помощью вы сможете эффективно защитить любой графический контент от воровства и при этом не навредить его внешнему виду. Еще такие лого оптимально подходят для полиграфической продукции, особенно при печати материалов небольших размеров. Например, если вы разрабатываете дизайн сувениров, визиток, календарей, то на них может не найтись отдельного места для лого с собственным фоном. А прозрачный объект быстро размещается где-угодно без особых сложностей.
Форматы логотипов с прозрачным фоном
Для создания данного типа графики подходят далеко не все существующие форматы, а только некоторые из них. В частности, к ним относятся:
Логотип в PNG формате. Наиболее популярное расширение для прозрачных логотипов – свободный растровый формат, позволяющий эффективно сжимать изображение без потери его качества. PNG был разработан в 1996 году, как некоммерческий аналог GIF, однако активно используется по сей день, благодаря своему удобству и широким возможностям для редактирования файлов. Формат поддерживает полноцветную графику, открывается и обрабатывается во всех популярных графических редакторах (например, Photoshop). Именно логотипы в PNG c прозрачным фоном чаще всего (до 90% случаев) используются на сайтах, фотографиях или же в печати;
Логотип в GIF формате. Старейший растровый формат (изобретенный в 1987 году) частично поддерживает прозрачность фона, поэтому в нем также можно создавать соответствующие логотипы. Для этого достаточно назначить прозрачным один из его 256 цветов, после чего сквозь картинку будет проступать фон веб-страницы. Важным недостатком GIF считается невозможность регулировать степень прозрачности, что делает это расширение не самым популярным в наши дни;
Логотип в SVG формате. Для создания подобной графики еще применяют векторный формат SVG, доступный в открытом стандарте. Сделать это в нем можно, благодаря свойству fill-opacity, позволяющему плавно изменять прозрачность фона картинки при помощи числовых значений. SVG имеет большое количество преимуществ, включая удобство обработки (даже в текстовых редакторах) и отличную масштабируемость. Данные файлы очень легко встраиваются в разметку веб-страниц, так как формат был создан на основе популярного языка разметки XML. При этом логотипы в SVG наиболее часто применяются профессиональными дизайнерами в сложных и объемных проектах, поэтому данный формат редко используется большинством обладателей лого.
Как сделать логотип прозрачным?
Большинство профессиональных дизайнеров по умолчанию оформляют свои логотипы на прозрачном фоне, если у клиента не было особых пожеланий по этому поводу. Однако что делать, если вы получили лого с цветной подложкой и теперь хотите от нее избавиться? Сделать это довольно легко и быстро вам помогут современные графические редакторы – например, Adobe Photoshop. Смотрите видео ниже как убрать фон логотипа в Photoshop.
Если у вас есть исходники логотипа в формате PSD, то откройте изображение в Photoshop и первым делом выделите все слои его объектов, за исключением фонового. Затем вам нужно создать новую группу (папку) и перенести туда их все – такая операция поможет впоследствии легко регулировать прозрачность самого логотипа, например, если понадобится сделать его частично прозрачным.
Для получения новой пустой папки нажмите на пиктограмму, расположенную в нижней правой половине панели слоев. После этого перейдите на строку инструментов, относящихся к фоновому слою – вам понадобится пиктограмма с глазом, находящаяся на ее левом краю. Щелкнув по ней, вы сможете полностью отключить видимость фона, без особого труда сделав свой логотип на 100% прозрачным.
Создать прозрачный логотип онлайн при помощи сервиса Логастер
Существует еще один, более простой и оперативный способ добиться такого результата, не тратя свое время на работу в графических редакторах. В частности, получить прозрачный логотип за считанные секунды вам поможет сервис Логастер – здесь вы можете с легкостью создать оригинальную эмблему для своего бренда, товара или услуги, а затем скачать ее в таком виде прямо на свой компьютер.
После того, как ваш лого будет готов, перейдите в раздел скачивания и выберите для этого формат PNG, PDF или SVG.
Затем на ваш жесткий диск мгновенно загрузится архив с логотипом в различных версиях, две из которых (полноцветная и черно-белая) будут иметь прозрачный фон. Определить их можно по слову transparent, присутствующему в названии файла.
Таким образом, сервис Логастер быстро поможет вам создать прозрачный логотип, чтобы затем без каких-либо ограничений использовать его для оформления интернет-сайтов или полиграфических материалов. Вот более детальная статья как получить логотип с прозрачным фоном, который созданный на сайте Логастер.
Готовы к созданию своего фирменного знака?
Если да, то переходите в онлайн-сервис Логастер. Там вас уже ожидают удобный интерфейс и огромная база привлекательных макетов.
lazarus — Нет прозрачного фона, несмотря на то, что для параметра transparent установлено значение true.
Только начал с Lazarus. Вот проблема: я разместил панель на форме и установил цвет панели на clRed
. Затем я поместил TImage
на панель. Я загрузил растровое изображение (.bmp) в компонент изображения.
Однако, хотя изображение выглядит так, как должно, фон не является прозрачным (т.е. красным), несмотря на то, что я установил флажок «прозрачный» для соответствующего TImage
в инспекторе объектов.
Итак, что я сделал не так на этот раз?
0
Mariner 8 Июл 2017 в 12:542 ответа
Лучший ответ
«Прозрачный» по отношению к BMP означает: заменить заданный цвет фоном. Обычно этот цвет определяется пикселем в левом / нижнем (или верхнем?) Углу изображения. У вас правильный цвет на данный момент?
Обычно проблем с прозрачностью меньше, если в TImage загружается изображение png с истинным альфа-каналом. Для теста попробуйте paw.png в папке images \ splash_source \ установки Lazarus — он работает отлично.
0
wp_1233996 12 Июл 2017 в 17:28
Afaik формат изображения BMP не имеет альфа-канала и прозрачного цвета. Таким образом, TImage прозрачен, но загруженное изображение не поддерживает прозрачность. Белый фон изображения по-прежнему отображается как белый, потому что программа не знает, что это белый фон, а не белый передний план. Попробуйте использовать формат изображения, который поддерживает альфа-значения, и отредактируйте файл изображения, чтобы он содержал полные или полупрозрачные цвета. Я рекомендую формат файла .PNG и, возможно, просто попробуйте несколько прозрачных изображений из Google или используйте gimp или paint.net для создания собственных.
0
mac.1 12 Июл 2017 в 15:25
Непрозрачность— CSS: каскадные таблицы стилей
. Свойство opacity
CSS устанавливает непрозрачность элемента. Непрозрачность — это степень, в которой скрыто содержимое за элементом, и является противоположностью прозрачности.
Исходный код этого интерактивного примера хранится в репозитории GitHub. Если вы хотите внести свой вклад в проект интерактивных примеров, клонируйте https://github.com/mdn/interactive-examples и отправьте нам запрос на перенос.
Значения
-
<альфа-значение>
- A
<число>
в диапазоне0.0
–1,0
включительно или<процент>
в диапазоне0%
–100%
включительно, представляя непрозрачность канала (то есть значение его альфа-канала). Любое значение вне интервала, хотя и действительное, ограничивается ближайшим пределом в диапазоне.Значение Значение 0
Элемент полностью прозрачный (то есть невидимый). Любой <номер>
строго между0
и1
Элемент полупрозрачный (то есть видно содержимое позади элемента). 1
(значение по умолчанию)Элемент полностью непрозрачный (визуально твердый).
непрозрачность
применяется к элементу в целом, включая его содержимое, даже если значение не наследуется дочерними элементами. Таким образом, элемент и его дочерние элементы имеют одинаковую непрозрачность относительно фона элемента, даже если они имеют разную прозрачность относительно друг друга.
Использование непрозрачности
со значением, отличным от 1
помещает элемент в новый контекст наложения.
Если вы не хотите применять непрозрачность к дочерним элементам, используйте вместо этого свойство background
. Например:
фон: rgba (0, 0, 0, 0.4);
Если непрозрачность текста регулируется, важно убедиться, что коэффициент контрастности между цветом текста и фоном, на котором размещен текст, достаточно высок, чтобы люди с ослабленным зрением могли прочитать содержимое текста. страница.
Коэффициент контрастности цвета определяется путем сравнения яркости текста с измененной непрозрачностью и значений цвета фона.Чтобы соответствовать текущим Рекомендациям по обеспечению доступности веб-содержимого (WCAG), требуется соотношение 4,5: 1 для текстового содержимого и 3: 1 для более крупного текста, такого как заголовки. Большой текст определяется как 18,66 пикселей и полужирный или больше, или 24 пикселей или больше.
Установка непрозрачности фона
HTML
Вы этого не видите.
Это легче увидеть.
Это очень легко увидеть.
CSS
div {цвет фона: желтый; }
.свет {
непрозрачность: 0,2;
}
.Средняя {
непрозрачность: 0,5;
}
.тяжелый {
непрозрачность: 0,9;
}
Результат
Установка непрозрачности при наведении курсора
HTML
CSS
img.opacity {
непрозрачность: 1;
фильтр: альфа (непрозрачность = 100);
масштабирование: 1;
}
img.opacity: hover {
непрозрачность: 0,5;
фильтр: альфа (непрозрачность = 50);
масштабирование: 1;
}
Результат
таблицы BCD загружаются только в браузере
CSS Image Transparency (Opacity)
CSS Image Opacity (Transparency)
В CSS нет такого свойства, как прозрачность.Но вы можете добиться прозрачности, вставив псевдоэлемент с обычной непрозрачностью, равной точному размеру элемента за ним. Свойством CSS3 прозрачности является непрозрачность, и это часть рекомендации W3C CSS3.
div { непрозрачность: 0,6; }Уровень непрозрачности описывает уровень прозрачности, он варьируется от 0,0 до 1,0. Уровень 0,0 полностью прозрачен, 0,5 — прозрачность 50%, а уровень 1,0 — непрозрачен. Непрозрачность имеет начальное значение по умолчанию 1 (непрозрачность 100%).
Создание прозрачного изображения
Вы можете создавать прозрачные фоновые изображения, используя свойство CSS opacity.
Первое изображение имеет уровень непрозрачности 1.0, а второе изображение — уровень непрозрачности 0.3.
Исходный код
Во всех современных веб-браузерах реализовано очень простое свойство непрозрачности CSS, поэтому код для конкретного браузера не требуется. Но IE8 и более ранние версии используют filter: alpha (opacity = x). X может принимать значение от 0 до 100.Значение 50 означает 50% прозрачности.
Как создать прозрачный цвет Div
Вы можете создать прозрачный фоновый элемент Div, используя свойство CSS Opacity.
Первый div имеет уровень прозрачности 1. и отправляет div с уровнем 0,5.
Исходный код
непрозрачность 1.0
непрозрачность 0,5
Прозрачная рамка
В CSS вы можете сделать границу изображения прозрачной.
Исходный код
прозрачная коробка
Следующая программа показывает прозрачную рамку поверх изображения, и вы можете написать свой текст в прозрачной рамке.
Исходный код
прозрачный текст
Следующая программа использует хитрый способ отображения текста как прозрачного.
Исходный код
Утка
Непрозрачность / прозрачность CSS
Свойство непрозрачности может принимать значение от 0.0 — 1.0. Чем меньше значение, тем прозрачнее:
непрозрачность 0,2
непрозрачность 0,5
непрозрачность 1
(по умолчанию)
Примечание. IE8 и более ранние версии используют filter: alpha (opacity = x). X может принимать значение от 0 до 100. Меньшее значение делает элемент более прозрачным.
Пример
img {
непрозрачность: 0,5;
фильтр:
альфа (непрозрачность = 50); / * Для IE8 и более ранних * /
}
Свойство opacity часто используется вместе с селектором: hover для изменения непрозрачности при наведении указателя мыши:
Пример
img {непрозрачность: 0.5;
фильтр: альфа (непрозрачность = 50); / * Для IE8 и более ранних версий * /
}
img: hover {
непрозрачность: 1.0;
фильтр: альфа (непрозрачность = 100); / * Для IE8
и ранее * /
}
Первый блок CSS похож на код в примере 1. Кроме того, мы добавили, что должно происходить, когда пользователь наводит курсор на одно из изображений. В этом случае мы хотим, чтобы изображение НЕ было прозрачным, когда пользователь наводит на него курсор.CSS для этого — opacity: 1 ;.
Когда указатель мыши отодвинется от изображения, изображение снова станет прозрачным.
Пример обратного эффекта наведения:
Пример
img: hover {
непрозрачность: 0,5;
фильтр: альфа (непрозрачность = 50); / * Для IE8
и ранее * /
}
При использовании свойства opacity для добавления прозрачности фону элемента все его дочерние элементы также становятся прозрачными.Это может затруднить чтение текста внутри полностью прозрачного элемента:
Пример
div {
непрозрачность: 0,3;
фильтр:
альфа (непрозрачность = 30); / * Для IE8 и более ранних * /
}
Если вы не хотите применять непрозрачность к дочерним элементам, как в нашем примере выше, используйте значения цвета RGBA. В следующем примере устанавливается непрозрачность цвета фона, а не текста:
Из нашей главы о цветах CSS вы узнали, что в качестве значения цвета можно использовать RGB.В дополнение к RGB, CSS3 представил значение цвета RGB с альфа-каналом (RGBA), который определяет непрозрачность цвета.
Значение цвета RGBA задается с помощью: rgba (красный, зеленый, синий, альфа). Параметр альфа — это число от 0,0 (полная прозрачность) до 1,0 (полная непрозрачность).
Совет: вы узнаете больше о цветах RGBA в нашей главе о цветах CSS3.
Пример
div {
фон: rgba (76, 175, 80, 0.3) / * Зеленый фон с 30%
непрозрачность * /
}
Это текст, помещенный в прозрачную рамку.
Пример
Это текст, помещенный в прозрачную рамку.
Сначала мы создаем элемент
.
Проверьте себя с помощью упражнений
4.
Как стать прозрачным — цвета, узоры и градиенты SVG [Книга] SVG использует три различных свойства для управления непрозрачностью основных форм и текста: непрозрачность
, непрозрачность заливки
и непрозрачность штрихов
.Все это можно установить с помощью атрибутов представления или правил стиля CSS.
CSS Color Module Level 3 расширил свойство opacity
для применения ко всему содержимому. Кроме того, вместо того, чтобы вводить свойства * -opacity
для каждого аспекта рисования CSS, этот модуль представил новые цветовые функции. Частично прозрачный цвет можно определить с помощью цветовых функций rgba ()
и hsla ()
, а затем использовать в любом месте CSS, где требуется значение цвета.
Непрозрачность в Интернете всегда выражается десятичным числом от 0,0 (невидимый) до 1,0 (сплошной, без прозрачности). Эти числа также известны как значения альфа , особенно при обсуждении непрозрачности как неотъемлемой части цветов или изображений. и
в rgba ()
и hsla ()
относятся к альфа-каналу. Эти функции принимают четыре значения вместо обычных трех, четвертое — альфа-значение от 0 до 1.
Примечание
Ключевое слово transparent
, которое раньше имело особое значение для фона CSS, было переопределено как именованный цвет.Эквивалентно rgba (0,0,0,0)
, его можно использовать как любое другое ключевое слово color в браузерах, поддерживающих цвета CSS 3.
Окончательный эффект изменения значения альфа-канала изображения зависит от используемого вами метода. В частности, общее свойство непрозрачности
работает существенно иначе, чем другие параметры.
Свойство непрозрачности
применяется к элементу, для которого оно установлено, даже если это группа
,
или
, и не наследуется. Он принимает окончательный результат рисования для этого элемента, включая все его дочернее содержимое, и делает его более прозрачным.
Подсказка
Непрозрачность . Значение
применяется после , определяя окончательный цвет в каждой точке, где две фигуры — или заливка и обводка одной формы — перекрываются.
Установка непрозрачности
меньше 1 создает контекст наложения, сглаживающий и содержащий все дочернее содержимое. В макете CSS это может существенно повлиять на положение элементов.Он не имеет аналогичного эффекта в содержимом SVG 1.1, но в SVG 2 он влияет на наложение z-index
и сглаживает все трехмерные преобразования.
Напротив, когда вы устанавливаете stroke-opacity
или fill-opacity
, или когда вы используете цветовые функции rgba
или hsla
, эффект прозрачности применяется во время рисования каждой фигуры к этому цветному участку. Только. Свойства stroke-opacity
и fill-opacity
наследуются по умолчанию.
Рисунок 4-1 демонстрирует разницу, используя контур в виде восьмерки с толстой зеленой обводкой и желтой заливкой, частично перекрывающий сине-фиолетовый эллипс, непрозрачность которого не меняется. Зеленая и желтая форма показаны с полной непрозрачностью (вверху слева) и имеют половинную непрозрачность с использованием непрозрачности обводки
и непрозрачности заливки
(вверху справа), непрозрачности
для элемента
(внизу слева ) или RGB
цветов для обводки и заливки (внизу справа).Пример 4-1 дает код.
Рисунок 4-1. Зелено-желтая фигура, полностью непрозрачная и частично прозрачная тремя различными способами
Пример 4-1. Использование различных параметров непрозрачности для управления прозрачностью графики
Повторно используемые формы предварительно определены в разделе
Передний план
Блок CSS