Hallo Gemeinde,
Ich bin dabei eine homepage aufzubauen. Ich habe einige bilder, die kleiner auf der page angezeigt werden. Wenn auf das bild geklickt wird, wird das bild vergroessert. Das erreiche ich mit der JavaScript routine window.open, in dem ich das bild vergroessert anzeige:
function insertImg()
{
var width = 680;
var height = 510;
var left = (screen.width - width)/2;
var top = (screen.height - height)/2;
var params = 'width='+width;
params += ', height='+height;
params += ', top='+top;
params += ', left='+left;
params += ', directories=no';
params += ', location=no';
params += ', menubar=no';
params += ', resizable=no';
params += ', scrollbars=no';
params += ', status=no';
params += ', toolbar=no';
// alert("The params are \n" + params + "\nResolution " + screen.width + "x" + screen.height);
window2=window.open("","pictwin", params);
window2.focus();
}
Das ergebnis ist wie folgt:
http://myweb.saudi.net.sa/skaelbert/Messages/window.open.jpg
Im prinzip funktioniert die prozedur ja ganz gut. Das neue window wird zentriert auf dem bildschirm geoeffnet und zentriert in abhaengigkeit von der screen resolution, alles gut soweit. Was mich stoert ist, dass das bild im neuen window nicht zentriert ist.
Das bild hat im original eine aufloesung von 640 x 480.
Gebe ich diese werte vor fuer 'width' und 'height', wird das bild etwas kleiner angezeigt mit einem zoom cursor als kleine lupe mit einem + darauf. Wenn ich die cursor lupe klicke, fuellt das bild das gesamte window und ist zentriert.
Wenn ich die cursor lupe nicht haben will, sondern das bild gleich in voller groesse anzeigen will, muss ich die window.open parameter 'hight' und 'width' um je 40 pixel groesse machen als das bild gross ist. Dann wird das bild von vornherein voll angezeigt, aber eben nicht zentriert.
Mein problem laesst nach meiner Ansicht 2 loesungen zu, die ich aber nicht zu programmieren weiss:
1. Eine zoom-in instruction muss in die routine eingefuegt werden, die den klick auf das fenster mit dem zoom cursor erspart.
2. Das bild muss durch zusatz-instructionen zentriert werden in das geoeffnete fenster.
Ich weiss weder, wie ich das eine, noch das andere programmieren soll.
Problem 2:
Eines meiner Bilder, eine landkarte von Thailand, ist vertikal groesser als der Bildschirm. Ich kann nun das window dimensionieren, wie ich will. Das bild wird immer vollstaendig und verkleinert in dem neuen window angezeigt. Es ist immer ein zoom cursor vorhanden, und ein klick vergrossert die karte dann auf originalgroesse, wobei der untere teil erst einmal nicht angezeigt wird. Ich habe den parameter 'scollbar=yes' eingefuehrt, aber ohne zoom cursor klick geht es nicht. Wie kann ich erreichen, dass das bild von vornherein mit voller 'width' und mit einer 'height' angezeigt wird bis zu der groesse, die zu der 'width' passt? Mit der scroll bar kann dann jeweils der gewuensche Ausschnitt in das window gescrollt werden.
Wer kann mir helfen?
Viele Gruesse aus der Wueste
SigiSaudi
Homepage selbermachen 7.851 Themen, 35.616 Beiträge
Hallo Sigi Saudi,
schalte mal die "Automatische Bildgrößenanpassung" wie im ersten Kommentar beschrieben ab,
dann funktioniert es auch richtig. Browser danach immer neu starten! Hier mein Testcode:
_______________________________________
function newwindow()
{
var width = 540 + 20;
var height = 480 + 28;
var left = (screen.width - width)/2;
var top = ((screen.height - height)/2) - 35;
// var left = left;
// var top = top;
var params = 'width='+width;
params += ', height='+height;
params += ', top='+top;
params += ', left='+left;
params += ', directories=no';
params += ', location=no';
params += ', menubar=no';
params += ', resizable=no';
params += ', scrollbars=no';
params += ', status=no';
params += ', toolbar=no';
alert("The params are \n" + params + "\nResolution " + screen.width + "x" + screen.height);
window2=window.open("bilder/bild2.jpg","picshow", params);
window2.focus();
}
_______________________________________
Die Parameter werden bei mir auch in der Alertbox richtig angezeigt - inklusive Ausgleichswerte.
Aber es ist nicht wirklich die Lösung! Es gibt zwar die Möglichkeit, per Javascript die Breite und
Höhe des aktuellen Bildes zu ermitteln, die könnte man dann als Parameter bei unterschiedlich
großen Bildern einsetzen, aber mir ist das bisher nich nicht gelungen - warum auch immer.
Die "Automatische Bildgrößenanpassung" ist aber genau der kritische Punkt, da man nicht weiß,
ob sie beim Nutzer ein- oder ausgeschaltet ist. Deshalb ist es sinnvoll, die Anzeige durch eine separate Datei z.B. "vollbild_01.html" zu steuern - Aufruf: window2=window.open("vollbild_01.html","picshow", params);
Wenn es sich um immer gleichgroße Bilder handelt, ist das ja auch einfach, bei unterschiedlichen Größen muss die Tabelle als Bildcontainer natürlich immer wieder neu angepasst werden, damit es schick aussieht.
Ein kleiner Trick für solche Fälle: Mache Dir ein Leerbild mit der größten Auflösung Deiner Bilder plus ca. 25 Pixel.
Nun setzt Du in dieses Leerbild mit weißem oder andersfarbigem Hintergrund einen 1-Pixel-breiten Rahmen als Bildumrandung - ca. 15 Pixel vom Rand des Leerbildes. In diesen Rahmen platzierst Du dann alle Deine Bilder mittig und speicherst sie neu ab. So sieht es durch den Rahmen wenigstens einigermaßen schick aus, alle Bilder erscheinen mittig im Anzeigefenster und Du musst nur eine Tabelle mit fester Größe definieren. Aber ob Dir das zusagt?
Bastle gerade an einer speziellen Fotoshow mit weichen Überblendungen sowie Slideshow mit Sound für eine Webseite. Problem: nicht alle Javascript-Routinen funktionieren in Firefox, habe aber nun eine gefunden und muss sie entsprechend der Webseite anpassen.
Gib mal Nachricht, ob und wie Du das Problem gelöst hast.
Grüße aus dem doch etwas kühleren Bayern
ewbayern