Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
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


Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
iPhone Air 2 in arrivo già nel 20...
Vimeo quasi svuotata: Bending Spoons ann...
Altro che bolla: per Huang l'AI è...
Battlefield 6: la Stagione 2 segner&agra...
Da Sony due nuovi giradischi wireless pe...
Arriva l'addio definitivo di Intel ad Al...
Attacco AI su Google Calendar: Gemini pu...
Renault vuole reintegrare Ampere nel gru...
1Password introduce un nuovo avviso anti...
Windows 11, nuovo bug blocca le app: col...
Tre sistemi operativi in uno smartphone:...
Crypto in Italia: 2,8 milioni di possess...
Pubblicato 'il carattere' di Claude: uti...
Siri cambia volto su iOS 27 e macOS 27: ...
Apple contro Intel e AMD: i numeri che r...
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: 22:31.


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