Exception while using GDAL in C#
Asked Answered
S

12

21

I started to use gdal_csharp dll in my application and read a geotiff file. but it says:

The type initializer for 'OSGeo.GDAL.GdalPINVOKE' threw an exception.

it's my code

string fileName = @"/path to geotiff file";

OSGeo.GDAL.Dataset DS = 
    OSGeo.GDAL.Gdal.Open(fileName, OSGeo.GDAL.Access.GA_ReadOnly);

can anyone help?

Edit:

I have these dlls

enter image description here

This is the full error message:

enter image description here

It says that cannot load gdal_wrap. But when I'm going to add that dll to my application the below message is shown:

enter image description here

Splay answered 16/1, 2013 at 7:45 Comment(7)
Is this code verbatim, or do you have a real path assigned to fileName? It also helps if you mention what you have done to try and solve this on your own.Pease
Since it is the type initializer it is not related to the fileName or the call to Open method. Check your dependencies first(.net/OS version/library)Scorbutic
@Tieson T. Yes, a real path is assigned to the fileName variable.Splay
Most likely one or more dll (gdal is depended on) is missing. Can you post full stacktrace?Zigrang
As mentioned by PLB, it sounds like there is a dll missing, use Dependency Walker and Process Monitor to identify which one.Dewayne
Look at the exception details (and edit them into your question). There should be an inner exception which shows you what went wrong in the type initializer.Saran
Was this problem ever resolved? I ran into the same problems using VS 2012 and GDALInfo.cs.Samathasamau
K
22

As an update to this there is now GDAL maintained by the SharpMap team as a nuget package here which is updated regularly. You'll need to install both the "GDAL.Native" and "GDAL" package for your project to use the GDAL library. Once installed via nuget, they'll automatically create a "GdalConfiguration.cs" that you call into to initialize the GDAL paths before starting. The only thing to note is the packages are setup to automatically copy their appropriate GDAL libraries to your output build directory. If you need to deploy the application you'll have to do a bit of extra effort.

Kanter answered 1/6, 2016 at 19:42 Comment(3)
Yes, this is it. Key was to also install GDAL.Native. Beats me why they don't have it be a dependency on GDAL if you always need both.Luck
How do I deploy this? I'm getting this issue after deploymentZito
Once you install GDAL and GDAL.Native you still need to call GdalConfiguration.ConfigureGdal().Inanna
E
5

To solve this one I downloaded the prebuilt libraries as described here and grabbed FWTools from here.

The unmanaged DLLs I used came from \install_dir\FWTools2.4.7\bin and the C# wrapper from \install_dir\FWTools2.4.7\csharp.

gdal14.dll, msvcp71.dll and msvcr71.dll came from here, which is mentioned in that first link.

The error you are receiving re gdal_wrap.dll is referring to one of its dependencies. I threw that DLL into depends and it found a lengthy list of dependent libraries. Note that this list is likely longer due to my use of the FWTools distribution - if you built your version from source it may look different, though the same principles apply.

To get the above code to work on my machine I had the following files in my output directory:

gdal14.dll
gdalconst_csharp.dll
gdalconst_wrap.dll
gdal_csharp.dll
gdal_fw.dll
gdal_wrap.dll
geos_fw.dll
geotiff_fw.dll
hdf5dll.dll
hdf_fw.dll
jpeg12_osgeo.dll
jpeg_osgeo.dll
libcurl.dll
libeay32.dll
libexpat.dll
libmysql.dll
libpq.dll
libtiff_fw.dll
lti_dsdk_dll.dll
mfhdf_fw.dll
msvcp71.dll
msvcr71.dll
NCScnet_fw.dll
NCSEcw_fw.dll
NCSUtil_fw.dll
netcdf.dll
ogdi_32b1.dll
proj.dll
sqlite3.dll
ssleay32.dll
szlibdll.dll
xerces-c_2_7.dll
zlib1.dll
zlib_osgeo.dll

Now these don't necessarily all have to live in the output directory - as long as they are on your path somewhere (e.g., \Windows\System32) you should be fine.

Epp answered 5/2, 2013 at 8:51 Comment(0)
I
5

I know it's an old question, but I believe my answer might help someone.

I was able to successfully compile and run examples using c# gdal by doing the following:

  1. Downloading GDAL sdk from http://www.gisinternals.com/ (64 bit in my case)
  2. Executing the SDKShell.bat script to set the system environment paths, etc.
  3. Creating a project in Visual Studio. And referencing all .net dlls (the ones that names end with _csharp.dll), located in \bin\gdal\csharp\ inside downloaded SDK
  4. Setting platform target in Visual Studio project settings to x64 to get rid og bad image format exceptions. The last step wouldn't be necessary if I'd choosse 32bit version of SDK to work with.

I did not install fwtools at all. It seems like the last build of fw_tools is relatively old, and sdk is still maintained.

Incase answered 9/12, 2015 at 14:47 Comment(1)
Setting platform target in Visual Studio project settings to x64 this part helps me.Guardant
S
4

I know this is a reasonably old question now, but I found this in google after researching the same problem myself, so this means that for searches on this error this is still a very relevant page to update given it's still in the top 5 from the big G when the same problem is searched.

In my case it was the answers from "DeusExMachina25" and "Grzegorz Sławecki" that struck a chord.

I'm writing some software that makes use of the current builds of "sharp map" on NUGet (as of 24th of June 2016) and my software kept throwing the same gdal_wrap message as the OP originally reported, even though I'm using the GDAL package provided by the Sharpmap team.

I didn't realize that the NUGet installer for the package had installed a configuration class for me, but after reading through this thread and finding out that it does I went looking for it.

