Valhalla Legends Archive

General => General Discussion => Topic started by: Skywing on February 10, 2004, 12:13 PM

Title: DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.035
Post by: Skywing on February 10, 2004, 12:13 PM
DxWnd (http://www.valhallalegends.com/skywing/files/DxWnd/DxWnd.zip) can be used to run DirectDraw 7 (or below) programs as a window, even if they don't natively support a windowed mode.  It probably won't work with programs that use Direct3D or DirectDraw 8/9 right now.

If it doesn't quite give the results you expect with a game (such as odd cursor behavior), you may have some luck by customizing the standard patch configuration for the program.

Feel free to post back with any programs you get it working with, and what options you used.

As a side note, games that were ported from DOS to Win32 are an especially good candidate for this.

A list of known compatible games and the options to use with them is included.

System requirements:
Windows NT 4.0/2000/XP/Server 2003/Longhorn (no support for Win9x/Me)
VC8 runtime libraries (available here (http://www.valhallalegends.com/pub/vcredist_x86.exe) if you don't already have them installed).

Update History:

[02/10/2004] Version 1.02 has been released.  This corrects an issue that prevented the Starcraft patcher from working properly, and adds a new patch option to the standard patcher (Defer Window Display).  This option is off by default.

[03/18/2004] Version 1.031 has been released.  This corrects an issue that caused crashes when programs called GetProcAddress with an ordinal.  Additionally, it introduces preliminary Direct3D8 support (further testing is required to determine how well the D3D8 patching will work in practice - this is included in the generic patcher).

[03/18/2004] Version 1.032 has been released.  This adds some new compatibility fixes, which among other things can be used to fix some problems when playing Civilization III with DxWnd.  Additionally, now the first patcher in the patcher list is automatically selected when you first start DxWnd.

[09/24/2006] Version 1.034 has been released.  This is a minor release that fixes a couple of obscure crash problems, and adds experimental support for rescaling windows to a larger size for DirectDraw (at this time, scaling is available only for the Standard patcher, not the Starcraft patcher).  To enable scaling, configure a program with the Standard patcher and select the "Stretch Video" option.  Optionally, specify an initial desired window size with the "Window Size" option.  Rescaling the program's video output in this manner will incur a performance penality, so if your program runs too slow with scaling enabled, you may need to disabling scaling and run the program at it's normal output size.  Additionally, scaling will result in a perceived loss in precision with the mouse cursor, as coordinates are translated back down to the program's preferred video output size.  Enabling scaling will also enable the maximize and resize functionality for the main program window of the program you are patching.  Remember that if you have selected the "Clip Cursor to Window" option, the cursor will continue to be clipped to the client area as long as the target program has focus, so you will probably need to right click on the task bar icon for the program to access to the maximize or resize options from the system menu.  Additionally, this release was rebuilt using a new compiler, so new runtime libraries are required (linked from this post); be sure to install them if you are unable to start the new DxWnd version.

[09/24/2006] Version 1.035 has been released.  This release fixes a longstanding graphics corruption problem with games using IDirectDrawSurface::Flip (such as Master of Orion II), and fixes a problem where the "Stretch Video" option would not function as expected if the window size was left set at the automatic option.

Getting Started:
After you download and extract the DxWnd.zip you can begin by either executing from command line (in Command Prompt) or more conveniently create a shortcut. The syntax for the execution should be: <DxWnd.exe> <Game.exe> <Patch.dxw>
(e.g. With Starcraft, I created a shortcut named "Starcraft – Window Mode" and then as a the target: "C:\Documents and Settings\Interdev\My Documents\My Received Files\DxWnd\DxWnd.exe" "C:\Program Files\Starcraft\starcraft.exe" "C:\Documents and Settings\Interdev\My Documents\My Received Files\DxWnd\Starcraft.dxw")

How You Can Help :):
We are going to extended lengths to provide open knowledge and resources for DxWnd so that we can enhance the database of games in which DxWnd may support. You can help by submitting (preferably in this forum thread) which games you found to be working and which patch was used during testing, so that we may add to our compatibility.txt (or perhaps a more efficient database, depending on popularity). Another way to help would of course be writing the patches for the games that may need them, as well as what options you use while configuring DxWnd to work with the specified game. Finally, you will be a great help by submitting any known errors with DxWnd. –Please-, be specific. Read current known compatibility issues and errors before submitting. Also, give as many details as you possibly can. Thank you all for your interest in DxWnd.

Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window)
Post by: Soul Taker on February 10, 2004, 03:38 PM
Can't download it =[
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window)
Post by: Hostile on February 10, 2004, 05:38 PM
Yes, something currently wrong with website, please don't make any more posts concerning that until its fixed. Thanks.
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window)
Post by: UserLoser. on February 10, 2004, 08:42 PM
Work with Starcraft? If so, how?  I tried to run the Starcraft HDL file, and some error came saying something about "Apply"?  Tried run on Starcraft.exe, was still in full window

XP Home/has runtimes
Title: Additional information for developers
Post by: Skywing on February 10, 2004, 10:49 PM
If you want to write a patch for a specific game, you can use the following:
DxWnd extensions are DLLs with the .dxw extension.  They must export the DxwQueryProgram and ClientDllInitialize functions, and may export the DxwConfigureProgram function (these are described in DxWnd.h).

If a debugger is attached to the target process, DxWndSrv.dll will breakpoint just before loading your DLL in ServerDllInitialize, but after signalling to DxWnd.exe that the bootstrap sequence completed.  Thus, you should set any breakpoints starting from the ServerDllInitialize breakpoint instead of the initial process breakpoint to avoid DxWnd.exe timing out on the bootstrap sequence and terminating the new process.

In order to debug a game launched by DxWnd, you should start DxWnd.exe under your debugger (with the debugger configured to debug child processes).

If all goes well, you should see something like this when attaching to the new process and running after the initial breakpoint:

DxWndSrv: Process attach completed; breaking before ClientDllInitialize.
DxWndSrv: SharedData @ 00140000
(8dc.95c): Break instruction exception - code 80000003 (first chance)
eax=00000000 ebx=00140000 ecx=77f467f9 edx=00150608 esi=4a000000 edi=00140000
eip=4a0010f5 esp=0012f4f8 ebp=0012fd20 iopl=0         nv up ei pl zr na po nc
cs=001b  ss=0023  ds=0023  es=0023  fs=0038  gs=0000             efl=00000246
DxWndSrv!ServerDllInitialize+0x85:
4a0010f5 cc               int     3


All calls to ServerDisplayString are also displayed to the debugger, if one is attached.  This is true even if ServerEnableConsole has not been called.

I've compiled a listing of vtable offsets for DirectDraw and DirectInput calls that may be of use if you are looking at the disassembly for a game and are trying to see what DirectX call it's trying to make:
Feel free to post if you think that you have found a bug or deficiency in DxWndSrv.dll.
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: Maddox on February 15, 2004, 03:14 PM
It doesn't work well with Starcraft. Text gets written on top of each other making it impossible to read. The channel list also gets redrawn every second. Everything is also slowed down. I didn't try in-game because I just quit after I saw all the problems.
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: Kp on February 15, 2004, 03:40 PM
Quote from: Maddox on February 15, 2004, 03:14 PM
It doesn't work well with Starcraft. Text gets written on top of each other making it impossible to read. The channel list also gets redrawn every second. Everything is also slowed down. I didn't try in-game because I just quit after I saw all the problems.

Yes.  Starcraft does quite a few unusual and bad things for its interface.  Skywing actually wrote ScWnd specifically to window-ize Starcraft, then later created DxWnd as a more generic program.  If you actually want Starcraft in a window, I'd suggest using ScWnd instead.  When I last checked, there were a few minor issues, but it worked much better than the problems you describe. :)
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: Spht on February 15, 2004, 04:33 PM
Quote from: Maddox on February 15, 2004, 03:14 PM
It doesn't work well with Starcraft. Text gets written on top of each other making it impossible to read. The channel list also gets redrawn every second. Everything is also slowed down. I didn't try in-game because I just quit after I saw all the problems.

It works just fine for me. You may want to considering upgrading if Starcraft's running slow...
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: Skywing on February 15, 2004, 06:55 PM
Note that ScWnd is included with and is useable from DxWnd.

Also, note that in-game performance is significantly improved over in-bnchat performance when using ScWnd due to some expensive workarounds for flaws in how the battle.net chat GUI works.
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: Maddox on February 15, 2004, 09:20 PM
Quote from: Spht on February 15, 2004, 04:33 PM
Quote from: Maddox on February 15, 2004, 03:14 PM
It doesn't work well with Starcraft. Text gets written on top of each other making it impossible to read. The channel list also gets redrawn every second. Everything is also slowed down. I didn't try in-game because I just quit after I saw all the problems.

