mirror of
https://github.com/BC46/freelancer-hd-edition
synced 2024-08-30 18:32:47 +00:00
1255 lines
59 KiB
HTML
1255 lines
59 KiB
HTML
|
<!DOCTYPE html>
|
||
|
<html>
|
||
|
<head>
|
||
|
<style>
|
||
|
|
||
|
p
|
||
|
{
|
||
|
max-width:1000px;
|
||
|
word-wrap:break-word;
|
||
|
text-align:justify
|
||
|
}
|
||
|
|
||
|
table, th, td {
|
||
|
width:1000px;
|
||
|
border: 1px solid #C0C0C0;
|
||
|
border-collapse: collapse;
|
||
|
text-align: center;
|
||
|
}
|
||
|
|
||
|
|
||
|
li {
|
||
|
max-width:1000px;
|
||
|
text-align:justify
|
||
|
}
|
||
|
|
||
|
</style>
|
||
|
|
||
|
<head>
|
||
|
|
||
|
<meta name="google-site-verification" content="4JMbYsGNl4-uZV9FEQvq56CQDND5NHcIPtMblynaH-Q" />
|
||
|
|
||
|
<title>dgVoodoo2 Main Readme</title>
|
||
|
|
||
|
</head>
|
||
|
|
||
|
<body bgcolor="#D97600">
|
||
|
<font color = "#FFFF00">
|
||
|
|
||
|
<h2 align="left">
|
||
|
===============================================================================<br>
|
||
|
<font color = "#FFFFFF">dgVoodoo 2.54</font>: Glide, DirectDraw/Direct3D and D3D8 to Direct3D11 Wrapper<br>
|
||
|
Released: <font color = "#FFFFFF">April 25, 2017</font><br>
|
||
|
Author: <font color = "#FFFFFF">Dege</font><br>
|
||
|
<br>
|
||
|
Copyright (c) 2013-2017<br>
|
||
|
===============================================================================<br>
|
||
|
</h2>
|
||
|
|
||
|
<p>
|
||
|
<h2><font color = "#FFFFFF"><u>
|
||
|
Table of contents
|
||
|
</u></font></h2>
|
||
|
<h3><b>
|
||
|
1. Redistribution rights<br>
|
||
|
2. Features<br>
|
||
|
3. Requirements<br>
|
||
|
4. Test results<br>
|
||
|
5. Usage<br>
|
||
|
6. Configuring<br>
|
||
|
7. Resolution overriding<br>
|
||
|
8. General Control Panel (CPL) options<br>
|
||
|
9. General tips and known issues<br>
|
||
|
10. Change log<br>
|
||
|
</b></h3>
|
||
|
===============================================================================<br>
|
||
|
|
||
|
</p>
|
||
|
|
||
|
<br>
|
||
|
<h2><font color = "#FFFFFF"><u>
|
||
|
1. Redistribution rights
|
||
|
</u></font></h2>
|
||
|
<p>
|
||
|
Files of dgVoodoo can be redistributed freely as far as they are kept together,
|
||
|
remain unmodified and unrenamed. Namely, only the full package can be
|
||
|
redistributed in the form as it is!
|
||
|
</p>
|
||
|
<p>
|
||
|
If you would like to utilize them in publicly available custom solutions or
|
||
|
packages, like game patches or anything else, then <font color = "#FFFFFF">PLEASE</font> ask me for permission,
|
||
|
furthermore mention its original source in your package along with the following
|
||
|
download link:
|
||
|
</p>
|
||
|
<a href="http://dege.fw.hu/">http://dege.fw.hu/</a>
|
||
|
<p>
|
||
|
Official dgVoodoo forum where you can contact me and the dgVoodoo community is at:
|
||
|
</p>
|
||
|
<a href="http://www.vogons.org/viewforum.php?f=59/">http://www.vogons.org/viewforum.php?f=59/</a><br>
|
||
|
<br>
|
||
|
Tip: See topic <font color = "#FFFFFF">"WIP versions"</font> for checking out new dgVoodoo versions that are not officially released.
|
||
|
<br><br>
|
||
|
<font color = "#FFFFFF">
|
||
|
<table bgcolor = "#C96600">
|
||
|
<tr><td>---------------------- !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! ----------------------</td></tr>
|
||
|
<tr><td>
|
||
|
<p>
|
||
|
Very BIG THANKS must go to the community of Vogons for helping me a lot in
|
||
|
testing during the development! Thanks Guys, I couldn't have proceed so far
|
||
|
without such a great quality assurance!
|
||
|
</p>
|
||
|
</tr></td>
|
||
|
<tr><td>
|
||
|
<p>
|
||
|
And I append a new sentence here to emphasize it again, especially for testing
|
||
|
my DX8 implementation and supplying me with ideas, tips and various informations
|
||
|
on several games!!!
|
||
|
</p>
|
||
|
</tr></td>
|
||
|
<tr><td>---------------------- !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! ----------------------</td></tr>
|
||
|
</table>
|
||
|
</font>
|
||
|
|
||
|
<br>
|
||
|
<h2><font color = "#FFFFFF"><u>
|
||
|
2. Features
|
||
|
</u></font></h2>
|
||
|
<p>
|
||
|
dgVoodoo 2 is a wrapper for old graphics API's for Windows Vista/7/8/10.
|
||
|
<br><br>
|
||
|
This wrapper can use Direct3D 11 with different device types as wrapping output:
|
||
|
<ul>
|
||
|
<li>Hardware rendering at GPU feature level 10.1 (recommended)</li>
|
||
|
<li>Hardware rendering at GPU feature level 10.0 (there are some restrictions)</li>
|
||
|
<li>Software rendering through Microsoft WARP renderer</li>
|
||
|
</ul>
|
||
|
|
||
|
The API's it currently can wrap are:
|
||
|
<ul>
|
||
|
<li>Glide 2.11, Glide 2.45, Glide 3.1 and Glide 3.1 Napalm</li>
|
||
|
<li>DirectX 1-7 (all versions of DirectDraw and Direct3D up to version 7)</li>
|
||
|
<li>Direct3D 8.1</li>
|
||
|
</ul>
|
||
|
<p>
|
||
|
For both Glide and DirectX, dgVoodoo pushes as many emulation work to the GPU as
|
||
|
possbile. Thus, the entire internal 3Dfx GPU logic is mapped to pixel shaders
|
||
|
for Glide emulation, and all the fixed function vertex & pixel processing
|
||
|
pipeline is implemented by shaders for DirectX emulation (when possible).<br>
|
||
|
dgVoodoo basically can work in two ways:
|
||
|
<ul>
|
||
|
<li>Using its precompiled shaders - it is the less efficient mode (legacy) and doesn't provide DX8-level vertex/pixel pipeline functionality</li>
|
||
|
<li>Using an external HLSL shader compiler - this is the most efficient and recommended mode and referred as 'dynamic shader compiling'</li>
|
||
|
</ul>
|
||
|
</p>
|
||
|
<p>
|
||
|
If dynamic shader compiling is available (see Usage) then dgVoodoo can work
|
||
|
with specialized shaders requiring much less GPU power, providing much better
|
||
|
performance, especially on weaker video cards.<br>
|
||
|
</p>
|
||
|
|
||
|
<br>
|
||
|
<h2><font color = "#FFFFFF"><u>
|
||
|
3. Requirements
|
||
|
</u></font></h2>
|
||
|
<ul>
|
||
|
<li>Operating system: Windows Vista/7/8/10</li>
|
||
|
<li>Hardware: GPU supporting DirectX feature level 10.0.</li>
|
||
|
</ul>
|
||
|
Optional and recommended:
|
||
|
<ul>
|
||
|
<li>GPU supporting DirectX <font color = "#FFFFFF">feature level 10.1</font></li>
|
||
|
<li>HLSL shader compiler <font color = "#FFFFFF">(D3DCompiler_43 or D3DCompiler_47)</font><br>(note that D3DCompiler_47 is part of Windows 10)</li>
|
||
|
</ul>
|
||
|
|
||
|
<br>
|
||
|
<h2><font color = "#FFFFFF"><u>
|
||
|
4. Test results
|
||
|
</u></font></h2>
|
||
|
<p>
|
||
|
We can examine this in two aspects:
|
||
|
</p>
|
||
|
<ul>
|
||
|
<li><font color = "#FFFFFF"><b>Used hardware and performance</b></font><br>
|
||
|
I've tested and run different versions of dgVoodoo2 on the following GPU's:
|
||
|
<font color = "#FFFFFF"><ul>
|
||
|
<li>Intel HD 2000 (feature level 10.0 only)</li>
|
||
|
<li>GeForce 8600 GT (feature level 10.0 only)</li>
|
||
|
<li>Intel HD 4000</li>
|
||
|
<li>Geforce GT 610</li>
|
||
|
<li>AMD HD 6450</li>
|
||
|
<li>Intel HD Graphics 530</li>
|
||
|
<li>GeForce GTS 450</li>
|
||
|
<li>AMD HD 7850</li>
|
||
|
<li>GeForce GTX Ti560 (RIP)</li>
|
||
|
<li>AMD R7 360</li>
|
||
|
<li>GeForce GTX 1060</li>
|
||
|
</ul></font>
|
||
|
If dynamic shader compiling is utilized then dgVoodoo generally performs quite well on all hardware except
|
||
|
integrated chips (like Intel HD 2000 and 4000).<br>
|
||
|
Using only precompiled shaders requires a mid-class video card at least, and the low-end ones (intended for office-like usage) like
|
||
|
Geforce GT 610 and AMD HD 6450 are not recommended.
|
||
|
</li>
|
||
|
|
||
|
<br><li><font color = "#FFFFFF"><b>Accuracy of the emulation, individual games and applications</b></font><br>
|
||
|
Of course it's not perfect but I think I got very nice results in general. I maintain expanding lists for games and demos, for DirectX emulation:<br>
|
||
|
<a href="http://dege.fw.hu/Gallery/DXGamesGallery.html">Games</a><br>
|
||
|
<a href="http://dege.fw.hu/Gallery/DXDemosGallery.html">Demos</a><br>
|
||
|
</li>
|
||
|
</ul>
|
||
|
|
||
|
<br>
|
||
|
<h2><font color = "#FFFFFF"><u>
|
||
|
5. Usage
|
||
|
</u></font></h2>
|
||
|
<p>
|
||
|
There is no installer for dgVoodoo beacuse you can copy its dlls anywhere
|
||
|
you want (to use). If u like it and want to use as the only global Glide
|
||
|
wrapper on your machine then copy Glide dlls to the system folder.
|
||
|
For DirectX emulation only a local installation is possible since the
|
||
|
DirectX dlls CANNOT be copied to the system folder (see DirectX readme).
|
||
|
</p>
|
||
|
<p>
|
||
|
A Glide wrapped application can start up either in windowed or full screen
|
||
|
mode (it is controlled by the <font color = "#FFFFFF">Control Panel</font>, see later). Also, you can switch between
|
||
|
them during the gameplay by Alt-Enter. See 'Known issues' for more.
|
||
|
</p>
|
||
|
<p>
|
||
|
The same is true for wrapped DirectX applications, but it is a more
|
||
|
complicated case, see DirectX readme.
|
||
|
</p>
|
||
|
<p>
|
||
|
Glide and DirectX dlls can co-work inside a process so the same versions
|
||
|
of them have to be used within a folder. If one of them detects the other
|
||
|
with different version then it refuses to initialize and work.
|
||
|
Co-work is useful for applications that use DirectDraw for some initial
|
||
|
in-game menu and Glide for 3D rendering.
|
||
|
</p>
|
||
|
<p>
|
||
|
If you use dgVoodoo on Windows 10 then dynamic shader compiling is automatically
|
||
|
available because D3DCompiler_47 is part of the operating system.<br>
|
||
|
For preceding Windows versions (Vista, 7, 8) you need to download it manually and
|
||
|
then, you can copy this dll into each game folder next to the wrapper dlls but the
|
||
|
best practice is to copy it into
|
||
|
</p>
|
||
|
|
||
|
<ul>
|
||
|
<li><font color = "#FFFFFF">Windows\System32 folder for 32 bit operating systems</font></li>
|
||
|
<li><font color = "#FFFFFF">Windows\SysWOW64 folder for 64 bit operating systems</font></li>
|
||
|
</ul>
|
||
|
|
||
|
<p>
|
||
|
if it is not already there by the result of the installation of some
|
||
|
other software.<br>
|
||
|
Note that dgVoodoo supports both D3DCompiler_43 and D3DCompiler_47.
|
||
|
_43 is supported only because of compatibility with users having it
|
||
|
downloaded and copied into their system folder previously.
|
||
|
</p>
|
||
|
<p>
|
||
|
Utilizing dynamic shader compiling is strongly recommended and
|
||
|
even unavoidable to get all DX8 level features to work.
|
||
|
If dgVoodoo cannot find D3DCompiler then it can use only its
|
||
|
generalized precompiled shaders just like versions before 2.5.
|
||
|
If dgVoodoo finds a supported compiler dll then it can adapt to the current
|
||
|
circumstances and compile specialized shaders providing maximum GPU
|
||
|
performance.
|
||
|
</p>
|
||
|
|
||
|
<br>
|
||
|
<h2><font color = "#FFFFFF"><u>
|
||
|
6. Configuring
|
||
|
</u></font></h2>
|
||
|
<p>
|
||
|
As different options might wanted to be used for particular applications,
|
||
|
I kept the concept of local/global configurations (might be familiar from old dgVoodoo).
|
||
|
The configuration data is not stored in the dlls themself anymore.
|
||
|
It is in a separate file named 'dgVoodoo.conf'. All of the Glide and DirectX
|
||
|
dlls uses this file.
|
||
|
</p>
|
||
|
<p>
|
||
|
When the Glide or DirectX wrapped application starts, dgVoodoo tries to read
|
||
|
config data. The search paths and the order for the config file are the following:
|
||
|
<ul>
|
||
|
<li>Folder of the wrapper DLL</li>
|
||
|
<li>Folder of the application (EXE)</li>
|
||
|
<li>User application data folder</li>
|
||
|
</ul>
|
||
|
If the config file can be found in none of them then the default config is used.
|
||
|
</p>
|
||
|
<p>
|
||
|
For modifying config files, you have <font color = "#FFFFFF">dgVoodoo Control Panel (dgVoodooCpl)</font>.
|
||
|
In dgVoodooCpl you can choose a folder where you can load (from) and save the current
|
||
|
configuration. After you chose a folder, it remains in the list permanently.
|
||
|
If the CPL application finds a valid config file in its own folder (where the app itself
|
||
|
is located) then it automatically places the folder into the list and selects the folder.
|
||
|
Otherwise the user's application data folder is selected, by default.
|
||
|
</p>
|
||
|
<p>
|
||
|
If an application tolerates losing focus without closing/minimizing itself,
|
||
|
you can configure it dynamically: when the CPL starts up it builds
|
||
|
a list of detected running Glide/DirectX wrapped applications and insert it
|
||
|
into the folder selector combobox. When you select such a running instance
|
||
|
then the current state of the application is read as config and most of the
|
||
|
options can also be changed. So, you can set resolution, msaa, brightness,
|
||
|
etc on the spot without restarting the application (configurable items depend
|
||
|
on emulation type). When an option changes, it takes effect at once. If the
|
||
|
dialog gets cancelled or an other config folder/instance is selected, all the
|
||
|
changes gets cancelled as well.
|
||
|
</p>
|
||
|
<p>
|
||
|
You can always use the <font color = "#FFFFFF">'Apply' button</font> to save the current config to the
|
||
|
selected folder or running application without exiting the CPL application.
|
||
|
|
||
|
Important to note:
|
||
|
</p>
|
||
|
|
||
|
<ul>
|
||
|
<li><p>
|
||
|
If the wrapped app and the CPL runs on different privilege levels
|
||
|
(admin/nonadmin) then the app won't appear in the instance list or they
|
||
|
cannot communicate to each other. Sorry for the inconvenience.</p>
|
||
|
</li>
|
||
|
<li><p>
|
||
|
Switching resolution or MSAA can only be performed perfectly if the
|
||
|
application re-renders everything on each frame. If it uses or keeps
|
||
|
previously (once-)rendered things like cockpits or similars then they will
|
||
|
be missing as will not get re-rendered. (Glide only)</p>
|
||
|
</li>
|
||
|
</ul>
|
||
|
|
||
|
<p>A folder inserted formerly into the list can be removed. Also, list of the
|
||
|
running instances can be refreshed.</p>
|
||
|
|
||
|
<p>
|
||
|
(Why configuration is still needed at all? Well, now it's not for choosing from
|
||
|
millions of technical options due to weak implementation but for fancy things,
|
||
|
see chapter 'General Control Panel (CPL) options' as well as Glide and DirectX readme.)
|
||
|
</p>
|
||
|
|
||
|
<br>
|
||
|
<h2><font color = "#FFFFFF"><u>
|
||
|
7. Resolution and refresh rate overriding
|
||
|
</u></font></h2>
|
||
|
|
||
|
<p>
|
||
|
You can override the application resolution and refresh rate both for
|
||
|
Glide and DirectX rendering.<br>
|
||
|
There are three types of resolution overriding, and, the 'Resolution'
|
||
|
comboboxes contain two types of elements in the enumerated list:
|
||
|
</p>
|
||
|
<ul>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">Static resolutions</font>
|
||
|
<p>
|
||
|
Those are enumerated by your videocard for the selected display output.
|
||
|
Select any of them, and the wrapper will force that one (along with the selected refresh rate),
|
||
|
no matter what resolution the application wants to set.<br>
|
||
|
Resolution 'Unforced' means always using the current application resolution, so there is no overriding at all.
|
||
|
</p>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">Dynamic resolutions</font>
|
||
|
<p>
|
||
|
First, a little explanation on what the practical problems are with static
|
||
|
resolutions (especially for DirectX applications).
|
||
|
</p>
|
||
|
<ul>
|
||
|
<li><p>
|
||
|
The application may use multiple resolutions for different parts like movies,
|
||
|
menus and ingame. The statically chosen resolution may not have the same
|
||
|
aspect ratio as those of them. For app-resolutions with different aspect
|
||
|
ratios like 4:3 vs 16:9 it's a problem because one of them will be displayed
|
||
|
hugely distorted.</p>
|
||
|
|
||
|
<li><p>
|
||
|
Even if the app uses only one resolution, and you can select or type another
|
||
|
one with the same aspect ratio, then selecting the proper resolution is still
|
||
|
not an easy task:<br>
|
||
|
a) you don't necessarily know what resolution the app uses<br>
|
||
|
b) you don't necessarily know what the max resolution your display is capable
|
||
|
of<br>
|
||
|
c) even if you know both of them, you may have to calculate manually the
|
||
|
desired resolution.</p>
|
||
|
</li>
|
||
|
</ul>
|
||
|
<p>
|
||
|
(My own problem was the following: I sat down in front of a new computer with
|
||
|
a 4K monitor and wanted to try out some stuffs through dgVoodoo. I faced the
|
||
|
fact that I didn't know the exact monitor resolution, I also didn't know what
|
||
|
res the stuffs to try were using. I just wanted the maximum available
|
||
|
resolution to be forced that keeps the aspect ratio.)
|
||
|
</p>
|
||
|
<p>
|
||
|
Dynamic resolution is the synonim of "let the wrapper choose the current
|
||
|
resolution for you". The maximum, and also the base used for calculating the
|
||
|
current resolution, is your desktop resolution. The base rule is that the
|
||
|
wrapper always calculates the maximum available resolution for the given
|
||
|
scaling mode, but
|
||
|
</p>
|
||
|
<ul>
|
||
|
<li><p>you can restrict the base maximum to <font color = "#FFFFFF">FullHD (1920x1080) or QHD (2560x1440)</font>
|
||
|
for weaker GPUs (like low-end cards or maybe, integrated chips) with large-res display outputs, and</p></li>
|
||
|
<li><p>you can restrict the scale factor to integer numbers.<br>
|
||
|
<font color = "#FFFFFF">(ISF - integer scale factor)</font></p></li>
|
||
|
</ul>
|
||
|
|
||
|
So, dynamic resolutions are the following:
|
||
|
<ul>
|
||
|
<li><font color = "#FFFFFF">Max:</font> Maximum resolution available</li>
|
||
|
<li><font color = "#FFFFFF">Max ISF:</font> Maximum resolution with integer scale factor available</li>
|
||
|
<li><font color = "#FFFFFF">Max FHD:</font> Maximum resolution available
|
||
|
(but restricted to 1920x1080)</li>
|
||
|
<li><font color = "#FFFFFF">Max FHD ISF:</font> Maximum resolution with integer scale factor available
|
||
|
(but restricted to 1920x1080)</li>
|
||
|
<li><font color = "#FFFFFF">Max QHD:</font> Maximum resolution available
|
||
|
(but restricted to 2560x1440)</li>
|
||
|
<li><font color = "#FFFFFF">Max QHD ISF:</font> Maximum resolution with integer scale factor available
|
||
|
(but restricted to 2560x1440)</li>
|
||
|
</ul>
|
||
|
<p>
|
||
|
By default, dynamic resolutions don't have refresh rate even if enumerating refresh rates is enabled.
|
||
|
When working with a dynamic resolution, then the refresh rate is undefined and it is up to the wrapper and the
|
||
|
video card that what rate will be used (probably the one at which desktop is driven).
|
||
|
</p>
|
||
|
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">Custom resolutions</font>
|
||
|
<p>
|
||
|
A custom resolution is either a static one that is not in the enumerated list, or one that is partially overridden.
|
||
|
Defining a custom resolution is about typing the string -manually into the combo box- describing the resolution/refresh rate pair.<br>
|
||
|
Resolution and refresh rate can be overridden independently on each other. Here are some examples (don't type quotation marks):
|
||
|
<ul>
|
||
|
<li>"128x128, 60" - means static resolution 128x128 at forced rate of 60Hz</li>
|
||
|
<li>"128x128, 0" or just "128x128" - means static resolution 128x128 without overridden refresh rate</li>
|
||
|
<li>"0x0, 75" or "unforced, 75" - means unforced (static) resolution with forced 75Hz</li>
|
||
|
<li>"max isf, 83" - means Max ISF dynamic resolution with forced 83Hz</li>
|
||
|
</ul><br>
|
||
|
If your resolution and refresh rate is in the list then it is better to select it from there than typing it manually.
|
||
|
It is because e.g. 60Hz is not exactly 60Hz in practice but 60.01Hz or 59.95Hz or so, depending on your display hardware.
|
||
|
dgVoodoo always handles the refresh rates in their exact rational form but it cannot do that with manually typed ones.<br>
|
||
|
When displaying a refresh rate in the combo box, dgVoodoo truncates the value. So, for example, 59.95Hz will appear as 59Hz
|
||
|
in the list, while the display manufacturer probably claims that your display supports 60Hz. Don't let it mislead you. It is all
|
||
|
about truncating or rounding the values.
|
||
|
</p>
|
||
|
</li>
|
||
|
|
||
|
</ul>
|
||
|
|
||
|
If you are terribly interested in how the current dynamic resolution is calculated then
|
||
|
a little technical part comes here. Otherwise you can skip this section.
|
||
|
<br><br>
|
||
|
<table bgcolor = "#C96600">
|
||
|
<tr><td>D:</td><td>desktop resolution</td></tr>
|
||
|
<tr><td>F:</td><td>FullHD resolution (1920x1080)</td></tr>
|
||
|
<tr><td>Q:</td><td>QHD resolution (2560x1440)</td></tr>
|
||
|
<tr><td>A:</td><td>application resolution</td></tr>
|
||
|
<tr><td>AS (x, y):</td><td>stretched from x to y, with aspect ratio</td></tr>
|
||
|
<tr><td>IAS (x, y):</td><td>stretched from x to y, with aspect ratio, integer scale factor</td></tr>
|
||
|
</table>
|
||
|
|
||
|
<br>
|
||
|
|
||
|
<table border = 1 bgcolor = "#C96600">
|
||
|
<tr>
|
||
|
<th></th>
|
||
|
<th>Unspecified</th>
|
||
|
<th>Centered</th>
|
||
|
<th>Stretched</th>
|
||
|
<th>Stretch with AR</th>
|
||
|
</tr>
|
||
|
<tr>
|
||
|
<th>Max</th>
|
||
|
<td>AS (A, D)</td>
|
||
|
<td>AS (A, D)</td>
|
||
|
<td>D</td>
|
||
|
<td>AS (A, D)</td>
|
||
|
</tr>
|
||
|
<tr>
|
||
|
<th>Max ISF</th>
|
||
|
<td>IAS (A, D)</td>
|
||
|
<td>IAS (A, D)</td>
|
||
|
<td>* remarks</td>
|
||
|
<td>IAS (A, D)</td>
|
||
|
</tr>
|
||
|
<tr>
|
||
|
<th>Max FHD</th>
|
||
|
<td>AS (A, min (D,F))</td>
|
||
|
<td>AS (A, min (D,F))</td>
|
||
|
<td>min (D,F)</td>
|
||
|
<td>AS (A, min (D,F))</td>
|
||
|
</tr>
|
||
|
<tr>
|
||
|
<th>Max FHD ISF</th>
|
||
|
<td>IAS (A, min (D,F))</td>
|
||
|
<td>IAS (A, min (D,F))</td>
|
||
|
<td>* remarks</td>
|
||
|
<td>IAS (A, min (D,F))</td>
|
||
|
</tr>
|
||
|
<tr>
|
||
|
<th>Max QHD</th>
|
||
|
<td>AS (A, min (D,Q))</td>
|
||
|
<td>AS (A, min (D,Q))</td>
|
||
|
<td>min (Q,F)</td>
|
||
|
<td>AS (A, min (D,Q))</td>
|
||
|
</tr>
|
||
|
<tr>
|
||
|
<th>Max QHD ISF </th>
|
||
|
<td>IAS (A, min (D,Q))</td>
|
||
|
<td>IAS (A, min (D,Q))</td>
|
||
|
<td>* remarks</td>
|
||
|
<td>IAS (A, min (D,Q))</td>
|
||
|
</tr>
|
||
|
</table>
|
||
|
<br>
|
||
|
Remarks:
|
||
|
<ul>
|
||
|
<li><p>
|
||
|
Resolution is calculated in the same way for scaling mode 'Unspecified', 'Centered' and 'Stretch with AR'.<br>
|
||
|
</p></li>
|
||
|
<li><p>
|
||
|
Stretched scaling mode with ISF tries to stretch to min([D|F|Q]) and the
|
||
|
scale factor for both direction is the integer part of the minimum of<br>
|
||
|
<font color = "#FFFFFF">min ([Dx|Fx|Qx])/Ax</font> and <font color = "#FFFFFF">min ([Dy|Fy|Qy])/Ay</font>
|
||
|
(ratios of X/Y directions).
|
||
|
</p></li>
|
||
|
</ul>
|
||
|
<p>
|
||
|
I'd like to say some words about what happens on multimonitor systems with
|
||
|
dynamic resolution forcing:
|
||
|
</p>
|
||
|
<ul>
|
||
|
<li><p>
|
||
|
Glide: when switching from windowed mode to fullscreen then a new forced
|
||
|
resolution is calculated by the wrapper, based on the native res of the
|
||
|
display on which the full screen output will appear.
|
||
|
</p></li>
|
||
|
<li><p>
|
||
|
DX: It's not so flexible at all, unfortunately. Since DX impl doesn't
|
||
|
support changing resolution during its working, it cannot do the same
|
||
|
as Glide when switching into fullscreen. Also, since display outputs
|
||
|
are enumerated to the application, resolution calculation can rely only
|
||
|
on the native res of the output on which DX is initialized (so changing
|
||
|
the output of a running DX emulated app from the CPL application is without avail,
|
||
|
won't affect the next resolution calculation).
|
||
|
</p></li>
|
||
|
</ul>
|
||
|
|
||
|
<br>
|
||
|
<h2><font color = "#FFFFFF"><u>
|
||
|
8. General Control Panel (CPL) options
|
||
|
</u></font></h2>
|
||
|
<br>
|
||
|
Options on the General tab affects all wrapped APIs, that is, currently
|
||
|
Glide and DirectX.
|
||
|
<ul>
|
||
|
<li><font color = "#FFFFFF"><b>Output API</b></font><br>
|
||
|
Three output API's are available:<br>
|
||
|
<ul>
|
||
|
<li><p><font color = "#FFFFFF">Direct3D11 feature level 10.1</font></p></li>
|
||
|
<li><p><font color = "#FFFFFF">Direct3D11 feature level 10.0</font></p></li>
|
||
|
<li><p><font color = "#FFFFFF">Direct3D11 Microsoft WARP renderer</font><br><br>
|
||
|
D3D11 with FL10.0 is designed to be used with late
|
||
|
DX 10.0 hardware and has some limitations:
|
||
|
<ul>
|
||
|
<li>No mipmapping in Glide rendering</li>
|
||
|
<li>Limited operations on Z-buffers</li>
|
||
|
<ul>
|
||
|
<li>Buffers <font color="#FFFFFF">with forced MSAA can only be rendering targets;</font></b> they cannot be used as
|
||
|
<ul>
|
||
|
<li>depth textures</li>
|
||
|
<li>source of copy operations (Blit in DDraw)</li>
|
||
|
<li>locked for CPU-access (Lock in DDraw/ LockRect in D3D8)</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<li>Faces of 3D-rendered cube-depth buffers cannot be
|
||
|
<ul>
|
||
|
<li>source of copy operations (Blit in DDraw)</li>
|
||
|
<li>locked for CPU-access (Lock in DDraw/ LockRect in D3D8)</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
</ul>
|
||
|
</ul>
|
||
|
<p>
|
||
|
WARP is a software renderer, I intended it to be
|
||
|
kind of a reference driver but I experienced some
|
||
|
rendering errors with it unfortunately.
|
||
|
</p>
|
||
|
</p></li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
|
||
|
<li><p>
|
||
|
<font color = "#FFFFFF"><b>Video card (adapter)</b></font><br>In case you have more than one, then
|
||
|
<ul>
|
||
|
<li>
|
||
|
Glide:
|
||
|
<font color = "#FFFFFF">which one to use</font> for rendering. Option 'All of them' is equivalent to selecting the first video card in the list.</li>
|
||
|
<li>DirectX: it is a multi-device capable API so you can
|
||
|
choose <font color = "#FFFFFF">which adapter(s) are to be enabled</font> for the emulation.</li>
|
||
|
</ul>
|
||
|
</p></li>
|
||
|
|
||
|
|
||
|
<li><p>
|
||
|
<font color = "#FFFFFF"><b>Monitor (output)</b></font><br>
|
||
|
If you have multiple monitors then you can choose
|
||
|
which one(s) (connected to the selected adapter):
|
||
|
<ul>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">Glide: which monitor is used for fullscreen output.</font> When 'Default'
|
||
|
is selected then switching from windowed to fullscreen
|
||
|
during playing a game selects the monitor containing
|
||
|
the largest part of the game window.<br>
|
||
|
It can be overridden dynamically on a running Glide wrapped application and it also affects
|
||
|
dynamic resolution calculating (see resolution overriding).
|
||
|
</li>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">DirectX: which monitor(s) to enable to appear as DX devices to the application.</font>
|
||
|
'Default' enables all the monitors connected to the selected adapter. When the game or
|
||
|
application goes into fullscreen then it always happens on the monitor (device) that the
|
||
|
game/application selected for use. In case of a multidevice environment games and applications
|
||
|
often (and silently) selects the first available device which generally corresponds to the primary monitor,
|
||
|
but advanced apps allows the user to configure it through the app itself.
|
||
|
<br>
|
||
|
It can be overridden dynamically on a running DirectX-wrapped application however it only
|
||
|
affects the output, it is all about pure visuality. It doesn't affects dynamic resolution
|
||
|
calculating (see resolution overriding) and also, the application shall continue to see the
|
||
|
corresponding device in it original state (keep in mind that it can conflict with the app).
|
||
|
</li>
|
||
|
</ul>
|
||
|
</p></li>
|
||
|
|
||
|
<li><p><font color = "#FFFFFF"><b>Full Screen / Windowed</b></font><br>
|
||
|
See section "Usage".</p></li>
|
||
|
|
||
|
<li><p><font color = "#FFFFFF"><b>Unspecified/Centered/Scaled/Scaled with Aspect Ratio kept, for full screen</b></font><br>
|
||
|
|
||
|
If the current resolution the wrapped app using does not
|
||
|
match any natural resolution your adapter supports
|
||
|
then the display can be strethed out to fit all the
|
||
|
screen or its size can be left unchanged but centered.
|
||
|
|
||
|
<font color = "#FFFFFF">NOTE that if your video card supports overriding the scaling
|
||
|
method of applications, and you'd like to apply a scaling
|
||
|
with aspect ratio then it is recommended to set dgVoodoo's
|
||
|
scaling method to 'Unspecified' + set the scaling mode <b>on your
|
||
|
video card control panel</b> because dgVoodoo's internal scaling
|
||
|
is unfortunately not a sterling one.</font> It implies that you may
|
||
|
experience various problems like wrong mouse cursor or
|
||
|
glitches in rendering in certain applications. Scaling can
|
||
|
only be done well (transparently) on the GPU/display side.
|
||
|
<br>
|
||
|
C64-like output: well, if you are not a former C64 owner and fan, don't even try it,
|
||
|
I'm sure you won't like it at all. As dgVoodoo is my main hobby programming playground
|
||
|
these times I tried some algorhytms as part of it. It's not really a feature,
|
||
|
but the result of some former experimenting and can be funny for some scene demos.
|
||
|
|
||
|
</p></li>
|
||
|
|
||
|
|
||
|
<li><p><font color = "#FFFFFF"><b>Progressive scanline order</b></font><br>
|
||
|
Default scanline order is interlaced or progressive. It is
|
||
|
up to the output display device which one to choose altough
|
||
|
it chooses progressive when it is possible, I think, so
|
||
|
that when the device is capable of displaying a given
|
||
|
resolution with a given refresh rate with progressive order.
|
||
|
Otherwise it might choose interlaced order with halved
|
||
|
physical refresh rate.
|
||
|
If this option is enabled, you can only see enumerated
|
||
|
resolutions that are displayable with progressive order.
|
||
|
However, if a custom resolution is defined then it may
|
||
|
causes the output device to use lower physical resolution
|
||
|
than the wrapper set.
|
||
|
</p></li>
|
||
|
|
||
|
<li><p><font color = "#FFFFFF"><b>Enumerate refresh rates</b></font><br>
|
||
|
Enables the CPL application to enumerate refresh rates for
|
||
|
each resolution and enables the wrapper to override the
|
||
|
default refresh rate of the application.
|
||
|
<font color = "#FFFFFF">However using other than the app default can cause heavy
|
||
|
animation lagging or glitches!</font>
|
||
|
</p></li>
|
||
|
|
||
|
|
||
|
<li><p><font color = "#FFFFFF"><b>Color adjustments</b></font><br>
|
||
|
Brightness, color intensity (saturation) and contrast can be finetuned here.
|
||
|
The defaults are good in general so treat this as a
|
||
|
cool extra. (I'm using it in some cases for making colors
|
||
|
more vital to get a bit cartoon-like effect.)
|
||
|
</p></li>
|
||
|
<li><p><font color="#FFFFFF"><b>Inherit Color Profile in full screen mode</b></font><br>
|
||
|
When this option is enabled then dgVoodoo won't change the physical
|
||
|
gamma ramp of the screen but instead it solves the color adjustments
|
||
|
just like in windowed mode and so your pre-configured color profile(s)
|
||
|
for the given monitor(s) remain(s) preserved. Color adjustments are
|
||
|
relative to the predefined color profile in that case.
|
||
|
|
||
|
</p></li>
|
||
|
|
||
|
<li><p><font color = "#FFFFFF"><b>Keep window aspect ratio</b></font><br>
|
||
|
In windowed mode, when sizing the window, you can keep
|
||
|
the aspect ratio of the current resolution.
|
||
|
</p></li>
|
||
|
|
||
|
<li><p><font color = "#FFFFFF"><b>Capture mouse</b></font><br>
|
||
|
It's useful mainly (but not only) for multimonitor systems. If this is enabled then the mouse cursor
|
||
|
is forced into the application window to prevent accidental mis-clicks outside of it.
|
||
|
</p></li>
|
||
|
|
||
|
<li><p><font color = "#FFFFFF"><b>Center app window</b></font><br>
|
||
|
When a game controlling the mouse input is being run in windowed mode then
|
||
|
it's a pain to move it's window into the screen, so I thought it's a valuable option (was a request too),
|
||
|
but it can conflict with the mouse input or the app itself.
|
||
|
|
||
|
</p></li>
|
||
|
</ul>
|
||
|
|
||
|
<br>
|
||
|
<h2><font color = "#FFFFFF"><u>
|
||
|
9. General tips and known issues
|
||
|
</u></font></h2>
|
||
|
<ul>
|
||
|
<li>Forcing things (like resolution, antialiasing, texture filtering, etc) is
|
||
|
not a healthy thing. If an application or game uses low resolution or point
|
||
|
sampled textures or anything dissonant to the eye then it has reasons for
|
||
|
that. It is not because the programmers were so lame but of avoiding artifacts
|
||
|
that would otherwise get brought in (typical example is a bilinear filtered
|
||
|
texture with colorkey based transparency). If you force anything then
|
||
|
potentially get one of those artifacts. If you can live with it then it is ok,
|
||
|
use the wrapper in forced mode. If not then disable all forcings and use the
|
||
|
particular game or application in the mode it was designed for, because no
|
||
|
general method exists to fix such type of artifacts.</li>
|
||
|
|
||
|
<li>Controlling antialiasing cannot be done on per-primitive basis in Direct3D 11
|
||
|
when feature set larger than 10.0 is used. That is why antialiased drawing
|
||
|
is not emulated in Glide automatically in this version in any way (per-primitive or
|
||
|
per-edge). It can only be forced globally in the CPL application.</li>
|
||
|
|
||
|
<li>Fullscreen gamma ramp may not be supported by your card. nVidia and ATI seem
|
||
|
to handle it as expected but (e.g.) Intel does not.</li>
|
||
|
|
||
|
<li>When an application is being run in compatibility mode (Win98/XP etc) then
|
||
|
<font color = "#FFFFFF">the user's application data folder is different than the OS default.</font>
|
||
|
Therefore dgVoodoo cannot read the global config file and the default
|
||
|
config gets applied if no local config file is present. The preferred way
|
||
|
is creating a local config for such cases if other than the default needed.
|
||
|
(Perhaps using the user's appdata folder is not a too good idea after all,
|
||
|
I might change it later.)</li>
|
||
|
|
||
|
<li>If you have a multimonitor system then always try a game to run on the primary
|
||
|
one for the first time. Some games lock the mouse cursor to the screen area
|
||
|
where game window is assumed to be (the left-top corner of the desktop).
|
||
|
If such a game is being forced onto another monitor then clicking in the game
|
||
|
causes application focus loss because its window is not under the mouse cursor.</li>
|
||
|
|
||
|
<li>I don't know why but overriding refresh rates by arbitrary values (in the resolution selector combo box) does not
|
||
|
seem to work for DirectX emulation. It is still subject to investigation because the code
|
||
|
handling this is common for both Glide and DirectX. :(
|
||
|
</li>
|
||
|
</ul>
|
||
|
|
||
|
<br>
|
||
|
<h2><font color = "#FFFFFF"><u>
|
||
|
10. Change log
|
||
|
</u></font></h2>
|
||
|
|
||
|
<ul>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.54</font>
|
||
|
<ul><li>Windows input issues caused by the wrapper are fixed (Outlaws, GTA1 DDraw mode, etc.)</li>
|
||
|
<li>Rendering transition between Glide/DDraw is fixed (Outlaws)</li>
|
||
|
<li>Concept of setup application is replaced with concept of Control Panel (CPL)</li>
|
||
|
<li>Control Panel App:</li>
|
||
|
<ul>
|
||
|
<li>Contrast as a new color adjustment option is added</li>
|
||
|
<li>Preserving predefined monitor color profile(s) for fullscreen mode as an option is added</li>
|
||
|
<li>A general option for centering the application/game window is added</li>
|
||
|
<li>DirectX texture filtering options are changed, possibility of forcing anisotropic filtering is introduced</li>
|
||
|
<li>New scaling mode with C64-like output (it's not a feature but more like an experimenting code)</li>
|
||
|
<li>Visual cosmetics</li>
|
||
|
</ul>
|
||
|
<li>DirectX:</li>
|
||
|
<ul>
|
||
|
<li>Some of the DDraw code is guarded to avoid the unexpected worst-way DLL unloading<br>
|
||
|
Now LithTech engine games (Blood2, NOLF, Kiss Psycho Circus, ...) should tolerate Alt-Tab on Win10</li>
|
||
|
<li>Some other extra guarding to prevent crashes, Virtua Cop2 now works in D3D mode</li>
|
||
|
<li>Blit bug and clipper incompatibility fixed in DDraw (D3DRM, Tokipazu, tech demo Final Reality)</li>
|
||
|
<li>Minor issue in DDraw and bad L6V5U5 format descriptor is fixed (Kyro tech demos)</li>
|
||
|
<li>Adding support for plain surface format A8L8 (DDraw) (Matrox G400 Tech Demo)</li>
|
||
|
<li>D3D3 fog fixed (Shadows of The Empire patched to 1.1)</li>
|
||
|
<li>Execute buffer bug fixed in D3D (D3DRM)</li>
|
||
|
<li>Some D3D5 incompatibilities are fixed (crash and texture handling with Space Bunnies Must Die)</li>
|
||
|
<li>Fixing D3D6 bugs and calculations of old software-only lighting and other incompatible things (DX6 SDK sample applications (Immediate/Retained) + Fog City/Tirtanium demos)</li>
|
||
|
<li>Unexpected way of texture compression is implemented (D3D7, Soulbringer)</li>
|
||
|
<li>Adding support for Q8W8V8U8 texture format (D3D8) (3DMark 2001 SE, Nature, Pixel shader and Advanced Pixel shader test)</li>
|
||
|
<li>D3D8 device handling bug is fixed (multimonitor environment)</li>
|
||
|
<li>D3D8 compatibility fixings, now handling managed textures is compatible with Phantasy Star Online Blue Burst
|
||
|
(corrupt mipmapping)</li>
|
||
|
<li>Issue with D3D8 device capabilities and SYSTEMMEM vertex buffers are fixed (LKCC demos)</li>
|
||
|
<li>D3D8 DrawIndexedPrimitive bug fixed (Syberia 2)</li>
|
||
|
<li>Adding support for depth buffer format D24X4S4 (D3D8) (Matrox Parhelia Reef Tech Demo)</li>
|
||
|
<li>Adding support for volume textures (D3D8), though with limited number of formats
|
||
|
(Matrox Parhelia Coral Reef Tech Demo + DX8 SDK VolumeTexture sample + general)</li>
|
||
|
|
||
|
<li>Lower resource usage is partly included in this version.
|
||
|
For the time being, only the usage of GPU accessible system memory.</li>
|
||
|
|
||
|
<li>General bugfixing, like unexpected forced windowed mode (Soulbringer movies), vertex shader (missing fog in Colin McRae Rally), non-perspective polygon drawing bug,
|
||
|
fixed (Zanzarah The Hidden Portal), and a lot other</li>
|
||
|
<li>Handling depth buffers had some bugs at FL 10.0, fixed (D3D11)</li>
|
||
|
<li>Potential bad driving of D3D11 at FL10.1 when no resolution and MSAA is forced (D3D11) (Gorky17)</li>
|
||
|
<li>Some (regression and other) bugs in the D3D11 renderer are fixed</li>
|
||
|
<li>GeForce 4 profile is slightly modified to match a real GF4</li>
|
||
|
<ul>
|
||
|
<li>Now light beams in Splinter Cell 1 should be rendered correctly through the GF4 card type (unblurred lights with occlusion)</li>
|
||
|
</ul>
|
||
|
<li>2 new videocard types are added:</li>
|
||
|
<ul>
|
||
|
<li>GeForce FX 5700 Ultra (keeps the soft shadows for Splinter Cell 1 (because I like it :D) and will hopefully be feasible to provide place for new features later)</li>
|
||
|
<li>Matrox Parhelia-512 (for Matrox Coral Reef Demo 1.1 and other Matrox tech demos)</li>
|
||
|
</ul>
|
||
|
</ul>
|
||
|
<li>Glide:</li>
|
||
|
<ul>
|
||
|
<li>Glide fix (far background in front of the 3D world: Mig29, Uprising)</li>
|
||
|
<li>Texture memory report is modified to match that of a real 3Dfx driver (Slave Zero)</li>
|
||
|
</ul>
|
||
|
<li>Tons of code changing for new features that are not ready yet and so not included in this version</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.53</font>
|
||
|
<ul><li>Support for 'dynamic resolutions' (see section 'Resolution overriding')</li>
|
||
|
<li>Added support for 'd3dcompiler_47.dll', so Win10 users don't have to
|
||
|
download and mess with d3dcompiler dll, 47 is part of the Win10 OS.</li>
|
||
|
<li>Linear filtering was applied for upscaling the output-image even if the
|
||
|
scale ratio was 1.0, fixed</li>
|
||
|
<li>Some modifications on the CRT-like shader were done for correct CRT-like
|
||
|
appearance on high-res displays like a 4K monitor</li>
|
||
|
<li>Glide mode 'Compare to bias' is fixed (Esoteria demo)</li>
|
||
|
<li>Some other Glide rendering issues are fixed (Hype - The Time Quest)</li>
|
||
|
<li>DDraw system memory surface pitch is fixed to match that of DIBs
|
||
|
(Snow Wave Avalanche)</li>
|
||
|
<li>A DX8 bug is fixed, so Mafia now works, altough I experience z-buffer
|
||
|
glitches here and there (to be fixed)</li>
|
||
|
<li>Lot of general D3D/D3D8 bugs are fixed, too</li>
|
||
|
<li>GeForce4-style shadow buffering is reverse engineered and implemented in
|
||
|
the 'Geforce Ti4800' preset</li>
|
||
|
<li>Floating point arithmetic differences (incompatibilities) between vs1.x
|
||
|
and vs4.x are resolved, Splinter Cell 1 now works in shadow buffer mode</li>
|
||
|
<li>New dynamic vertex buffering algorhythm for removing rendering performance
|
||
|
bottleneck, better usage of GPU</li>
|
||
|
<li>The config application is now per-monitor DPI-aware, to have sharp
|
||
|
appearance</li>
|
||
|
<li>MSAA option name 'Auto' is changed to 'App driven'</li>
|
||
|
<li>New option for DirectX emulation is added (No texture filtering)</li>
|
||
|
<li>Changes in the default config:</li>
|
||
|
<ul>
|
||
|
<li>Capture mouse is on</li>
|
||
|
<li>MSAA is app driven</li>
|
||
|
</ul>
|
||
|
<li>Doc format is changed from txt to html and content is revised</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.52</font>
|
||
|
<ul><li>Support for new output APIs are added</li>
|
||
|
<ul>
|
||
|
<li>Direct3D11 at feature level 10.0 (there are some restrictions)</li>
|
||
|
<li>Direct3D11 Microsoft WARP renderer</li>
|
||
|
</ul>
|
||
|
<li>Support for rendering DirectShow movie playback</li>
|
||
|
<li>Resolution overriding for DirectX emulation is now available</li>
|
||
|
<li>New scaling mode (forced 4:3 aspect ratio) with/without CRT-like
|
||
|
appearance is added</li>
|
||
|
<li>MSAA support for DX8</li>
|
||
|
<li>Lot of DX8 bugfixings</li>
|
||
|
<li>A few DDraw/D3D bugfixings</li>
|
||
|
<li>Making 'VertexLayout' functionality be compatible with a real 3Dfx
|
||
|
driver (Glide3)</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.51</font>
|
||
|
<ul><li>Point sprite support for DX8 is added</li>
|
||
|
<li>New texture formats (A8, L8, A8L8) for DX7/DX8 are added</li>
|
||
|
<li>Tons of DX8 bugfixings, more compatibility</li>
|
||
|
<li>More DirectDraw compatibility in object handling + bugfixing</li>
|
||
|
<li>Regression bugs in Glide fixed</li>
|
||
|
<li>Capabilities of GeForce Ti 4800 and ATI Radeon 8500 are changed to be much
|
||
|
closer to the real ones (see the technical details in the DX readme)</li>
|
||
|
<li>AMD driver bug causing driver crash with Glide rendering is workarounded
|
||
|
now dgVoodoo should work on all AMD cards properly</li>
|
||
|
<li>'Fast video memory access' is now compatible with Unreal engines</li>
|
||
|
<li>Emulated method of stretching the display output with keeping aspect ratio
|
||
|
is added</li>
|
||
|
</ul>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.5</font>
|
||
|
<ul><li>First version of D3D8 implementation is added</li>
|
||
|
<li>Lot of bugs fixed during general DirectX code refactoring, I don't want
|
||
|
to detail them all here</li>
|
||
|
<li>Dynamic shader compiling for all API components for better performance
|
||
|
(see Usage and DirectX readme for details, you'll need D3DCompiler_43.dll
|
||
|
for this feature)</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
</br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.45</font>
|
||
|
<ul><li>Heavily refactored DirectX emulation code for certain planned features</li>
|
||
|
<li>Full cooperating between Glide and DirectX</li>
|
||
|
<br>
|
||
|
<li>DirectDraw emulation:
|
||
|
<ul>
|
||
|
<li>True multidevice support, more robust DDraw emulation</li>
|
||
|
<li>OLE interface support for DirectDraw</li>
|
||
|
<li>DXTC (S3TC) block compression encoder is added, full support for
|
||
|
possible alpha-format conversions</li>
|
||
|
<li>Two new video card types are added with slightly different properties
|
||
|
(GeForce4 Ti 4800, ATI Radeon 8500)</li>
|
||
|
<li>DirectDraw emulation-only mode could fail, fixed</li>
|
||
|
<li>Various DirectDraw bugs/incompatibilities are fixed</li>
|
||
|
<li>Blitting bugs fixed + full support for blitting from primary surface</li>
|
||
|
</ul>
|
||
|
<br>
|
||
|
<li>Direct3D emulation:</li>
|
||
|
<ul>
|
||
|
<li>New colorkeying method added and existing colorkeying related bugs
|
||
|
are fixed</li>
|
||
|
<li>Bugs in rendering from execute buffers (points/lines), fixed</li>
|
||
|
<li>Bug in handling state blocks, fixed</li>
|
||
|
</ul>
|
||
|
<br>
|
||
|
<li>Glide rendering</li>
|
||
|
<ul>
|
||
|
<li>Resolution extension support (idea and technical concept by VEG and Zeus)</li>
|
||
|
</ul>
|
||
|
</ul>
|
||
|
</li>
|
||
|
</br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.44</font>
|
||
|
<ul>
|
||
|
<li>DirectX emulation:</li>
|
||
|
<ul>
|
||
|
<li>Some surface/D3D device related bugs are fixed</li>
|
||
|
<li>Mirrored blitting was broken, fixed</li>
|
||
|
<li>24bit software surface support is added</li>
|
||
|
<li>support for DXT1-5 compressed textures is added but an S3TC encoder is
|
||
|
still missing for the cases when a compressed texture is the blitting
|
||
|
target</li>
|
||
|
<li>Transforming normal vectors was incompatible with MS D3D, fixed
|
||
|
This fix includes enabling/disabling of normalizing them, default was
|
||
|
wrong for older than DX7 interfaces</li>
|
||
|
<li>Colorkey blend capability is added</li>
|
||
|
<li>support is added for old mode-X display modes</li>
|
||
|
<li>Various other small bugs fixed that I can't remember of</li>
|
||
|
</ul>
|
||
|
</ul>
|
||
|
</li>
|
||
|
</br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.43</font>
|
||
|
<ul>
|
||
|
<li>DirectX emulation:</li>
|
||
|
<ul>
|
||
|
<li>3D support for 8 bit surfaces is added (Colin McRae Rally)</li>
|
||
|
<li>Improved surface blitting, more optimal resource consuming for 3D
|
||
|
surfaces
|
||
|
<li>First version of fast surface video memory CPU-access is added
|
||
|
<li>Introducing 'lost' state into the default DX behavior, with additional
|
||
|
automatic self-restore mechanism for buggy DX applications
|
||
|
<li>3D TL vertex rendering incompatibilites, fixed
|
||
|
<li>Various small 3D/caps related bugs, fixed
|
||
|
<li>Several other bugfixes that I don't want to word here
|
||
|
</ul>
|
||
|
<li>Other:</li>
|
||
|
<ul>
|
||
|
<li>Some problems related to the window procedures and message handling
|
||
|
are fixed</li>
|
||
|
<li>Names of the wrapped running DX applications were displayed incorrectly,
|
||
|
fixed</li>
|
||
|
</ul>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.42</font>
|
||
|
<ul>
|
||
|
<li>Direct3D3 renderstate handling bugfixes (some of them were disabled)</li>
|
||
|
<li>Various DirectDraw bugfixes like object/structure version handling,</li>
|
||
|
surface blitting, basic ROP codes are added, and others</li>
|
||
|
<li>Compatibility fixings in DirectDraw surface creation functionality</li>
|
||
|
<li>Compatibility fixings in DirectDraw surface locking functionality</li>
|
||
|
<li>Compatibility fixings in Direct3D device creating</li>
|
||
|
<li>Fixing/refactoring light handling in general; now software vertex
|
||
|
processing can handle any number of them, and also, they can be added at
|
||
|
any index in Direct3D7</li>
|
||
|
<li>32 bit z-buffer support added</li>
|
||
|
<li>Minor Direct3D rendering bugs</li>
|
||
|
<li>Bad return code in an empty (but necessary) function on IDirect3DTexture,
|
||
|
fixed</li>
|
||
|
<li>Missing multithreading guarding in some Direct3D3 methods, fixed</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
</li>
|
||
|
<font color = "#FFFFFF">2.41</font>
|
||
|
<ul>
|
||
|
<li>Direct3D 3 support is added;
|
||
|
that is all Direct3D interface is supported now</li>
|
||
|
<li>Bug in the resolution enumerator in DirectDraw, fixed
|
||
|
(classic and all other resolutions are now enumerated with all bit depths.)</li>
|
||
|
<li>Resolution combo box was buggy in the setup; couldn't enumerate anything
|
||
|
when too much resolutions were available, fixed</li>
|
||
|
<li>Logic of selecting the refresh rate when unspecified rate is requested
|
||
|
by the application is changed</li>
|
||
|
<li>Overridable refresh rates</li>
|
||
|
<li>Bugfixings and improvement for blitting to the primary surface in
|
||
|
DirectDraw</li>
|
||
|
<li>Bugfixings for other general surface locking/blitting functionality</li>
|
||
|
<li>Minor DrawPrimitive bug fixed (missing triangles in Diablo II with
|
||
|
Direct3D renderer)</li>
|
||
|
<li>Bug with monochrome lighting is fixed
|
||
|
(discovered with Jedi Knight - Mysteries of the Sith)</li>
|
||
|
<li>Bug in surface blitting, fixed (The Settlers IV)</li>
|
||
|
<li>Bug/incompatibility fixings in surface handling in:
|
||
|
GetAttachedSurface, EnumerateSurfaces, SetSurfaceDesc and loading
|
||
|
textures from system memory surfaces to texture surfaces in video memory</li>
|
||
|
<li>DX wrapper is now more noshutdown-proof when unexpectedly pulled out from
|
||
|
the process memory area; LithTech engine based games now should work
|
||
|
(tested with Blood2 and Shogo Mobile Armor Division)</li>
|
||
|
<li>Various other small bugs fixed that I came across</li>
|
||
|
<li>Introducing 'unspecified' scaling mode. If you want to apply
|
||
|
'scaling but keeping aspect ratio' then select it on your graphics driver
|
||
|
control panel and select 'unspecified' mode in dgVoodoo Setup.
|
||
|
If it does not work then your only chance is forcing it through the
|
||
|
graphics control panel (it all seems to be a Windows issue).</li>
|
||
|
<li>Disabling 'Bilinear blit stretch' in the default configuration.
|
||
|
I've seen a few games where it caused more 'harm' than coolness that is
|
||
|
why I decided to disable it by default.</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.4</font>
|
||
|
<ul>
|
||
|
<li>DirectX rendering:</li>
|
||
|
<ul>
|
||
|
<li>New, improved version of DirectDraw. It fully supports creating and
|
||
|
blitting to/from textures, Z-buffers and 3D-renderable surfaces with
|
||
|
several pixel formats. Also, general API-behavioring is more accurate
|
||
|
to the original one because of lot of bugfixings and heavy reverse
|
||
|
engineering.</li>
|
||
|
<li>Gammacontrol interfaces is added to DirectDraw</li>
|
||
|
<li>First version of Direct3D implementation is added and (almost) fully
|
||
|
supports DirectX5, DirectX6 and DirectX7. For more and technical details,
|
||
|
see the DirectX readme. Direct3D interfaces are also as carefully reverse
|
||
|
engineered as DirectDraw ones.</li>
|
||
|
</ul>
|
||
|
|
||
|
<li>Glide rendering:</li>
|
||
|
<ul>
|
||
|
<li>Bug in handling utility textures, fixed (missing textures in South Park)</li>
|
||
|
<li>Bug with PALETTE6666 extension fixed
|
||
|
(unreadable menu text in Need For Speed - Porsche 2000 with a Voodoo2
|
||
|
or higher)</li>
|
||
|
<li>Bug with tripebuffering fixed (missing 3D elements in The Tainted)</li>
|
||
|
<li>Adapting Glide3 to 3Dfx mini GL driver (3Dfxvgl.dll),
|
||
|
(American McGee's Alice):</li>
|
||
|
<li>Lowering gamma bitnum to 8 (3Dfx didn't follow his own rules...)</li>
|
||
|
<li>Some init/exit code could get stuck because they can get called from
|
||
|
DLLMain, fixed</li>
|
||
|
</ul>
|
||
|
<li>Setup</li>
|
||
|
<ul>
|
||
|
</li>'Apply' button in the setup is added
|
||
|
(I got bored to OK'ing and reopening the setup each time I want to
|
||
|
modify the config of more folders or running instances)</li>
|
||
|
</ul>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.32</font>
|
||
|
<ul>
|
||
|
<li>Possibility of overriding the application resfresh rate is added</li>
|
||
|
<li>Small Glide3 fix (bug with Turok 2)</li>
|
||
|
<li>Minor Glide3 shader modification (SurfDemo)</li>
|
||
|
<li>Glide lib is made thread-safe at the needed (minimal) level
|
||
|
(means avoiding crashes at certain circumstances where the original
|
||
|
3Dfx driver survived beause of its architecture; a Turok 2 issue again,
|
||
|
using background threads)</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.31 - It is a slight patch version for 2.3:</font>
|
||
|
<ul>
|
||
|
<li>Fixing Glide 3DF reader for various line ending types (Crazy Marbles)</li>
|
||
|
<li>A bug found in one of Glide state setting functions, fixed (Crazy Marbles)</li>
|
||
|
<li>Hidden/shown cursor glitch is (seems to be) fixed in windowed mode</li>
|
||
|
<li>Possibility of forcing progressive scanline order on output display is
|
||
|
now available in the setup</li>
|
||
|
<li>Fixing some DirectDraw bugs thanks to other pending developments
|
||
|
(what I don't want to release yet)</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.3 - This won't be easy because I suspended developing for a few months, but:</font>
|
||
|
<ul>
|
||
|
<li>First I refactored the code in order to any new driver component or
|
||
|
renderer could be added easily</li>
|
||
|
<li>Fixed some issues with multiple video cards/monitors. Now it works OK
|
||
|
in a multi-videocard system (not so frequent usecase but I like if
|
||
|
something is done well)</li>
|
||
|
<li>Added first version of DirectDraw component to the driver</li>
|
||
|
<li>Minor Glide shader modifications</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.2</font>
|
||
|
<ul>
|
||
|
<li>Napalm build added</li>
|
||
|
<li>Glide3 fixings: erroneous clip coord space handling</li>
|
||
|
<li>Small bug related to lfb write with active pipeline, fixed</li>
|
||
|
<li>Setup got revamped a bit</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.15</font>
|
||
|
<ul>
|
||
|
<li>Full support for texture buffers via Glide3 extension 'TEXTUREBUFFER'
|
||
|
All 16 bit texture formats are supported as rendering format except for
|
||
|
paletted ones</li>
|
||
|
<li>Bad color order for delta0 color, fixed
|
||
|
(seems I'm not in luck with RGBA order in general)</li>
|
||
|
<li>Some bugs are fixed I found through my own tests: unwritten alpha values
|
||
|
to the aux buffer, bogus Glide3 viewport handling</li>
|
||
|
<li>More optimization in LFB lock handling to avoid slowdowns on locking
|
||
|
patterns/usage like in King's Quest: Mask of Eternity
|
||
|
(Thanks for the feedback & help, Andrew!!)</li>
|
||
|
<li>A lot of code changed thanks to other developments, so I hope I have
|
||
|
not broken anything</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.14</font>
|
||
|
<ul>
|
||
|
<li>Unified Memory Architecture (UMA) along with TEXUMA Glide3 extension
|
||
|
is supported</li>
|
||
|
<li>Some Voodoo hardware properties are changed according to UMA/non-UMA
|
||
|
architecture<br>
|
||
|
(Now Extreme Assault works with Gulikoza's latest patch, but see Tips
|
||
|
for more)</li>
|
||
|
<li>Optimizations for lfb read/write region (including 3Dfx watermark)</li>
|
||
|
<li>A missing thing from PCI emulation is implemented for perfect lfb
|
||
|
access with active pixel pipeline</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.13</font>
|
||
|
<ul>
|
||
|
<li>Improved PCI emulation for LFB access: heavy lfb-lockers like Carma1
|
||
|
and Pyl SHOULD run much smoother now (see Tips for more)</li>
|
||
|
<li>Glide3 fixings: bad color order with packed RGBA, uninitialized
|
||
|
texchroma state</li>
|
||
|
<li>General glide fixings: bug in glide setstate and clip rectangle</li>
|
||
|
<li>Missing feature "fog with iterated z" is implemented along with minor
|
||
|
shader modifications</li>
|
||
|
<li>Support for splash screen and shameless plug: dgVoodoo needs the 3Dfx
|
||
|
splash dlls to get it working (3DfxSpl2.dll, 3DfxSpl3.dll, all with
|
||
|
version 1.0.0.4), however I did not include them in the core dgVoodoo
|
||
|
pack</li>
|
||
|
<li>Minor modification for DosBox</li>
|
||
|
<li>TMUnum selector combobox is fixed, I fcked it down last time</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.12</font>
|
||
|
<ul>
|
||
|
<li>More shader optimizations: most critical ones are reduced to 90% in
|
||
|
size again (So, by now, their size are 65% of the original. I hope I
|
||
|
have not messed up anything with them.)</li>
|
||
|
<li>Optional 16 bit depth buffer (see Tips for why is that)</li>
|
||
|
<li>Some fixings in Glide3 thanks to some unexpected API-driving
|
||
|
(scene demo Virhe)</li>
|
||
|
<li>Some bugs related to maintaining/switching/handling windowed/fullscreen
|
||
|
state are fixed</li>
|
||
|
<li>Voodoo2 with 1 TMU is no longer selectable in the setup; A Voodoo2
|
||
|
always have 2 TMUs and it is the default now because shaders are
|
||
|
optimal enough now to handle 2 TMUs</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.11</font>
|
||
|
<ul>
|
||
|
<li>Refactoring GPU querying to get it to work with ATI drivers
|
||
|
(ATI does not seem to handle them correctly, my code was always fooled
|
||
|
into infinite loop at a certain point)</li>
|
||
|
<li>Further shader optimizations: most critical ones are reduced to 90% in
|
||
|
size</li>
|
||
|
<li>Minor cursor-issue related to losing window focus, fixed</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.1</font>
|
||
|
<ul>
|
||
|
<li>Potential stalling rendering (even on fast GPUs) when switching screen
|
||
|
modes, fixed</li>
|
||
|
<li>Shader optimizations: most critical ones are reduced to ~80% in size</li>
|
||
|
<li>Ability to configure running Glide wrapped applications dynamically
|
||
|
(see section 'Configuring')</li>
|
||
|
<li>Different exposed capabilities according to the selected card type</li>
|
||
|
<li>More Dosbox compatibility</li>
|
||
|
<li>Bug in gammaramp handling, fixed</li>
|
||
|
<li>Bug in fogtable generating code, fixed</li>
|
||
|
<li>Bug in PCI access emulation, fixed</li>
|
||
|
<li>Forced vSync is enabled by default to avoid overkilling the GPU with
|
||
|
wild-rendering applications</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.01</font>
|
||
|
<ul>
|
||
|
<li>Undrawn polygons when updating TMU memory, fixed</li>
|
||
|
<li>Potentially bad drawing of strip-primitives in Glide3, fixed</li>
|
||
|
<li>Malfunctioning LFB lock with 32bit formats when PCI emulation is
|
||
|
enabled, fixed</li>
|
||
|
<li>Fullscreen/Windowed state was not always remembered between
|
||
|
Glide-initializings, fixed</li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<br>
|
||
|
<li>
|
||
|
<font color = "#FFFFFF">2.0 - The original version</font>
|
||
|
</li>
|
||
|
</ul>
|
||
|
|
||
|
|
||
|
Have luck,<br>
|
||
|
|
||
|
Dege
|
||
|
|
||
|
|
||
|
<hr></hr>
|
||
|
|
||
|
<font>
|
||
|
</body>
|
||
|
|
||
|
</html>
|