Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
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 ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
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


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...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Il mondo piange Gladys West, la matemati...
Tomb Raider: Catalyst, il cast si allarg...
Renault Group chiude un ottimo 2025: Dac...
A questo prezzo la Blink Mini è difficil...
DJI Mini 4 Pro Fly More a 859€ su Amazon...
realme P4 Power avrà una batteria...
Marathon: data di uscita, edizioni e tut...
Dojo 3 riparte: Tesla affida a Intel il ...
Smartphone e attenzione in frantumi: Mat...
Aerei costruiti da robot umanoidi? L'eur...
Chery prende tutti in contropiede: batte...
Il colpo silenzioso di Intel: arriva l'u...
PosteMobile passa a TIM: ecco quando sca...
I nuovi chip M5 Pro, Max e Ultra sono se...
Nuove livree, tocca a Haas "Toyota&...
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: 10:38.


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