Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-11-2010, 09:16   #1
majowski86
Senior Member
 
L'Avatar di majowski86
 
Iscritto dal: Jan 2008
Città: Trieste - Bologna
Messaggi: 952
[Javascript] Problema selezione immagini casuale

Ciao a tutti.
Ho sviluppato per un sito eprsonale la seguente funzioncina:

function put_random_image()
{
var hiddenValue = document.getElementById('ctl00_PhotoUC_ImagesHidden').value;
fileList = new Array();

var i = 0;
var ind = 0;
var index = 0;

while (true)
{
index = hiddenValue.indexOf(';', ind)
if (index == -1)
break;

fileList[i] = hiddenValue.substring(ind,index);
i++;
ind = index + 1;
}

var randValue = Math.floor(Math.random() * (i + 1));

if (randValue > (fileList.length - 1))
randValue = (fileList.length - 1);

document.getElementById('PhotoUcImage').setAttribute('src', fileList[randValue]);
//alert(fileList[randValue]);
}

In sostanza al caricamento di una pagina ASPX, vado a popolare il contenuto di un campo hidden con l'elenco dei file jpeg presenti in una cartella specifica. poi da questo javascript metto in un array le varie imamgini, scelgo un'immagine random e la vosualizzo. Il mio problema ora è il segiente:

Il javascript a livello teorico finziona alla grande, andando in debug vedo che assegna correttamente all'array tutti i file, ne sceglie uno a caso, quindi aggiorna il parametro src dell'immagine. Quello che invece capita è che solo alcune di queste immagini, quando vengono scelte, aggiornano veramente l'immagine lato client, e sono sempre le stesse immagini, mentre le altre non vanno mai. Ho verificato i path e sono corretti, le imamgini sono tutte jpeg, stesse dimensioni ecc.. non riesco a capire per chè certe vengono visualizzate e altre no.. Un'altra cosa strana è che con lo stesso path ripreso dal javascript se metto un tag <img> normale all'intenro della pagina l'immagine viene visualizzata correttamente, anche se la stessa immagine non appare se uso la funzione sopra.
Qualcuno mi può aiutare?
__________________
Ho comprato da: Lesto_Fante, cipo88, Qnick, jerrygdm, Dax86+, microcip, ilcalmo, sgaga86 - Ho venduto a:dipancrazio82, senda, JJ McTiss, marcandrea, DEXTHA, orso232, Crisa..., ombra666, Gighen-, simpatiacaserta, toniz - Black list: motosensei
majowski86 è offline   Rispondi citando il messaggio o parte di esso
Old 26-11-2010, 10:34   #2
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Ciao, un ciclo while fatto in quel modo non si può vedere , tra l'altro c'è una funziona apposta per fare quel lavoro, String.split.

Detto questo comunque sembra tutto apposto, magari cancella la cache del browser.

Le immagini che non caricano hanno circa la medesima dimensione delle altre vero? non è che sono n-mila MByte di immagine
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 26-11-2010, 11:04   #3
majowski86
Senior Member
 
L'Avatar di majowski86
 
Iscritto dal: Jan 2008
Città: Trieste - Bologna
Messaggi: 952
Quote:
Originariamente inviato da MEMon Guarda i messaggi
Ciao, un ciclo while fatto in quel modo non si può vedere , tra l'altro c'è una funziona apposta per fare quel lavoro, String.split.

Detto questo comunque sembra tutto apposto, magari cancella la cache del browser.

Le immagini che non caricano hanno circa la medesima dimensione delle altre vero? non è che sono n-mila MByte di immagine
Sono daccordo sul while e sul split, ma ho trovato la funzione così come la vedi e l'ho inserita nel sito per provare se funziona. Non ho idea di chi l'abbia fatta. La sto già sistemando e adattando ulteriormente per quello che mi serve prima di mettere su il sito.

