mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 10:25:33 +00:00
96d762c6eb
%HOMEPATH% does, however. Fixes https://gitlab.freedesktop.org/gstreamer/gst-docs/-/issues/52 Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/7859>
224 lines
11 KiB
Markdown
224 lines
11 KiB
Markdown
# Installing on Windows
|
|
|
|
## Supported platforms
|
|
|
|
* Windows 7
|
|
* Windows 8
|
|
* Windows 8.1
|
|
* Windows 10
|
|
* Windows 11 and newer
|
|
|
|
## Prerequisites
|
|
|
|
To develop applications using GStreamer for Windows we recommend using Windows
|
|
10 or newer with Microsoft Visual Studio 2019 or newer. Older versions of each
|
|
may also work, but they are not recommended.
|
|
|
|
GStreamer package includes C headers (`.h`) and library files (`.lib`) valid
|
|
for any version of [Microsoft Visual Studio](http://www.microsoft.com/visualstudio).
|
|
For convenience, property pages (`.props`) are also included which extremely
|
|
simplify creating new projects.
|
|
|
|
## Download and install GStreamer binaries
|
|
|
|
There are 3 sets of files in GStreamer binaries:
|
|
|
|
- The runtime files are needed to run GStreamer applications. You probably want
|
|
to distribute these files with your application (or the installer below).
|
|
- The development files are **additional** files you need at build-time to
|
|
create GStreamer applications.
|
|
- The [Merge Modules](http://msdn.microsoft.com/en-us/library/windows/desktop/aa369820%28v=vs.85%29.aspx)
|
|
files are **additional** files you can use to deploy GStreamer binaries
|
|
alongside your application (see [Windows deployment](deploying/windows.md)).
|
|
|
|
Get both **the Runtime and Development** installers appropriate for
|
|
your architecture from the [GStreamer download page](https://gstreamer.freedesktop.org/download/).
|
|
|
|
If in doubt, download the 64-bit MSVC packages:
|
|
- Runtime installer: e.g. `gstreamer-1.0-msvc-x86_64-{VERSION}.msi`
|
|
- Development files installer: e.g. `gstreamer-1.0-devel-msvc-x86_64-{VERSION}.msi`
|
|
|
|
Execute the installers and choose an installation folder. The suggested
|
|
default is usually OK.
|
|
|
|
> ![Warning](images/icons/emoticons/warning.svg)
|
|
> If you plan to use Visual Studio, **close it before installing GStreamer**.
|
|
> The installer will define new environment variables which will not be picked up by Visual Studio if it is open.
|
|
|
|
> On **Windows 8** and **Windows 10**, it might be necessary to log out and log back in to your account
|
|
> after the installation for the newly defined environment variables to be picked up by Visual Studio.
|
|
|
|
It is the application's responsibility to ensure that, at runtime,
|
|
GStreamer can access its libraries and plugins. It can be done by adding
|
|
`%GSTREAMER_ROOT_X86%\bin` to the `PATH` environment variable, or
|
|
by running the application from this same folder.
|
|
|
|
How to do this:
|
|
Windows start icon > Search "environment variables" > Edit the system environment variables (will open System Properties)
|
|
> Environment Variables > System variables > Variable :Path > Edit > New > Paste "C:\gstreamer\1.0\msvc_x86_64\bin" > OK
|
|
|
|
At runtime, GStreamer will look for its plugins in the following folders:
|
|
|
|
- `%HOMEDRIVE%%HOMEPATH%/.gstreamer-1.0/plugins`
|
|
- `C:\gstreamer\1.0\x86\lib\gstreamer-1.0`
|
|
- `<location of gstreamer-1.0-0.dll>\..\lib\gstreamer-1.0`
|
|
- `%GST_PLUGIN_PATH%`
|
|
|
|
So, typically, if your application can find `gstreamer-1.0-0.dll`,
|
|
it will find the GStreamer plugins, as long as the installation folder
|
|
structure is unmodified. If you do change this structure in your
|
|
application, then you can use the `GST_PLUGIN_PATH` environment
|
|
variable to point GStreamer to its plugins. The plugins are initially
|
|
found at `%GSTREAMER_ROOT_X86%\lib\gstreamer-1.0`.
|
|
|
|
Additionally, if you want to prevent GStreamer from looking in all the
|
|
default folders listed above, you can set the `GST_PLUGIN_SYSTEM_PATH`
|
|
environment variable to point where the plugins are located.
|
|
|
|
## Configure your development environment
|
|
|
|
**NOTE: these instructions are out of date, exercise caution while following them**
|
|
|
|
### Building the tutorials
|
|
|
|
The tutorials code, along with project files and a solution file for
|
|
Visual Studio 2010, are in the
|
|
[gst-docs](https://gitlab.freedesktop.org/gstreamer/gstreamer/-/tree/main/subprojects/gst-docs) in the
|
|
`examples/tutorials` folder.
|
|
|
|
In order to prevent accidental modification of the original code, and to
|
|
make sure Visual Studio has the necessary permissions to write the
|
|
output files, copy the entire `tutorials` folder to a place of your
|
|
liking, and work from there.
|
|
|
|
> ![Information](images/icons/emoticons/information.svg)
|
|
> **64-bit Users**
|
|
>
|
|
> Use the `GSTREAMER_ROOT_X86_64` environment variable if you have installed GStreamer binaries for 64-bit platforms.
|
|
> Both GStreamer packages (32 and 64-bit) can be installed simultaneously, hence the separate environment variables.
|
|
>
|
|
> Make sure you select the Solution Configuration that matches GStreamer that you have installed: `Win32` for 32-bit or `x64` for 64-bit.
|
|
>
|
|
> ![Windows Install Configuration](images/WindowsInstall-Configuration.png)
|
|
|
|
You can launch Visual Studio 2010 and load your copy of the
|
|
`tutorials.sln` solution file (Click on the screen shots to enlarge them).
|
|
|
|
![](images/WindowsInstall2.png)
|
|
|
|
![](images/WindowsInstall1.png)
|
|
|
|
Hit **F7**, press the Build Solution button
|
|
![](images/WindowsInstall-BuildSolution.png) or go to Build →
|
|
Build Solution. All projects should build without problems.
|
|
|
|
### Running the tutorials
|
|
|
|
In order to run the tutorials, we will set the current working directory
|
|
to `%GSTREAMER_ROOT_X86%\bin` in the Debugging section of the
|
|
project properties. **This property is not stored in the project files,
|
|
so you will need to manually add it to every tutorial you want to run
|
|
from within Visual Studio**. Right click on a project in the Solution
|
|
Explorer, Properties → Debugging → Working Directory, and type
|
|
`$(GSTREAMER_ROOT_X86)\bin`.
|
|
|
|
(The `$(...)` notation is required to access environment variables
|
|
from within Visual Studio property pages. You use the `%...%` notation in Windows
|
|
Explorer and in CMD scripts.)
|
|
|
|
You should now be able to run the tutorials.
|
|
|
|
### Creating new projects manually
|
|
|
|
**If you want to create 64-bit applications, remember also to create x64
|
|
Solution and Project configurations as
|
|
explained [here](http://msdn.microsoft.com/en-us/library/9yb4317s\(v=vs.100\).aspx).**
|
|
|
|
#### Include the necessary GStreamer Property Sheet
|
|
|
|
The included property sheets make creating new projects extremely easy.
|
|
In Visual Studio 2010 create a new project (Normally a `Win32
|
|
Console` or `Win32 Application`). Then go to the Property Manager
|
|
(View→Property Manager), right-click on your project and select “Add
|
|
Existing Property Sheet...”.
|
|
|
|
> In Visual Studio 2017, the property manager can be found in
|
|
> View→Other Windows→Property Manager
|
|
|
|
Navigate to `%GSTREAMER_ROOT_X86%\share\vs\2010\libs` and load `gstreamer-1.0.props`.
|
|
|
|
This property sheet contains the directories where the headers and
|
|
libraries are located, and the necessary options for the compiler and
|
|
linker, so you do not need to change anything else in your project.
|
|
|
|
If you cannot find the Property Manager, you might need to enable Expert
|
|
Settings. Go to Tools → Settings → Expert Settings. Upon first
|
|
installation of Visual Studio, Expert Settings are disabled by
|
|
default.
|
|
|
|
![](images/WindowsInstall10.png)
|
|
|
|
> ![Warning](images/icons/emoticons/warning.svg)
|
|
> **Depending on the GStreamer libraries you need to use, you will have to add more property pages,
|
|
> besides `gstreamer-1.0`** (each property page corresponds to one GStreamer library).
|
|
>
|
|
> The tutorial's project files already contain all necessary property pages. When developing your own applications,
|
|
> the GStreamer documentation will tell you what library a function belongs to, and therefore, what property pages you need to add.
|
|
|
|
#### Remove the dependency with the Visual Studio runtime
|
|
|
|
At this point, you have a working environment, which you can test by
|
|
running the tutorials. However, there is a last step remaining.
|
|
|
|
Applications built with Visual C++ 2010 depend on the Visual C++ 2010
|
|
Runtime, which is a DLL that gets installed when you install Visual
|
|
Studio. If you were to distribute your application, you would need to
|
|
distribute this DLL with it (e.g. via the [Visual C++ 2010 Redistributable
|
|
Package](http://www.microsoft.com/download/en/details.aspx?id=5555)).
|
|
This happens with every version of Visual Studio, and the Runtime DLL is
|
|
different for every version of Visual Studio.
|
|
|
|
Furthermore, GStreamer itself is built using a “basic” C runtime which
|
|
comes in every Windows system since Windows XP, and is named
|
|
`MSVCRT.DLL`. If your application and GStreamer do not use the same C
|
|
Runtime, problems are bound to crop out.
|
|
|
|
In order to avoid these issues you must instruct your application to use
|
|
the system's C Runtime. First install the [Windows Device Driver Kit
|
|
Version 7.1.0](http://www.microsoft.com/download/en/details.aspx?displaylang=en&id=11800) (DDK).
|
|
When the installer asks about the features, select only “Build
|
|
Environments”. Accept the suggested location for the installation, which
|
|
is usually `C:\WinDDK\7600.16385.1`. This download is an ISO file, you
|
|
can either burn a DVD with it (as recommended in the Microsoft site. You
|
|
will need DVD burning software), mount the file in a virtual DVD device
|
|
(you will need DVD virtualization software) or unpack the file as if it
|
|
was a regular compressed file (you will need decompression software that
|
|
understands the ISO format).
|
|
|
|
Then, add the `x86.props` or `x86_64.props` (for 32 or 64 bits) property
|
|
sheet found in `%GSTREAMER_ROOT_X86%\share\vs\2010\msvc` to your
|
|
project. This will make your application use the ubiquitous
|
|
`MSVCRT.DLL` saving you from some troubles in the future.
|
|
|
|
> ![Information](images/icons/emoticons/information.svg)
|
|
> If you did not install the WinDDK to the standard path `C:\WinDDK\7600.16385.1`,
|
|
> you will need to tell Visual Studio where it is. Unfortunately, there is no automated way to do this.
|
|
> Once you have added the `x86.props` or `x86_64.props` to your project, go to the Property Manager,
|
|
> expand your project and its subfolders until you find the property sheet called `config`.
|
|
> Double click to edit it, and select the section called “User Macros” in the list on the left.
|
|
> You should see a macro called `WINDOWS_DRIVER_KIT`. Double click to edit it, and set its value to
|
|
> the root folder where you installed the DDK. This is the folder containing a file called `samples.txt`.
|
|
>
|
|
> That's it. Accept the changes, right click on the `config` property sheet and select “Save”.
|
|
> The path to the DDK is now stored in `config.props` and you do not need to perform this operation anymore.
|
|
|
|
### Creating new projects using the wizard
|
|
|
|
Go to File → New → Project… and you should find a template
|
|
named **GStreamer Project**. It takes no parameters, and sets all
|
|
necessary project settings, both for 32 and 64 bits architectures.
|
|
|
|
The generated project file includes the two required Property Sheets
|
|
described in the previous section, so, in order to link to the correct
|
|
`MSVCRT.DLL`, **you still need to install the Windows Device Driver
|
|
Kit** and change the appropriate property sheets.
|