web-dev-qa-db-fra.com

changer une zone particulière d'une image et remplir les couleurs de cette zone

Edit Png Image For E.g changez de zone et remplissez la couleur de cette zone.

Je souhaite modifier la couleur d'une image uniquement dans la zone sélectionnée. Comme le premier utilisateur sélectionne une couleur, il choisit une image après quoi il peut modifier la zone de couleur de l'image avec la couleur sélectionnée.

Après cela, il pourra également sauvegarder cette image. Est-ce possible ?? comme le site Web de la société Color utilise ce genre de chose.

comme ci-dessous URL https://www.sherwin-williams.com/visualizer#/active

9
user3198563

Démo:

Page complète: https://angularjs-rj88cu.stackblitz.io/

Code: https://stackblitz.com/edit/angularjs-rj88cu

Explication:

L'éditeur est un svg contenant l'image d'arrière-plan sous la forme <image> et les zones sous la forme <path>. Les deux sont créées à partir de editor.imageUrl et editor.areas.

Pour le téléchargement,

  1. L'image de fond est dessinée sur une toile
  2. SVG (sans <image>) est converti en dataUrl puis dessiné sur du canevas
  3. La toile est convertie en dataUrl pour le téléchargement

Pourquoi la toile n'a-t-elle pas été utilisée à la place de svg?

Parce que les interactions de la souris sont difficiles à implémenter dans le canevas et sont beaucoup plus faciles dans les svg en ligne car elles fonctionnent comme des éléments DOM (pseudo classe survolée, événements de clic, etc.)

J'ai aussi supposé que vous vouliez angularjs parce que vous l'avez étiqueté (même si vous ne l'avez pas mentionné dans la question)

De plus, il y a beaucoup de mauvaises pratiques dans le code, comme l'éditeur ne faisant pas partie des composants et le style de Shadow DOM de input[type=color] (vous pouvez utiliser un plugin colorpicker à la place).

PS: Dites-moi si quelque chose doit être changé

2
Devansh J

Éditer: Il est possible d’obtenir les données d’image d’une toile et de changer ses pixels. Vous pouvez également rechercher des algorithmes pour dessiner des lignes, des cercles, etc. Mais les idées sont toujours les mêmes (obtenir une image de toile, la modifier, puis la sauvegarder).

Puisque vous utilisez AngularJS, vous pouvez créer une directive qui récupère la couleur en entrée et trace cette couleur sur une zone spécifique de l'image. Ensuite, vous pouvez utiliser la méthode canvas.toDataURL() ou canvas2image() pour analyser le canevas dans une image au format souhaité.

Consultez les documents MDN pour cette méthode ici https://developer.mozilla.org/pt-BR/docs/Web/API/HTMLCanvasElement/toDataURL

J'ai fait un petit extrait de code juste pour vous donner une idée. Je pense que la fonctionnalité de sélection de couleur est une étape que vous pouvez facilement implémenter et transmettre en tant qu'entrée à votre directive canvas. J'espère que ça aide!

function hexToRgb(color) {
    var shorthandRegex = /^#?([a-f\d])([a-f\d])([a-f\d])$/i;
    color = color.replace(shorthandRegex, function(m, r, g, b) {
        return r + r + g + g + b + b;
    });
    
    var result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(color);
    return result ? {
        r: parseInt(result[1], 16),
        g: parseInt(result[2], 16),
        b: parseInt(result[3], 16)
    } : {
        r: 0,
        g: 0,
        b: 0
    };
}

function colorImage(imgId,hexaColor) {
    // create hidden canvas (using image dimensions)
    var imgElement = document.getElementById(imgId);
  
    var canvas = document.createElement("canvas");
    canvas.width = imgElement.width;
    canvas.height = imgElement.height;

    var ctx = canvas.getContext("2d");
    ctx.drawImage(imgElement,0,0);
    
    var imageData = ctx.getImageData(0,0,canvas.width,canvas.height);
    
    var data = imageData.data;
  
    // convert image to grayscale
    var rgbColor = hexToRgb(hexaColor);
    //console.log(rgbColor);
    
    for(var p = 0, len = data.length; p < len; p+=4) {
        //if(data[p+3] == 0)
        //   continue;
        data[p + 0] = rgbColor.r;
        data[p + 1] = rgbColor.g;
        data[p + 2] = rgbColor.b;
        //data[p + 3] = 255;
    }
    ctx.putImageData(imageData, 0, 0);

    // replace image source with canvas data
    imgElement.src = canvas.toDataURL();
}

// changing color of capsule on select event
document.getElementById('sel_top').onchange = function(){
    colorImage('img_top', this.value);
}
document.getElementById('sel_bottom').onchange = function(){
    colorImage('img_bottom', this.value);
}

$('input[type="color"]').on("change", function(color) {
      console.log(this.value);
      var colorHex = this.value;
   
      colorImage('img_top',colorHex);
 });
img.color-img {
	position: absolute;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.slim.js"></script>

<script src="https://cdnjs.cloudflare.com/ajax/libs/tinyColorPicker/1.1.1/jqColorPicker.min.js"></script>

<label for="sel_top">top color: </label>
		<select id="sel_top">
			<option value="#ffffff">select</option>
		    <option value="#ff0000">red</option>
		    <option value="#00ff00">green</option>
		    <option value="#0000ff">blue</option>
		    <option value="#FCF153">yellow</option>    
		</select>
		<label for="sel_top">bottom color: </label>
		<select id="sel_bottom">
		    <option value="#ffffff">select</option>
		    <option value="#ff0000">red</option>
		    <option value="#00ff00">green</option>
		    <option value="#0000ff">blue</option>
		    <option value="#FCF153">yellow</option>    
		</select>
    <div>
      <input type="color" value="#ff0000" class="myColorPic">
    </div>
		<br><br>
		<img src="" />
		
		<img id="img_top" src="" class="color-img" />
		<img id="img_bottom" src="" class="color-img" />
		<img src="" class="color-img" />

8
Tiago Conceiçao

Le fonctionnel dans l'exemple - produit personnalisé, et il est implémenté via AngularJS.

Si vous voulez faire quelque chose comme ça, vous pouvez combiner plusieurs plugins jQuery et des fonctionnalités HTML5.

Choses dont tu as besoin:

  • un sélecteur de couleur jQuery - pour choisir la couleur
  • Toile HTML5 - Pour afficher les bordures et remplir les zones d'image avec une couleur
  • canvas2image - pour enregistrer l'image

Si vous souhaitez en utiliser, cherchez-en un peu jquery colorize image plugin.

0
zen