Cmq (e qui c'è da farsi delle grasse risate) ho notato che a seconda del software usato per salvare le imamgini in quiestione (tutti jpeg ottenuti da raw) funzionano o meno all'intenro del javascript. I file salvati con photoshop funzionano, quelli salvati con picasa e modificati con paint.NET no. Non mi spiego questa differenza, visto che le stesse immagini messe in un normale tag img funzionano bene, ma da questo js no. e per quanto può sembrare assurdo giuro che è così. Ho provato ad aprire una delle immagini che funzionano con picasa e salvarla con la stessa estensione e nome diverso. Risultato? mettendola direttamente in un tag img funziona, se viene selezionata dal js no..
Le immagini sono della stessa dimensione.

Cmq ci rinuncio a capire il perchè faccia così, rimetto a posto la funzione e evito di salvare le foto con picasa..



EDIT:
Ecco come si presenta corretta un pochino:

function put_random_image()
{
var hiddenValue = document.getElementById('ctl00_PhotoUC_ImagesHidden').value;

fileList = new Array();
fileList = hiddenValue.split(';');

var randValue = Math.floor((Math.random() * 1000) % (fileList.length));

if (randValue > (fileList.length - 1))
randValue = (fileList.length - 1);

document.getElementById('PhotoUcImage').setAttribute('src', fileList[randValue]);
//alert(fileList[randValue]);
}
__________________
Ho comprato da: Lesto_Fante, cipo88, Qnick, jerrygdm, Dax86+, microcip, ilcalmo, sgaga86 - Ho venduto a:dipancrazio82, senda, JJ McTiss, marcandrea, DEXTHA, orso232, Crisa..., ombra666, Gighen-, simpatiacaserta, toniz - Black list: motosensei

Ultima modifica di majowski86 : 26-11-2010 alle 11:23.
majowski86 è offline   Rispondi citando il messaggio o parte di esso
Old 26-11-2010, 11:58   #4
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
L'elemento con id "PhotoUcImage" come si presenta realmente? Hai provato a inserire le immagini che nn vanno a mano propri in quell'elemento?

Hai provato a metterle come background di un div?

Fai anche questa prova:
Codice:
function put_random_image() {
	var hiddenValue = document.getElementById('ctl00_PhotoUC_ImagesHidden').value;
	fileList = new Array();
	fileList = hiddenValue.split(';');
	var randValue = Math.floor((Math.random() * 1000) % (fileList.length));
	randValue = (randValue > fileList.length - 1) ? fileList.length - 1 : randValue;
	Image img=new Image();
	// inizia a precaricare l'img, volendo puoi anche aggiungere un evento onLoad per vedere se la carica bene
	img.src=fileList[randValue];  
	document.getElementById('PhotoUcImage').setAttribute('src', img.src);
}

Ultima modifica di MEMon : 26-11-2010 alle 12:00.
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 26-11-2010, 13:11   #5
majowski86
Senior Member
 
L'Avatar di majowski86
 
Iscritto dal: Jan 2008
Città: Trieste - Bologna
Messaggi: 952
Ciao. L'elemento con id "PhotoUcImage" non è altro un tag <img> al quale cambio il src. Ho provato a inserire le immagini che non vanno in quell'elemento direttamente all'interno della pagina asp, e vengono visualizzate correttamente, proprio per questo è tutto ancora più strano.

Ho provato con la parte di codice che mi hai scritto tu, ma mi da solo un generico errore "previsto oggetto" quando richiamo il js, senza indicarmi niente di più

ora provo ad usare il div al posto del tag img, vedo se cambia qualcosa. A questa possibiloità non ci avevo proprio pensato

Ti faccio sapere se cambia qualcosa, intanto grazie mille
__________________
Ho comprato da: Lesto_Fante, cipo88, Qnick, jerrygdm, Dax86+, microcip, ilcalmo, sgaga86 - Ho venduto a:dipancrazio82, senda, JJ McTiss, marcandrea, DEXTHA, orso232, Crisa..., ombra666, Gighen-, simpatiacaserta, toniz - Black list: motosensei

Ultima modifica di majowski86 : 26-11-2010 alle 13:36.
majowski86 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
Le 10 migliori offerte Amazon di Pasqua:...
Nuove fotografie dagli astronauti di Art...
La toilette della capsula Orion Integrit...
GeForce NOW: ecco tutte le novità in arr...
Il Realme 16 5G debutta sul mercato glob...
HONOR svela tre nuovi tablet: il più int...
Tineco Floor One S9 Master: aspira e pul...
Vivo X300 Ultra, il lancio globale è ini...
Offerte robot aspirapolvere Amazon: ECOV...
L'AI genera codice in 8 minuti e i senio...
Ring Intercom Audio a 44,99€ su Amazon: ...
Apple iPhone 16 crolla a 689€: ecco perc...
Google Pixel 9 a 449,90€ con caricatore ...
Ecco la top 7 delle offerte Amazon, aggi...
Ex ingegnere ammette il sabotaggio: migl...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 03:52.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v