AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Delphi DLL erstelt mit D10.4 Community, Aufruf in D2006 Zugriffsverletzung
Thema durchsuchen
Ansicht
Themen-Optionen

DLL erstelt mit D10.4 Community, Aufruf in D2006 Zugriffsverletzung

Ein Thema von Michael Habbe · begonnen am 21. Apr 2022 · letzter Beitrag vom 21. Apr 2022
Antwort Antwort
Benutzerbild von Michael Habbe
Michael Habbe

Registriert seit: 10. Aug 2005
264 Beiträge
 
Turbo Delphi für Win32
 
#1

DLL erstelt mit D10.4 Community, Aufruf in D2006 Zugriffsverletzung

  Alt 21. Apr 2022, 13:09
Hallo zusammen.

In diesem Thread (https://www.delphipraxis.net/203147-...er-delphi.html) hat Redeemer eine superkompakte Klasse für die Erstellung von QR-Codes erstellt.

Die wollte ich nach einem Test mit Delphi 10.4 Community nach Turbo Delphi portieren, stieß da aber auf einige Probleme u.a. bzgl. pngimage (was ich mit etwas Aufwand beheben konnte). Aber nach delphi 2006 sind zu viele Änderungen erfolgt.

Nach einigen Versuchen habe ich mir dann überlegt, eine DLL mit D10.4C zu erstellen, um sie dann in Delphi 2006 zu laden und den QR-Code per Bitmap zu übertragen.

Die DLL mit Delphi 10.4 Community:
Delphi-Quellcode:
library GiroCode;

uses
// ShareMem,
  System.SysUtils,
  System.Classes,
  Graphics, ExtCtrls,
  RedeemerQR in '..\..\..\BorlandDelphiKomponenten\RedeemerQR\RedeemerQR.pas',
  RedeemerInheritablePNG in '..\..\..\BorlandDelphiKomponenten\RedeemerQR\RedeemerInheritablePNG.pas';

{$R *.res}

type
  TTextGiroCode = array [1..12] of ShortString;

function GenerateCode(GC: TTextGiroCode; var QRbmp: TBitmap): Integer;
var
  QR: TRedeemerQR;
  GC_Text: String;
  i: Integer;
begin
  result := 0;
  GC_Text := '';
  for i := 1 to 11 do
    GC_Text := GC_Text + GC[i] + #13;
  GC_Text := GC_Text + GC[12];

  QR := TRedeemerQR.Create();
  try
    QR.LoadFromString(AnsiString(GC_Text), ecMedium);

// hier kommt es zur Zugriffsverletzung
    QRbmp.Width := QR.Width + 2;
// auch, wenn Height vor Width steht
    QRbmp.Height := QR.Height + 2;

    QRbmp.Canvas.Draw(1,1, QR);
    result := 1;
  finally
    QR.Free;
  end;
end;

exports
  GenerateCode index 1;

begin
end.

Der Aufruf aus Delphi 2006 (in D10.4C sieht die Unit genauso aus):
Delphi-Quellcode:
[...]
type
  TTextGiroCode = array [1..12] of ShortString;

{$R *.dfm}

procedure TForm1.Button3Click(Sender: TObject);
var
  FuncCall: function(GC: TTextGiroCode; var QRbmp: TBitmap): Integer;
  DllHandle: THandle;
  text: TTextGiroCode;
  i: Integer;
  bmp: TBitmap;
begin
  DllHandle := loadlibrary('GiroCode.dll');
  if DllHandle = 0 then
  begin
    ShowMessage('DLL-Ladefehler: GiroCode.dll nicht gefunden!');
    Exit;
  end;

  @FuncCall := getprocaddress(DllHandle, 'GenerateCode');
  if (@FuncCall = Nil) then
    ShowMessage('GetProcAddress-Fehler: GiroCode.dll enthält keine Function "GenerateCode"')
  else
  begin
    for i := 1 to 12 do
      text[i] := Memo1.Lines[i-1];
    bmp := TBitmap.Create;
    bmp.Width := 0;
    bmp.Height := 0;
    FuncCall(text, bmp);
    image1.Picture.Assign(bmp);
    //bmp.SaveToFile('qr.png');
  end;
  FreeLibrary(DLLHandle);
end;
Bei Aufruf der DLL aus D10.4C ist alles in Ordnung und der QR-Code wird angezeigt.
Wenn nun die DLL aus Delphi2006 aufgerufen wird, kommt es inzu einer Zugriffsverletzung an der Stelle, wo QRbmp.Width zugewiesen wird. Eine Auswertung der Variablen ergibt, dass diverse Eigenschaften nicht verfügbar sind.
Kann mir jemand helfen und verraten, wo mein Fehler liegt???

PS: Die Verwendung von "sharemem" oder nicht bringt keinen Unterschied.

Danke
Michael
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.453 Beiträge
 
Delphi 12 Athens
 
#2

AW: DLL erstelt mit D10.4 Community, Aufruf in D2006 Zugriffsverletzung

  Alt 21. Apr 2022, 13:45
Das Problem wird sein, dass die DLL eine TBitmap gemäß der Deklaration in Delphi 10.4 erwartet, dein Programm aber eine TBitmap gemäß der Deklaration in Delphi 2006 liefert.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.062 Beiträge
 
Delphi 12 Athens
 
#3

AW: DLL erstelt mit D10.4 Community, Aufruf in D2006 Zugriffsverletzung

  Alt 21. Apr 2022, 14:31
Nicht nur, dass das TBitmap anders aufgebaut sein kann (unterschedliche Delphi-versionen), die DLL verwendet auch ihren eigenen Speichermanager und ihre eigenen globalen Instanzen (Font/Brush/Pen/...), was auf der anderen Seite garnicht funktioniert kann.

Du könntest maximal ein MSDN-Library durchsuchenHBITMAP verwenden, wo dann die WinAPI den gemeinsamen Grundstock bereitstellt.
Oder nur den Inhalt (Pixelspeicher) des Bitmaps übergeben/kopieren.
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu (21. Apr 2022 um 14:33 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Michael Habbe
Michael Habbe

Registriert seit: 10. Aug 2005
264 Beiträge
 
Turbo Delphi für Win32
 
#4

AW: DLL erstelt mit D10.4 Community, Aufruf in D2006 Zugriffsverletzung

  Alt 21. Apr 2022, 15:26
Alles klar. Danke erstmal.

Überlege gerade, die Größe in Width und Height sowie die Pixels als Array zu übertragen.

Melde mich wieder....

Danke
Michael
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.275 Beiträge
 
Delphi 10.4 Sydney
 
#5

AW: DLL erstelt mit D10.4 Community, Aufruf in D2006 Zugriffsverletzung

  Alt 21. Apr 2022, 17:06
Hallo,
ich würde der Dll einen Dateinamen mit übergeben,
wohin die Dll das Bitmap speichern soll.
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.062 Beiträge
 
Delphi 12 Athens
 
#6

AW: DLL erstelt mit D10.4 Community, Aufruf in D2006 Zugriffsverletzung

  Alt 21. Apr 2022, 17:56
Also im Prinzip darfst du keine Objekte übergeben,
aber du kannst den Objekten ein Interface verpassen und das übergeben.

Selbst wenn die Objekte intern gleich wären,
alleine TObjekt (die Grundklasse für ALLES) ist zwischen 2006 und 10.4 schon in großen Teilen verändert.

Und auch Strings und teilweise die dymaischen Arrays wurden 2009 grundlegend umgebaut. (funktionell wurde nachher zwar wieder einiges Rückgebaut, aber strukturell immernoch unterschiedlich)


Aber selbst z.B. Delphi 2006 und 2007, welche nicht nur fast überall "identische" Klatten, sondern sogar den selben Compiler hatten und somit praktisch nahezu 100% kompatibel sind,
da sind TItgendwas der EXE und TIrgendwas der DLL komplett unterschiedlich, da jeder seine eigene RTTI hat, dazu kommt dann noch der jeweil eigene Speichermanager (den Teil könnte man über ShareMem umgehen) und eben auch jeder eigene Variablen für globale Objekte.
Hier also von den verwendeten globalen Font/Pen/Brush jeder seine eigene Instanz.






Oder hier eben das interne HBITMAP übergeben und drüben direkt damit arbeiten, bzw. einem anderen TBitmap dieses HBITMAP unterschieben, so dass beide Seiten mit dem Selben arbeiten.

Bei TStream gäbe es z.B. ein IStream im Windows, was aber leider nicht mit dem TStream von Delphi kompatibel ist, womit man TStream nicht direkt als IStream weitergeben kann, sondern erst umkopieren muß.
Oder eben den Speicher der Pixel oder die Bytes des Stream (SaveToStream) als Buffer übergeben und drüben wieder in ein anderes TBitmap einlesen.
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.
  Mit Zitat antworten Zitat
ol1uw

Registriert seit: 24. Jul 2004
Ort: Freiberg
69 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: DLL erstelt mit D10.4 Community, Aufruf in D2006 Zugriffsverletzung

  Alt 21. Apr 2022, 18:53
Hallo

wenn es nicht primär darum geht genau diese Komponente in einer DLL zu verwenden.
Es gibt ja durchaus alternativen z.B. DelphiZXingQRCodeEx.

Uwe
  Mit Zitat antworten Zitat
Antwort Antwort

 

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:40 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz