recherche
Maisoninterface Webtutoriel CSSComment puis-je recolorer le noir (#000) en une couleur RVB cible en utilisant uniquement des filtres CSS ?

How can I recolor black (#000) to a target RGB color using only CSS filters?

Avec filtres CSS uniquement

Il s'agit d'une solution à un problème soulevé dans cette question Stack Overflow. Le texte du problème explique le contexte mieux que je ne pourrais le faire dans un résumé :

Problème : Étant donné une couleur RVB cible, quelle est la formule pour recolorer le noir (#000) dans celle-ci couleur en utilisant uniquement des filtres CSS ?

Pour qu'une réponse soit acceptée, elle devrait fournir une fonction (dans n'importe quelle langue) qui accepterait la couleur cible comme et renvoie la chaîne de filtre CSS correspondante.

Le contexte est la nécessité de recolorer un SVG à l'intérieur d'une image d'arrière-plan. Dans ce cas, il s'agit de prendre en charge certains Fonctionnalités mathématiques TeX dans KaTeX : https://github.com/Khan/KaTeX/issues/587.

Voici la solution, présentée sous forme de code JavaScript.

class Color {
    constructor(r, g, b) { this.set(r, g, b); }
    toString() { return `rgb(${Math.round(this.r)}, ${Math.round(this.g)}, ${Math.round(this.b)})`; }

    set(r, g, b) {
        this.r = this.clamp(r);
        this.g = this.clamp(g);
        this.b = this.clamp(b);
    }

    hueRotate(angle = 0) {
        angle = angle / 180 * Math.PI;
        let sin = Math.sin(angle);
        let cos = Math.cos(angle);

        this.multiply([
            0.213 + cos * 0.787 - sin * 0.213, 0.715 - cos * 0.715 - sin * 0.715, 0.072 - cos * 0.072 + sin * 0.928,
            0.213 - cos * 0.213 + sin * 0.143, 0.715 + cos * 0.285 + sin * 0.140, 0.072 - cos * 0.072 - sin * 0.283,
            0.213 - cos * 0.213 - sin * 0.787, 0.715 - cos * 0.715 + sin * 0.715, 0.072 + cos * 0.928 + sin * 0.072
        ]);
    }

    grayscale(value = 1) {
        this.multiply([
            0.2126 + 0.7874 * (1 - value), 0.7152 - 0.7152 * (1 - value), 0.0722 - 0.0722 * (1 - value),
            0.2126 - 0.2126 * (1 - value), 0.7152 + 0.2848 * (1 - value), 0.0722 - 0.0722 * (1 - value),
            0.2126 - 0.2126 * (1 - value), 0.7152 - 0.7152 * (1 - value), 0.0722 + 0.9278 * (1 - value)
        ]);
    }

    sepia(value = 1) {
        this.multiply([
            0.393 + 0.607 * (1 - value), 0.769 - 0.769 * (1 - value), 0.189 - 0.189 * (1 - value),
            0.349 - 0.349 * (1 - value), 0.686 + 0.314 * (1 - value), 0.168 - 0.168 * (1 - value),
            0.272 - 0.272 * (1 - value), 0.534 - 0.534 * (1 - value), 0.131 + 0.869 * (1 - value)
        ]);
    }

    saturate(value = 1) {
        this.multiply([
            0.213 + 0.787 * value, 0.715 - 0.715 * value, 0.072 - 0.072 * value,
            0.213 - 0.213 * value, 0.715 + 0.285 * value, 0.072 - 0.072 * value,
            0.213 - 0.213 * value, 0.715 - 0.715 * value, 0.072 + 0.928 * value
        ]);
    }

    multiply(matrix) {
        let newR = this.clamp(this.r * matrix[0] + this.g * matrix[1] + this.b * matrix[2]);
        let newG = this.clamp(this.r * matrix[3] + this.g * matrix[4] + this.b * matrix[5]);
        let newB = this.clamp(this.r * matrix[6] + this.g * matrix[7] + this.b * matrix[8]);
        this.r = newR; this.g = newG; this.b = newB;
    }

    brightness(value = 1) { this.linear(value); }
    contrast(value = 1) { this.linear(value, -(0.5 * value) + 0.5); }

    linear(slope = 1, intercept = 0) {
        this.r = this.clamp(this.r * slope + intercept * 255);
        this.g = this.clamp(this.g * slope + intercept * 255);
        this.b = this.clamp(this.b * slope + intercept * 255);
    }

    invert(value = 1) {
        this.r = this.clamp((value + (this.r / 255) * (1 - 2 * value)) * 255);
        this.g = this.clamp((value + (this.g / 255) * (1 - 2 * value)) * 255);
        this.b = this.clamp((value + (this.b / 255) * (1 - 2 * value)) * 255);
    }

    hsl() { // Code taken from https://stackoverflow.com/a/9493060/2688027, licensed under CC BY-SA.
        let r = this.r / 255;
        let g = this.g / 255;
        let b = this.b / 255;
        let max = Math.max(r, g, b);
        let min = Math.min(r, g, b);
        let h, s, l = (max + min) / 2;

        if(max === min) {
            h = s = 0;
        } else {
            let d = max - min;
            s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
            switch(max) {
                case r: h = (g - b) / d + (g  255) { value = 255; }
        else if(value 

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Guide des commandes de la consoleGuide des commandes de la consoleApr 11, 2025 am 10:14 AM

La console de débogage du développeur est disponible sous une forme ou une autre dans les navigateurs Web depuis de nombreuses années. Commencer comme un moyen de signaler les erreurs

Le cas des noms de domaine volésLe cas des noms de domaine volésApr 11, 2025 am 10:12 AM

En 2011, le nom de domaine de ce site, CSS-Tricks.com, a été volé. "Le détournement de domaine", ils l'appellent. Ce n'était pas juste ce site, mais environ 12 autres

Éléments pleine largeur en utilisant une grille de bord à bordÉléments pleine largeur en utilisant une grille de bord à bordApr 11, 2025 am 10:09 AM

Si vous avez un conteneur à largeur limitée, disons une colonne de texte centrée, "éclater" de cela pour faire un élément pleine largeur implique la ruse. Peut-être le meilleur

Créer un élément de détails qui s'ouvre mais ne se ferme jamaisCréer un élément de détails qui s'ouvre mais ne se ferme jamaisApr 11, 2025 am 10:02 AM

Les éléments et les éléments de HTML sont utiles pour faire des bascules de contenu pour des bits de texte. Par défaut, vous voyez le

Création d'une page Web modifiable avec des feuilles de calcul Google et tabletop.jsCréation d'une page Web modifiable avec des feuilles de calcul Google et tabletop.jsApr 11, 2025 am 10:01 AM

Veuillez lever la main si vous avez déjà fait face à des demandes de révision de contenu sans fin de vos clients. Ce n'est pas que les changements eux-mêmes sont difficiles, mais

L'innovation ne peut pas garder le Web rapidementL'innovation ne peut pas garder le Web rapidementApr 11, 2025 am 09:59 AM

De temps en temps, les fruits de l'innovation portent des fruits sous la forme d'améliorations aux couches fondamentales du Web. En 2015, HTTP / 2 est devenu une publication

Guillermo & # 039; s 2019 en revueGuillermo & # 039; s 2019 en revueApr 11, 2025 am 09:52 AM

De tous les messages de la technologie de la technologie que j'ai lus, Guillermo Rauch est mon préféré. Il y en a beaucoup là-dedans, à sauter de sujets comme les architectures modernes,

Les crochets du routeur ReactLes crochets du routeur ReactApr 11, 2025 am 09:49 AM

React Router 5 embrasse la puissance des crochets et a introduit quatre crochets différents pour aider à l'acheminement. Vous trouverez cet article utile si vous cherchez

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Dreamweaver Mac

Dreamweaver Mac

Outils de développement Web visuel

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

Version Mac de WebStorm

Version Mac de WebStorm

Outils de développement JavaScript utiles

Adaptateur de serveur SAP NetWeaver pour Eclipse

Adaptateur de serveur SAP NetWeaver pour Eclipse

Intégrez Eclipse au serveur d'applications SAP NetWeaver.

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)