Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Google ha appena rinnovato la sua celebre serie A con il Pixel 10a, lo smartphone della serie più conveniente se consideriamo il rapporto tra costo e prestazioni. Con il chip Tensor G4, un design raffinato soprattutto sul retro e l'integrazione profonda di Gemini, il colosso di Mountain View promette un'esperienza premium a un prezzo accessibile. E il retro non ha nessuno scalino
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
Al MWC Qualcomm annuncia una coalizione industriale per lanciare il 6G entro il 2029 e introduce agenti IA per la gestione autonoma della RAN. Ericsson, presente sul palco, conferma la direzione: le reti del futuro saranno IA-native fin dalla progettazione
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air è un ultraleggero da 1 kg con Ryzen 5 6600H, display 14" 16:10 e 16 GB LPDDR5. Offre buona portabilità, autonomia discreta e costruzione in alluminio, ma storage PCIe 3.0 e RAM saldata limitano l'espandibilità. A 549 euro sfida brand più noti nella stessa fascia di mercato.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-02-2009, 15:27   #1
cipi
Senior Member
 
L'Avatar di cipi
 
Iscritto dal: May 2002
Città: udine
Messaggi: 546
[Excel] Usare in VBA una dll creata in VB6

Ciao,
come da oggetto sto provando a creare una dll da usare in VBA all'interno di Excel. Sono passato a VB6 (che non conosco bene) dopo aver provato in VB.NET e VC++.NET perché la dll deve essere COM (ActiveX). Non capisco però come creare una dll leggibile da VBA visto che mi da sempre problemi di "punto di ingresso" o di inizializzazione della dll.
Qualcuno sa fornirmi una procedura step by step?
Grazie 1000!
__________________
a chi non piace il vino... dio neghi anche l'acqua!
DELL Latitude E4300, iPhone 6
cipi è offline   Rispondi citando il messaggio o parte di esso
Old 26-02-2009, 18:49   #2
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Beh, vediamo prima di ridurre a zero gli errori sulla DLL...

Creare DLL in VB6 è abbastanza semplice.
Anzitutto devi aprire un nuovo progetto, del tipo "DLL ActiveX".
Verrà creata una classe di default...

Subito dopo vai su proprietà ed imposta alcune cose importanti :
Devi rinominare quanto prima ( prima di salvare ) il progetto con un nome più significativo di "Progetto1".
Inoltre inserisci una descrizione "intelligente" in "Descrizione Progetto", perchè in molti casi sarà l'unica voce che troverai negli elenchi vari dei Riferimenti utilizzabili, quando la dovrai importare !

A questo punto puoi tenere la prima ( ed unica ) classe nei "Moduli Di Classe" della DLL, eliminarla e/o aggiungerne altre.

Immagino tu sappia già tutto o quasi su Property Let / Property Get, Functions o Subs ( i futuri metodi della DLL... ).
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 26-02-2009, 18:53   #3
cipi
Senior Member
 
L'Avatar di cipi
 
Iscritto dal: May 2002
Città: udine
Messaggi: 546
diciamo che in seguito a queste tue domande vado a leggere qualcosa in più (santo google!)... non voglio farti perdere tempo per cose che posso trovare in internet... ti ringrazio invece delle "dritte"... quelle talvolta fanno la differenza.

vai con la parte due della spiegazione
__________________
a chi non piace il vino... dio neghi anche l'acqua!
DELL Latitude E4300, iPhone 6
cipi è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2009, 09:15   #4
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da cipi Guarda i messaggi
vai con la parte due della spiegazione
Ok, poniamo tu abbia adesso la tua bella DLL "NomeDll.Dll" compilata correttamente e funzionante, che ha 1 classe "ClasseDll", la quale espone ad es. un metodo ".MetodoDll".
Inoltre nella "Descrizione Progetto" avevi specificato ad es. "La Mia Prima DLL v1.0".

Apri un nuovo WorkBook Excel, vai nell'editor VBA ( le pagine con il codice... ), poi Strumenti/Riferimenti. Nella lista dei tanti Rif disponibili dovrebbe già esserci "La Mia Prima DLL v1.0". Se non ci fosse puoi sempre cercare manualmente la DLL con Sfoglia...
Una volta aggiunto il Rif al WorkBook, il codice essenziale per utilizzare la DLL è il seguente :