It works just fine for me. You may want to considering upgrading if Starcraft's running slow...

It only runs slow in the window.
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: Denial on February 15, 2004, 11:59 PM
half life works


the version for broodwar goes nice and fast except when i try to move the window it just disappears and shuts down

I tried a ingame thing and when i move the window nothing happens the window doesnt die and i do see text drawn over each other as well


I decided then to try and just make  my own broodwar one. but it keeps the mouse inside the window like its little and i have to alt+tab to get out of the window ... but on yours i dont. This is the stuff i recorded off the one i made


DDPatchInit: Setting initial patches for 00000000...
DIPatchInit: Setting initial patches for 00000000...
MyCreateWindowExA: Setting 640x480 (centered, styles) - requested 1024x768
MyGetProcAddress: Returning MyDirectDrawCreate
PatchDirectDraw: Setting IDirectDraw hooks...
MySetCooperativeLevel: Setting DDSCL_NORMAL, adjusting main window size
MySetDisplayMode: Discarding request for 640x480x8
MyCreateSurface: Surface request (caps 00000200 flags 00000001)
MyCreateSurface: Creating primary surface
MyCreateSurface: Auto-selecting surface dimensions 640x480x8...
PatchDirectDrawSurface: Setting IDirectDrawSurface hooks for 00b31f20...
MyCreateSurface: Primary surface is 00b31f20
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: Skywing on February 16, 2004, 12:24 PM
Remember that you need to use the Starcraft/Diablo I/Warcraft II patcher with SC/BW; don't use the generic patcher.

The battle.snp GUI has some problems, but it's at least useable.  Avoid moving the game window while the Battle.net chat GUI is up, and avoid moving other windows on top of the game window while the Battle.net chat GUI is up.  If I find a good solution to fix these remaining problems, I'll update the Starcraft patcher - but I wouldn't count on this happening any time soon.

And yes, performance will be slower windowed.  However, with the Starcraft patcher you will see much better performance in-game than in-bnchat.  As long as you weren't borderline for the game system requirements, it should be perfectly playable windowed.
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: Denial on February 16, 2004, 01:59 PM
ok ya i tried the ingame play and it works perfectly i owned me some computers

P.S. if you didn't see half-life works pretty nice
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: TheMinistered on February 16, 2004, 09:08 PM
nvm -- oxymoron question ;)
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: Skywing on February 16, 2004, 09:23 PM
Quote from: Denial on February 16, 2004, 01:59 PM
ok ya i tried the ingame play and it works perfectly i owned me some computers

P.S. if you didn't see half-life works pretty nice
With DxWnd? What settings did you use?

Quote from: TheMinistered on February 16, 2004, 09:08 PM
I'm curious how you inject a .NET dll into SC.  Do you drag the entire .NET runtime/clr/whatever it uses into the SC address space?
I don't... none of that is .NET.
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: l)ragon on February 16, 2004, 10:32 PM
Quote from: Denial on February 16, 2004, 01:59 PM
ok ya i tried the ingame play and it works perfectly i owned me some computers

P.S. if you didn't see half-life works pretty nice

btw HL is allready windowable.

Edit: -window comand line
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: Spht on February 17, 2004, 10:51 AM
Quote from: dRAgoN on February 16, 2004, 10:32 PM
Quote from: Denial on February 16, 2004, 01:59 PM
ok ya i tried the ingame play and it works perfectly i owned me some computers

P.S. if you didn't see half-life works pretty nice

btw HL is allready windowable.

Edit: -window comand line

So are other games I've tried, but by default they run non-window so it's nice to test DxWnd on as many things as possible.
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: iago on February 17, 2004, 11:57 AM
Quote from: Skywing on February 16, 2004, 09:23 PM
Quote from: TheMinistered on February 16, 2004, 09:08 PM
I'm curious how you inject a .NET dll into SC.  Do you drag the entire .NET runtime/clr/whatever it uses into the SC address space?
I don't... none of that is .NET.

