Ich verwende derzeit Jcrop, um einem Benutzer das Beschneiden eines Bildes zu ermöglichen. Sie können ein Bild auswählen, das Bild wird in das Bild geladen und ein Miniaturbild zeigt an, wie ein zugeschnittenes Bild aussehen würde.Jcrop-Bild wird in der Vorschau nicht korrekt angezeigt
Ich hatte dies funktioniert, als ich es auf localhost mit einem Wamp-Server getestet habe, aber sobald ich es auf meine Wordpress-Seite hochgeladen hatte, ging die Vorschau schief. Hier ist ein Screenshot, wie es aussieht, wenn es schief geht: image Die schwarzen Linien zeigen die gesamte Breite des Vorschaubildes, wie Sie sehen können, ist die Ausschnittauswahl verzerrt und verschwindet aus dem Miniaturbild.
Ich habe die Unterschiede in inspect Element auf meinem localhost und meine Wordpress-Website untersucht und festgestellt, dass die Breite und Höhe Element der Hälfte des Bildes ist hochgeladen, auf meinem localhost bekommt es die genaue Breite und Höhe des Bildes.
Hier sind meine Jcrop Einstellungen i verwenden und andere Codes, die relevant sein könnten:
$(document).ready(function(){
$('#preview').Jcrop({
onChange: function(coords){showPreview(coords, origWidth, origHeight, thumnailWidth, thumbnailHeight)},
onSelect: function(coords){showPreview(coords, origWidth, origHeight, thumnailWidth, thumbnailHeight)},
onRelease: function(){releaseCheck(minWidth, minHeight)},
boxWidth: 400,
bgColor: 'white',
allowSelect: 'false',
setSelect: [0, 0, minWidth, minHeight],
minSize: [ minWidth, minHeight ],
aspectRatio: minWidth/minHeight
}, function(){
jcrop_api = this;
});
$('#thumbnail-div').css({"width" : thumnailWidth, "height" : thumbnailHeight, "background-image" : "url(" + achtergrondLink + ")"});
$('#thumbnail').css({"opacity" : "0.7"});
});
Die minWidth und minHeight Werte die minimale Menge an Pixeln die Ernte Auswahl sonst wird das Bild zu niedrig sein sollten, sind Auflösung. Das jcrop-Plugin berechnet automatisch, wie das Bild in die Box skaliert wird. thumbnailwidth und height sind voreingestellte Variablen.
Dies ist die Showpreview-Funktion, die jedes Mal ausgeführt wird, wenn sich der Ausschnitt ändert oder ausgewählt wird.
function showPreview(c, origWidth, origHeight, thumnailWidth, thumbnailHeight){
$('#x1').val(c.x);
$('#y1').val(c.y);
$('#x2').val(c.x2);
$('#y2').val(c.y2);
$('#w').val(c.w);
$('#h').val(c.h);
var rx = thumnailWidth/c.w;
var ry = thumbnailHeight/c.h;
$('#thumbnail').css({
width: Math.round(rx * origWidth) + 'px',
height: Math.round(ry * origHeight) + 'px',
marginLeft: '-' + Math.round(rx * c.x) + 'px',
marginTop: '-' + Math.round(ry * c.y) + 'px'
});
}
Hier ist auch ein Link mit allen Code, den ich benutze ich alles in 1 Datei auch die Skript-Tags. Full source code
Ihre Antwort ist nicht korrekt, aber Sie behoben es trotzdem, ich sah auf Ihren Schnipsel und ich remmered, was ich tun musste –
Ich dachte, Sie geben die beiden schwarze Linien. – vel
Nein die schwarzen Linien wo zu zeigen, wie viel Breite der Thumbnail-Bereich war. –