Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Abbiamo messo alla prova il drone Antigravity A1 capace di riprese in 8K a 360° che permette un reframe in post-produzione ad eliche ferme. Il concetto è molto valido, permette al pilota di concentrarsi sul volo e le manovre in tutta sicurezza e decidere con tutta tranquillità come gestire le riprese. La qualità dei video, tuttavia, ha bisogno di uno step in più per essere competitiva
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Dopo oltre 4 anni si rinnova la serie Sony Alpha 7 con la quinta generazione, che porta in dote veramente tante novità a partire dai 30fps e dal nuovo sensore partially stacked da 33Mpixel. L'abbiamo provata per un breve periodo, ecco come è andata dopo averla messa alle strette.
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme e Aston Martin Aramco F1 Team si sono (ri)unite dando alla vita un flagship con chip Snapdragon 8 Elite Gen 5 e design esclusivo ispirato alle monoposto di Formula 1. La Dream Edition introduce la nuova colorazione Lime Essence abbinata al tradizionale Aston Martin Racing Green, decorazioni intercambiabili personalizzate e una confezione a tema F1, intorno a uno smartphone dall'ottima dotazione tecnica con batteria da 7000mAh ricaricabile a 120W e isola fotografica intercambiabile
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


Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare Antigravity A1: drone futuristico per riprese a ...
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator Sony Alpha 7 V, anteprima e novità della ...
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1 realme GT 8 Pro Dream Edition: prestazioni da fl...
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
Amazon versa 180 milioni al Fisco e canc...
Meta, il Board di Supervisione guarda o...
DJI rivoluziona le consegne aeree: il nu...
Fibercop e Microsoft Italia uniscono per...
App Store Award 2025: scarica le 17 app ...
NVIDIA fa marcia indietro, il supporto P...
Addio definitivo alla GeForce GTX 1080: ...
Numeri record per gli iPhone 17: Apple s...
L'Italia del 2025 raccontata da Google: ...
Piaggio lancia Porter NPE, il pick-up el...
Xiaomi L1 a 153€: il proiettore smart 10...
Dopo Amazon, anche il data center di Gro...
Scoppia il caso Meta AI: l'Europa apre u...
Torna in sconto dopo mesi il super table...
Ricarica elettrica senza cavi: in Svizze...
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: 17:37.


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