he was probably confused by the fact that it uses .net runtimes (ie, vc7 stuff).
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.02
Post by: l)ragon on February 17, 2004, 09:52 PM
Quote from: Spht on February 17, 2004, 10:51 AM
Quote from: dRAgoN on February 16, 2004, 10:32 PM
Quote from: Denial on February 16, 2004, 01:59 PM
ok ya i tried the ingame play and it works perfectly i owned me some computers

P.S. if you didn't see half-life works pretty nice

btw HL is allready windowable.

Edit: -window comand line

So are other games I've tried, but by default they run non-window so it's nice to test DxWnd on as many things as possible.

I realized what your getting at just after I posted, I was going to remove the post but I figured he never knew that command line.
Title: DxWnd 1.031 released
Post by: Skywing on March 18, 2004, 01:03 AM
This corrects a crash when programs called GetProcAddress with an ordinal.

Additionally, it introduces preliminary Direct3D8 support to the generic patcher.  Because this has not been well tested, use at your own risk.

You can now use Civilization III with DxWnd (it crashed in previous versions due to the GetProcAddress problem mentioned above).  Non-standard settings are required in order for it to function properly; see Compatibility.txt in the program package for more details.
Title: DxWnd 1.032 released
Post by: Skywing on March 18, 2004, 07:08 PM
This version adds some new compatibility options (such as overriding the game window size).

You need to use some of these to get Civilization III working completely - see the updated Compatibility.txt.
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.032
Post by: Soul Taker on April 11, 2004, 04:38 PM
This has always worked with SC, but I just installed Diablo and it just runs it in fullscreen.  Something I'm not thinking of?
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.032
Post by: Skywing on April 15, 2004, 02:17 AM
Quote from: Soul Taker on April 11, 2004, 04:38 PM
This has always worked with SC, but I just installed Diablo and it just runs it in fullscreen.  Something I'm not thinking of?
I'll see if I can reproduce the problem - are you using the latest Diablo version, or the retail CD version?
Title: Re:DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.032
Post by: Soul Taker on April 15, 2004, 04:25 AM
Quote from: Skywing on April 15, 2004, 02:17 AM
Quote from: Soul Taker on April 11, 2004, 04:38 PM
This has always worked with SC, but I just installed Diablo and it just runs it in fullscreen.  Something I'm not thinking of?
I'll see if I can reproduce the problem - are you using the latest Diablo version, or the retail CD version?
Latest version, I play it on Bnet daily.
Title: Re: DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.032
Post by: DiskoLLama on October 22, 2004, 07:40 AM
This dosen't work for Warcraft 3 TFT or ROC. The generic patch(no customization) doesn't load the game in a window(war3.exe) and I don't think any possible combination of customization can allow the game to run in a window.

Perhaps another game-specific patch is required?

*edit*

Stupid me, Warcraft3 already has a windowed option. My bad.
Title: Re: DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.032
Post by: MyndFyre on October 25, 2004, 02:28 PM
Quote from: DiskoLLama on October 22, 2004, 07:40 AM
This dosen't work for Warcraft 3 TFT or ROC. The generic patch(no customization) doesn't load the game in a window(war3.exe) and I don't think any possible combination of customization can allow the game to run in a window.

Perhaps another game-specific patch is required?

*edit*

Stupid me, Warcraft3 already has a windowed option. My bad.

Stupid you, you 1.) revived a post dead for 6 months, and 2.) talked about a Dx7 utility not working for a program that requires Dx8 or better.
Title: Re: DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.032
Post by: setsukun on February 03, 2005, 01:42 AM
I'm trying to get Final Fantasy 7 to work with DxWnd, and so far no luck.

Final Fantasy 7 has a quarter screen option where it just loads the game in your desktop resolution and throws the game into the center of the screen with black around it. I like the way the game looks like, but I'd rather have it in a movable window.
Title: Re: DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.034
Post by: Skywing on September 24, 2006, 02:09 PM
1.034 has been released.  See the main post for details.
Title: Re: DxWnd (Run DirectDraw fullscreen apps as a window) - current version: 1.035
Post by: jwilcox25 on September 04, 2009, 08:10 PM
I love this program, and was wondering if it's still in development. Definitely has more options and customizability than the MapleStory version of DxWnd. I would love to see support for more programs like Zuma (higher than 640x480), Risk II, and Worms Armageddon.

Implementing resize filters like hq2x would also be awesome! I'd be happy to help in anyway I can.