Sure enough I found the file 'GdalConfiguration.cs' in my project and added a call to it in an appropriate place in my project, expecting GDAL to be initialized correctly.

However, after I did this, I still had the same problem.

So, I set a break point on the beginning of the GDAL routine that had been added, and waited until the break point was hit.

I then traced through the method, and eventually found the following line:

var gdalPath = Path.Combine(executingDirectory, "gdal");

at around line 64 in the file.

Tracing through this, I noticed that the path being built was:

d:\geodata\maptest\maptest\bin\debug\gdal

but the NUGet installer had installed all the dependent assemblies in

d:\geodata\maptest\maptest\bin\debug

Exactly where I expected them to be.

I changed line 64 so that it now read:

var gdalPath = Path.Combine(executingDirectory, "");

and voila, the error went away and everything started to work.

I could have done things the other way too, and created a folder called gdal, then copied everything into that, but that then would have gotten deleted when I did a "clean" on the project.

Since the config class, set's up various environment variables based on this path, quickly changing that one line also fixes up the path for the GDAL data files , plugins and a few other things too.

Speculator answered 24/6, 2016 at 21:24 Comment(0)
T
1

You could try using Dependency Walker to see if there are any dlls that gdal_csharp is trying to grab but cannot.

Teador answered 29/1, 2013 at 17:56 Comment(5)
@Dewayne - Sorry, I didn't see that you already suggested that.Teador
@Hossein - Try copying the dll to the output directory eather manually or with a Build Event or adding it to your project (not as a reference) and setting the "Copy to Output Directory". See this related questionTeador
I was just looking back at the popup you posted. The dll will need to be put in the folder where your exe is, probably the bin/debug or release sub-folders in your project.Teador
Is it still looking for gdal_wrap.dll or a different dll?Teador
Yes, it is still looking for gdal_wrap.dll!Splay
C
1

Have you added the path to your GDAL libraries to your PATH environment variable? I downloaded my files from http://vbkto.dyndns.org/sdk/?_sm_au_=iVVqjsHS2n46WP00 and here's my path: C:\libs\release-1600-gdal-1-9-mapserver-6-2\bin.

Canine answered 14/2, 2013 at 13:20 Comment(0)
S
0

To use the C#-bindings of GDAL you need an installation of FWTools (from http://fwtools.maptools.org/) as well as the most current binaries that match your system (from http://vbkto.dyndns.org/sdk/). Afterwards it is important to include the bin-directory of FWTools (example for 64bit-systems: C:\Program Files (x86)\FWTools2.4.7\bin) in your PATH variable as well as the necessary dlls (gdal_csharp.dll was mentioned in the question) in your Visual Studio project references. I outlined the complete processs here.

This process works on 32 bit as well as 64 bit systems, I tested it with VS 2010 and 2012.

Samathasamau answered 6/5, 2013 at 21:16 Comment(0)
C
0

Remove the path to python from the system variables. Because the main gdal paths conflict with python 27

Cabbagehead answered 2/7, 2019 at 14:41 Comment(0)
A
0

Did you forget to:

GdalConfiguration.ConfigureGdal();
GdalConfiguration.ConfigureOgr();

Gdal.AllRegister();
Ogr.RegisterAll();
Alamein answered 20/12, 2021 at 20:5 Comment(0)
M
0

In my case the issue was:

  • I had 2 projects in my solution: ProjectA and ProjectB

  • I was executing ProjectA, and ProjectA was referencing ProjectB

  • ProjectB is the one that contained the references to both GDAL and GDAL.Native

  • ProjectA tried to find GDAL.Native's files under ProjectA\bin\Debug\netcoreapp3.1\gdal ... but in reality those files are under ProjectB\bin\Debug\netcoreapp3.1\gdal


Possible solutions:

  • Dirty solution: just copy the files from ProjectB under ProjectA\bin\Debug\netcoreapp3.1

  • Okayish solution: add the GDAL.Native package to each one of your "entry projects"


I don't like either of those solutions. This stuff happens under GdalConfiguration.cs, so maybe there is a way to modify it to find the correct path.

Mineral answered 15/3, 2022 at 10:8 Comment(0)
A
0

Fixed it by changing config line from

string executingAssemblyFile = new Uri(Assembly.GetExecutingAssembly().GetName().CodeBase).LocalPath;
executingDirectory = Path.GetDirectoryName(executingAssemblyFile);

to

executingDirectory = Directory.GetCurrentDirectory();
Assured answered 28/2, 2023 at 10:12 Comment(0)
A
0

This answer may or may not be fully relevant to the OP, but I feel it may be useful to some. I ran into this question recently in the context of building an ArcGIS Pro standalone .NET CoreHost client application which performs various GIS data I/O. The native ESRI ArcGIS.Core and ArcGIS.CoreHost libraries which are available for this kind of development don't provide full support for all GIS data types, so I tried leveraging GDAL through the MaxRev.GDAL.Universal NuGet package. My integration tests against the GDAL operations continuously ran into the error reported in the OP. Looking into my ./bin directory, I confirmed that the gdal_wrap.dll library was not available.

SOLUTION: To leverage the ArcGIS Pro CoreHost libraries, it's standard practice to run their Host.Initialize() routine prior to attempting access to any of the ESRI components. Because ArcGIS makes use of GDAL internally however though, it appears this initialization routine runs afoul of the GDAL library initialization (achieved with MaxRev.GDAL.Universal by calling their wrapper operation GdalBase.ConfigureAll()). By switching the order of these operations and running the GDAL library initialization FIRST, I verified the required GDAL libraries were initialized into the ./bin directory and everything ran smoothly without error. I also verified the Host.Initialize() operation completed properly and ESRI-based I/O that I was testing also worked properly.

Alberich answered 31/7, 2024 at 15:58 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.