Codice:
    Dim nomeIstanza As nomeDll.ClasseDll
    Set nomeIstanza = New nomeDll.ClasseDll
    nomeIstanza.MetodoDll()
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 10-03-2009, 22:47   #5
cipi
Senior Member
 
L'Avatar di cipi
 
Iscritto dal: May 2002
Città: udine
Messaggi: 546
Chiedo scusa se rispondo solo ora ma ero incasinato fino a ieri...
Ho provato a fare come dici tu; la dll contiene un solo "Modulo di classe" con all'interno una funzione unica e semplice:
Codice:
Public Function Somma(ByRef x As Double, ByRef y As Double) As Double
Somma = x + y
End Function
Poi sul file excel ho aggiunto la dll (la vede) che si trova nella stessa directory del file excel. Nell'excel il modulo è come segue:
Codice:
Option Explicit
Public Declare Function Somma Lib "mF_colors.dll" (ByRef x As Double, ByRef y As Double) As Double

Sub Prova()
        Dim v(10) As Double
        v(1) = 0.3
        v(2) = 0.5
        v(3) = Somma(v(1), v(2))
End Sub
Ma a questo punto mi da un errore: "Impossibile trovare il punto di ingresso Somma della DLL in mF_colors.dll"
Cosa significa?
__________________
a chi non piace il vino... dio neghi anche l'acqua!
DELL Latitude E4300, iPhone 6
cipi è offline   Rispondi citando il messaggio o parte di esso
Old 11-03-2009, 10:18   #6
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da cipi Guarda i messaggi
Codice:
Public Function Somma(ByRef x As Double, ByRef y As Double) As Double
Somma = x + y
End Function
Codice:
Option Explicit
Public Declare Function Somma Lib "mF_colors.dll" (ByRef x As Double, ByRef y As Double) As Double

Sub Prova()
        Dim v(10) As Double
        v(1) = 0.3
        v(2) = 0.5
        v(3) = Somma(v(1), v(2))
End Sub
Ma quello non è il metodo che ho suggerito io.
Il metodo sicuro è importare il Rif della Dll, come spiegato sopra, e richiamarne metodi e proprietà così :
Codice:
    Dim nomeIstanza As nomeDll.ClasseDll
    Set nomeIstanza = New nomeDll.ClasseDll
    nomeIstanza.MetodoDll()
Poi non mi è chiaro perchè passi 2 valori numerici Double ByRef.
Usa ByVal.
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 11-03-2009, 11:35   #7
cipi
Senior Member
 
L'Avatar di cipi
 
Iscritto dal: May 2002
Città: udine
Messaggi: 546
Miiiiiiiii............. Non ci posso credere!!!! Funziona! Grazie.
Ok, ma non è finita: questo era solo "Hello World"! Quindi tornerò a "rompere" se mi perderò nei meandri della programmazione.
Ancora grazie,
cipi
__________________
a chi non piace il vino... dio neghi anche l'acqua!
DELL Latitude E4300, iPhone 6
cipi è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Roborock Saros 20: il robot preciso e molto sottile Roborock Saros 20: il robot preciso e molto sott...
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
Rocket Lab ha posticipato il lancio del ...
Dalla missione Artemis IV il razzo spazi...
Una delle sonde europee di ESA Proba-3 h...
Un modder fa girare Linux su PS5: GTA V ...
MacBook Neo: nessuna sorpresa nei primi ...
La serie POCO X8 Pro è pronta al ...
Smartphone: 2026 difficile per il mercat...
Star Wars: Knights of the Old Republic R...
Huang, NVIDIA: OpenClaw ha realizzato in...
Annunciano il recupero di 4,8 milioni di...
Oggi degli ottimi auricolari Sony con ca...
Muffa in casa? Questo deumidificatore da...
Sonos Era 100: il punto d'ingresso per u...
"Non stiamo sostituendo nessuno con...
Tutti i robot in offerta ora: prezzi bas...
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: 04:55.


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