当前位置:主页 > 资料 >

Dolphin Progress Report: July 2018
栏目分类:资料   发布日期:2018-08-02   浏览次数:

导读:本文为去找网小编(www.7zhao.net)为您推荐的Dolphin Progress Report: July 2018,希望对您有所帮助,谢谢! On July 13th, 2008, , now just over ten years ago. While it could be easy to drift off into how much things have

本文为去找网小编(www.7zhao.net)为您推荐的Dolphin Progress Report: July 2018,希望对您有所帮助,谢谢! 本文来自去找www.7zhao.net



On July 13th, 2008, , now just over ten years ago. While it could be easy to drift off into how much things have changed... there's one particular feature that has never quite lived up to the hype despite debuting that very same year - netplay.

去找(www.7zhao.net欢迎您

As surprising as it may sound Dolphin Netplay has been around since the emulator went open source. For roughly a decade, users have tried their hand at taming the beast of synchronizing multiple instances of a GameCube and Wii despite their relative complexities. Netplay allows users to run the same instance of game on multiple computers by having two or more emulators in the exact same state, only transferring inputs between one another. By staying in lockstep like this, theoretically the emulators' states will never diverge assuming perfect determinism. This would allow people across the world to play a game together, even if it only featured local multiplayer on the console. 内容来自www.7zhao.net

The problem has always been attaining that determinism. Back in the early days of netplay, it didn't especially matter what settings were used; Dolphin wasn't deterministic enough to stay in lockstep for very long. Then in the early days of the 3.0 era, it was finally possible to stay synced - if you were willing to sacrifice audio and performance. Early netplayers would hack up Dolphin to reduce requirements with 30 FPS hacks to , hacks to LLE audio to make it slow down less during attacks, and much more. 本文来自去找www.7zhao.net

Despite the stutters and desyncs, some seriousMelee players saw the potential and kept with the project. It wasn't until New-AX-HLE Audio (part 2) hit Dolphin that audio was both performant and deterministic enough to use in netplay. By the time Dolphin 4.0 rolled around, netplay had become a staple forMelee users and could be used by advanced users willing to suffer through some annoying quirks. copyright www.7zhao.net

In the last few years, a focus has gone toward adding highly requested features to make netplay easier to use. Dolphin's STUN service allows some users who cannot port-forward play on netplay without issues, saves can be disabled to make synchronizing party games easier. But the one constant is that despite all these advances, simply getting netplay to work was a chore and crashes were common even if you did everything right.

内容来自www.7zhao.net

Getting netplay into a more user-friendly state has been quite the process. In July, we saw some of the most drastic changes to netplay that we've seen in the past couple of years! Emulated Wii Remotes also saw huge usability improvements and some non-NVIDIA Android devices will finally be able to use Dolphin's Vulkan backend. If that wasn't enough, delivered some very big improvements to the DolphinQt GUI to give a new way to display your favorite games in the gamelist. Let's not delay any longer, please enjoy this month's Dolphin Progress Report.

copyright www.7zhao.net

This Month's Notable Changes
[GUI] Add Cover Support to Grid Layout (spycrab0)[Netplay] Vastly Improve Shutdown Behavior (spycrab0, Techjar)[Netplay] Reduce Bandwidth Usage (Techjar)[Netplay] Fix and Improve Various Interface Issues (Techjar, spycrab0)[Netplay] Automatically Synchronize Save Data (Techjar)[Netplay] Improve Setting Synchronization (Techjar)[Netplay] Prevent SRAM Clearing (Techjar)[Performance] Disable Branch Following for N64 VC Games (spycrab0)[Android] Make Touch Joystick Re-Centering Optional (gwicks)[Android-Vulkan] Implement 24-bit Depth Fallback (stenzek)[Android] Support For Oreo Homescreen Channels (zackhow)[Android] Fix Controllers Configuration for Emulated Wii Remotes (zackhow)[Wii Remote] Improve Various Emulated Wii Remote Input Behaviors (iwubcode)[Feature] Remove Skip DCBZ Hack (booto)[Website] Updates and Improvements

by

A lot of people have been wanting a coverflow GUI in Dolphin for a long time. While the banners may look okay in some instances, covers have added detail, nostalgic value, and can look great when flowing through Dolphin's gamelist. When DolphinQt was given Grid Layout long ago, the dream was to eventually pair that up with a cover database to produce a more visually pleasing gamelist. Thanks to some additions by and 's massive cover database, Dolphin can now display full covers in grid mode. 欢迎访问www.7zhao.net

To enable this feature, a new option in the interface menu has been added - Download Game Covers from GameTDB.com for Use in Grid Mode and must be enabled for Dolphin to start downloading covers. Do note that this will cause Dolphin to access the internet and, depending on the size of your gamelist, download hundreds of covers. There are a few differences between this and banners. Because Dolphin is downloading this from a separate service, we cache these separate from the gamelist cache in a GameCovers folder. This makes it less likely you'll have to download a cover multiple times, even if the gamelist cache is incremented to a new version. The other key difference is a big one - Wii games do not need a save for their cover to show up in the gamelist, unlike their banner. Depending on your gamelist, it may be easier to fill it in with covers than it is with banners!

内容来自www.7zhao.net

While Grid Layout has existed for quite a while, without the ability to use covers it didn't see much use. For those of you trying it out for the first time to make use of this feature, make sure to know that Control and + will zoom in, making the covers bigger, while Control and - will zoom out, allowing Dolphin to display more covers at once. If you have a lot of games, zooming out can give you a broader view. 本文来自去找www.7zhao.net

Maybe zooming out this much isn't a good idea...

There are some limitations to this - doesn't have every cover to every game and Dolphin doesn't try for more common regions yet on off-region games. As well, because Dolphin uses GameID to to determine which cover to grab, this means some homebrew and unlicensed titles may get the wrong cover or not cover at all. Some custom covers are on and will show up in Dolphin with patched ISOs, such as someMario Kart Wii Track Packs and various mods!

copyright www.7zhao.net

For now this is only available in the DolphinQt GUI and is not present within either Android GUI. That being said, there are plans to port the feature into the Android T.V. GUI where it would give everything a much nicer look.

内容来自www.7zhao.net

What if your favorite game doesn't have a cover?

While has a massive amount of covers, it doesn't have every cover for every region and there are some additional cases where looking up covers by GameID just doesn't work. In these cases, you can force a cover to a particular item in the gamelist by putting a file in the same directory with this structure. This can be done by adding a file in the directory that is [gamename].cover.png. Let's say you want to do it with theAdvance Game Port (named agp.iso for our purposes) a custom cover because it uses a GameINI stolen fromNHL HITZ 20-02. While doesn't have a cover directly for it,Dolphin's Game Wiki does ! We can download that, put it in the same folder as agp.iso and name it agp.cover.png to get a custom cover! copyright www.7zhao.net

You can even overrideGameTDBcovers with custom covers! Can you spot which cover doesn't belong?

In the situation above, two of custom covers for the unofficial discs came fromDolphin's Game Wiki and the last was made from photograph of the game case. Being able to do this is incredibly useful in the situations where is missing covers or Dolphin can't search for the cover thanks to the game having a bogus or no GameID. While this may seem like a lot to digest, there are mostly just edge-cases. The vast majority of users should be able to have a fully covered gamelist by just enabling the option. With that, we hope you enjoy using this new feature. copyright www.7zhao.net

The Netplay Revolution

, 5.0-8395, and5.0-8504 - Improve Netplay Shutdown Behavior by and

Anyone who's used Dolphin's netplay in the past couple of years knows a few key truths about the netplay experience. Once you know what you're doing, starting and playing a game on netplay aren't huge problems. Dolphin is relatively stable and people have proven that Dolphin can stay in sync for multiple days in a single session. While extending the session could delay the inevitable, when you were ready to stop, there was no avoiding your final fate. 去找(www.7zhao.net欢迎您

Death, Taxes and Dolphin's netplay segfaulting...

Dramatization of spycrab arriving on the scene.

欢迎访问www.7zhao.net

After being repeatedly harrassed, finally caved in and decided to look into the netplay stability issues. After felling the fearsome beast that was DolphinWx and porting over the netplay GUI, he couldn't imagine it being something he couldn't handle. Little did he know the horrors that awaited. www.7zhao.net

After recovering from the initial shock of seeing netplay's condition, realized there was a tiny flaw in the netplay infrastructure that could be the cause of some very minor issues. Namely, Dolphin instances connected to one another in netplay had no intention of letting the others know when they had stopped the game. So if a player closed their game after they were done playing, their instance would then say literally nothing to the other instances. So now these sessions are frozen waiting for inputs from the game that is stopped. Then, when that first instance leaves netplay altogether, the pad mappings attempt to change and all the other instances would deadlock! But even the instance that successfully left the session was a bit messed up. That instance would have to close Dolphin before it could ever start another netplay session because Dolphin never communicated to itself that the netplay session was over. This is what happens when you do not maintain your features.

copyright www.7zhao.net

It turned out not telling "Core" the game had stopped was a slight mistake.

In order to make things slightly more stable, has retrofitted Dolphin's netplay infrastructure with the revolutionary ability to tell itself and other instances of Dolphin within the same netplay session when the game has actually ended. Thanks to this change, it's entirely reasonable to play on netplay without everyone crashing at the end because Dolphin was in some messed up state of not knowing if a game was running of not.

欢迎访问www.7zhao.net

's efforts made it so anyone playing with GameCube controllers should be fine, but, while testing this feature, and ran into another issue that was just as puzzling. Spectators have no controllers assigned to them and Dolphin tries to make sure a spectator has no impact on the players playing the game. If a spectator has slowdown, it can fall behind the other players. If a spectator disconnects, the netplay session is supposed to continue on. And sometimes it did... and other times, Dolphin crashed. Over the course of three days (and testing other features in this report,) the two of them messed around with just about every idea you could imagine.

本文来自去找www.7zhao.net

Finally, added some extra netplay debug logging into the mix with5.0-8391 and they noticed packets indicating GameCube Pad/Wii Remote mappings being updated. This happening during a netplay session was a huge red flag and after some investigation, realized the input mapping code was misplaced outside of a loop and being triggered erroneously by spectators leaving the match despite not having any controllers! With two lines of code moved, this mysterious random crash was quelled.

本文来自去找www.7zhao.net

Addtional crashes relating to ending a session while MD5 calculation was active and other race conditions were quelled in5.0-8504. These crashes were caused by the netplay client object being destroyed while other threads were still using it. Because it was somewhat rare that this happened (and netplay shutdown behavior didn't work prior to this month...) it took quite a while to track down and cleanly fix the issue. copyright www.7zhao.net

Note: Emulated Wii Remotes are still a disaster on netplay. The above applies to GameCube Netplay and Wii games that can use GameCube Controllers.

内容来自www.7zhao.net

, , and 5.0-8412- Reduce Netplay Bandwidth Usage - by

Because Dolphin's netplay is more or less sending inputs to synchronize clients, you may think that bandwidth usage isn't an issue whatsoever. While those of you on top-end internet connections probably don't notice, Dolphin could actually use quite a bit of bandwidth. A popular netplay game likeMario Party 5 could require up to 300 Kbps upload in addition to other overhead. can have even higher requirements thanks to popular cheat codes to increase its polling rate beyond what it was on console.

www.7zhao.net

's connection wasn't strong enough to use netplay because of the high upload requirements. Oddly enough, this wasn't always the case, Dolphin used to purposefully limit how many times a game would poll the controller during a Movie/Netplay in order to simplify things. This was removed as part of a feature to fixSonic Heroes

copyright www.7zhao.net

The last thing we wanted to do was revive this amazing bug.

Thanks to various fixes since the old polling rate hacks were removed,Sonic Heroes works fine even the new Reduce Polling Rate enabled. Other games with polling rate issues, such as also work correctly with the revived reduce polling rate option. With this option enabled,Mario Party 5 drops from over 200 Kbps to only 100 Kbps . Do note that the Reduce Polling feature is optional . If you have good enough internet to play your favorite games with full polling, you can completely ignore it. That doesn't mean you don't get some benefits regardless, though. also reduced Dolphin Netplay's bandwidth requirements by reducing timebase checks to once per second and bundling controller packets when multiple controllers are used by a single instance of Dolphin. Together, these changes make a huge impact, especially for those of us who may not have the best internet options.

去找(www.7zhao.net欢迎您

, , , , and 5.0-8423 Fix and Improve Netplay Interface Issues by and

While the Qt version of Dolphin's Netplay GUI certainly looked a lot nicer and was much more customizable than its Wx sibling, there were more than a few things that had minor issues.

去找(www.7zhao.net欢迎您

Some were more minor than others, with one particularly annoying (though insignificant) problem being that Dolphin wasn't correctly restoring the saved IP address/Traversal ID when switching between the traversal server and direct connect connection modes. Dolphin now correctly restores the values for whichever mode you're using rather than carrying over the previous value. Another oversight was the fact that Dolphin was using panic handlers to communicate key connection error information to users if they were not able to connect. The only problem with this is that users can disable panichandlers and would then just be left with nothing but a generic error message.

本文来自去找www.7zhao.net

We also realized that in the port of the netplay over from Qt, the flash on notification feature was left behind. joined the party to restore this missing feature so that you no longer have to watch the netplay window directly to make sure your friends aren't waiting on you.

copyright www.7zhao.net

But by far the funniest of the GUI issues has to go with whatever happened to the MD5 Hash Verification feature. While it worked in Wx, the port over to Qt left it in absolute shambles. It was absolutely sure the hashes matched no matter what. It was so sure, it wouldn't even wait until everyone was finished checking their hash. And if they were different? It stuck to its guns. copyright www.7zhao.net

This about says it all...

With these issues quelled, every feature within the netplay interface should finally be fully functional.

本文来自去找www.7zhao.net

by

One of the more annoying steps when setting up a netplay session was figuring out what to do with saves. Whether it was syncing a whole folder of GameCube saves, transferring a memory card blob, or exporting a Wii save, users had to be extremely careful to make sure every player had the same saves available. If one player mistakingly booted the games between sessions, then syncing would have to be done yet again. In a beloved game likeTales of Symphonia where a playthrough may take place over the course of weeks or even months, this can lead to a lot of wasted time, frustrating desyncs, and unhappy players. 本文来自去找www.7zhao.net

officially puts an end to this struggle by synchronizing save data from within Dolphin. All users have to do is wait a few moments while the savedata is passed between players! 欢迎访问www.7zhao.net

Make sure you you turn on Write Save/SD data to keep your progress between sessions!

How does this all work? The base save that everyone uses is controlled by the host. It is their save that is used and transferred between all of the players. This does not overwrite the save on the client's end, though! Instead, Dolphin will keep it safe and sound in a temporary folder for the session. The host's save will automatically be transferred out of that temporary folder at the end of the session and overwrite the original save. If for some reason Dolphin crashes during a netplay session and it does not export, don't panic! The saves will be kept in that temporary folder until the next time you use netplay.

copyright www.7zhao.net

When using GCI Folders or Wii games, only saves matching the GameID of game launched in netplay will be loaded. If you're using a homebrew launcher to startup Brawl, the GameID may not match that of the savefile that Brawl is looking for, meaning the save synchronization will fail. There are also a small number of Wii games that block save exporting, which breaks Dolphin's ability to automatically synchronize them. Those titles will still need their saves manually synchronized until an automated solution is found.

copyright www.7zhao.net

by

Getting instances of Dolphin to synchronize can be difficult. While previous changes mentioned fixed some major issues with netplay, there's still one key thing that hasn't been mentioned. Sometimes you'll do everything right, synchronize save data, have the correct version of a game, setup the buffer and controllers correctly and yet... Dolphin still won't synchronize . You try flipping every setting in hopes that maybe something will fix it but in the end, you can't fix it. So, you download a new version of Dolphin, make it portable, setup netplay and boom, it works. This is because there are a lot of hidden settings that can absolutely affect netplay. 欢迎访问www.7zhao.net

learned this very quickly when playing on netplay with , whom had tons of insane settings that no reasonable user would have turned on. FPRF permanently enabled? AccurateNaNs always on?! While those settings may be fine when hunting for bugs, they cause headaches for anyone trying to play with him on netplay.

本文来自去找www.7zhao.net

In order to rectify this issue, and came up with a list of settings to synchronize on netplay that would allow even the most customized configurations to still synchronize on netplay.

copyright www.7zhao.net

Strict Settings Sync

In addiction to synchronizing more settings, also added a new option to the mix called Strict Settings Sync .

欢迎访问www.7zhao.net

You can tell this screenshot is from a test build because the build number displayed is from before it was merged!

In some cases games tend to require extra synchronization due to certain behaviors. In the case ofMario Party 8 some minigames use Store EFB Copies to Texture and RAM . Using different internal resolutions can cause desyncs after a while if a game reads from the screen. Strict Settings Sync synchronizes various graphical enhancements and settings in addition to everything else synchronized by default.

copyright www.7zhao.net

Use this feature with caution - you may be able to run a game at 8x Internal Resolution, but your buddy on a laptop using onboard graphics may not! In a case likeSuper Mario Sunshine, you may additionally need the same graphics backend to stay synchronized. Because not all operating systems have every graphics backend, Dolphin will not attempt to synchronize that. There's really not much that can be done in those very rare cases. Even though these new setting syncing features are incredibly helpful, still try to be aware of your settings to avoid the remaining potential pitfalls. 去找(www.7zhao.net欢迎您

by

Sometimes an issue is actually really simple and silly - the problem is actually tracking it down. Once he knew what was wrong, was able to fix it in moments by removing a single flawed condition. Stumbling upon the issue took a tremendous amount of luck and patience. If not for the huge netplay features hitting all at once necessitating a ton of testing, it's very likely this bug would still exist in the emulator. copyright www.7zhao.net

and were testing quite a bit with the new input polling and save synchronization features. These features allowed for smoother gameplay on and less setup. With the saves synced, they could just join and play without issues and sync up. But, in longer sessions, they'd find that their games would quickly start desyncing usually within the first 30 seconds . Considering that they were both using relatively fresh Dolphin folders and carefully took care of their settings, this was bewildering. Worse yet, the problem would come and go at seemingly random. Neither of them could reproduce the issue with local netplay instances, it only occured when both of them were playing together.

欢迎访问www.7zhao.net

They tried more carefully synchronizing their builds, wiping settings, adding the real GameCube fonts, DSP-LLE files, and even trying other games! Seemingly randomly, they would desync. One day turned to two and two turned to three before they made any real headway. While simply throwing stuff at the wall they booted into The GameCube Main Menu during a netplay session. When checking memcards and flicking around the various options, a setting caught 's eye. He typed over the netplay chat, "Did you see that?" and got nothing but bepuzzlement in response. They flicked back to the audio tab and said that his said MONO for audio. 's instead said STEREO.

www.7zhao.net

Techjar: "So, why exactly is your SRAM set to MONO?"

本文来自去找www.7zhao.net

JMC47: "I dunno." 本文来自去找www.7zhao.net

The odd thing is that this desync wouldn't always happen. Now that they knew what they were looking for, the two of them narrowed down the behavior. On first boot of a new netplay session, the SRAM was properly synced. If you stayed in the netplay session and booted another game, the original SRAM on each player would be used. Because literally just fixed the ability to survive a netplay game without crashing, this bug went unnoticed for years. But even then, without all of the new additions, it'd be unlikely for two players to even notice this behavior at all. It turns out on game stop in netplay, it was clearing the synced SRAM, causing each client to fallback to their own. 内容来自www.7zhao.net

...but there's one more mystery in all of this. Why was 's SRAM set to MONO? Without this key detail, their SRAM settings would have been identical and this bug may not have been found. Even was puzzled as these builds were mostly fresh and only used for netplay testing. It wasn't until days later that he remembered what was wrong. When having difficulties creating a new memory card for use in netplay (before save syncing existed,) he was having problems getting the game to save. Before the was fixed, he gave up on this proposition. ...But one of the settings he changed when trying to trick the game into saving was STEREO to MONO in the main menu of the game he was setting up! Because the SRAM is separate from memory cards, that particular setting did get saved unbeknownst to .

欢迎访问www.7zhao.net

Sometimes it takes the stars to align to fix a simple bug in logic. 去找(www.7zhao.net欢迎您

by

Branch Following is an optimization added in5.0-2178 and greatly improved performance in popular games such as andXenoblade Chronicles. This feature of Dolphin's JIT allows it to optimize larger blocks of code at once. Larger blocks means that our optimizer has more knowledge about what the code does, which allows us to shortcut many things that we would have to do with small blocks.

去找(www.7zhao.net欢迎您

These massive performance improvements aren't exactly typical, but overall Branch Following is a performance increase of some amount in most games. For Nintendo 64 Virtual Console games, this actually holds true - their maximum performance is increased with Branch Following enabled but it comes at a cost. While if you tested a single spot inMario Party 2 with it enabled, you'd see an increase in performance, problems show up as soon as you start to do just about anything. Any action, from navigating a menu, selecting a character, hitting the dice block, or simply loading a mini-game, Dolphin would stutter harder thanMetroid Prime 3 before ubershaders!

欢迎访问www.7zhao.net

While this can't be visualized well with raw performance, if you look at the framerate when navigating the menus with Branch Following enabled and disabled, you can see a stark contrast between the two experiences.

本文来自去找www.7zhao.net

If you can't see Branch Following Disabled, try hiding Branch Following Enabled by clicking it in the legend.

So why exactly is Branch Following causing all of these gigantic stutters? In order to truly understand this, we have to look at the emulator. Not just Dolphin, mind you, but Nintendo's N64 emulator poweringMario Party 2 on the Wii. JITing a JIT isn't exactly the most elegant of situations for Dolphin, the JIT within these emulators were creating incredibly big blocks of code. Branch Following now allowed Dolphin's JIT to try and inline the branches within them which resulted in Dolphin compiling gigantic blocks. This isn't bad on its own, but after a look at the logs the problem becomes very apparent.

www.7zhao.net

45:29:685 Core/PowerPC/Jit64/Jit.cpp:749 E[PowerPC]: Compiling JIT block 0x8006b690, 350 instructions
45:29:692 Core/PowerPC/Jit64/Jit.cpp:749 E[PowerPC]: Compiling JIT block 0x8006b6c0, 338 instructions
45:29:692 Core/PowerPC/Jit64/Jit.cpp:749 E[PowerPC]: Compiling JIT block 0x8006b6ec, 327 instructions
45:29:693 Core/PowerPC/Jit64/Jit.cpp:749 E[PowerPC]: Compiling JIT block 0x8006b71c, 315 instructions
45:29:693 Core/PowerPC/Jit64/Jit.cpp:749 E[PowerPC]: Compiling JIT block 0x8006b744, 305 instructions 
copyright www.7zhao.net

The rest of the log keeps going down until Dolphin compiles a ~19 instruction block. But, we can already see what's wrong with this little slice. Dolphin compiles a JIT block of 350 instructions using branch following and then only executes 10 instructions of it before hitting a jump and compiling a block of 338 instructions. Within one block Dolphin can take the wrong branch over 30 times , bloating the JIT cache to unreasonable levels.Mario Party 2 and friends were managing to overflow the cache multiple times per minute while generating tons of unnecessary code that never gets executed. All because Dolphin's JIT was being a little too adventurous with its optimizations. 去找(www.7zhao.net欢迎您

As of5.0-8377 Branch Following has been completely disabled for N64 Virtual Console games, restoring their performance to that of before when branch following was added in5.0-2178.

去找(www.7zhao.net欢迎您

by

Joystick Re-centering makes a lot of games more playable on a touchscreen. Anything requiring precision movement or platforming is nearly impossible without re-centering enabled. Alongside some relief, there was also some disappointment among users who preferred the old method for the games they played. There were some valid concerns - some people preferred static placement for racing games and RPGs to making driving and menu navigation easier. While touchscreen games can carefully curate their control scheme to their needs, Dolphin can play thousands of different games. If we hope to make our touchscreen controls usable across many of those, there needs to be flexibility.

copyright www.7zhao.net

To truly explain why, here's a demonstration using homebrew to show how the controls translate to a controller.

本文来自去找www.7zhao.net

Two modes that can be changed while the game is playing!

Mode 1: Re-centering Disabled

This is the original way that Dolphin handled joystick input on touchscreens. The virtual joystick is planted in a spot, and if you touch in its range, it'll tilt toward the center of the touch. So if you touch at the extremes, you can immediately be at the limits of the joystick range. This makes navigating menus and making quick movements much easier to do while sacrificing some precision for smaller movements. If you're careful and make sure to plant your thumb right in the middle of the range every time, it's absolutely possible to perform precise movements. But when faced with complex platforming challenges or other timed challenges that require precise movement, this behavior is more likely to cause you to fail than anything else.

内容来自www.7zhao.net

Mode 2: Re-centering Enabled

This was the only option as of5.0-6376 and originally replaced re-centering disabled. This mode was a direct response to how difficult it was to control platformers and action games. Without this feature, it took three hours to pass a simple platforming challenge in that would take less than a minute on a conventional controller. The problem was that whenever he touched the joystick, he would start moving in a direction and then have to adjust his thumb to get to the correct angle before accidentally jumping off a small platform. Touching it directly in the center to setup a precision jump without wasting too much time was extremely difficult to do once, but with there being several consecutive jumps, it bordered on maddening.

本文来自去找www.7zhao.net

The bane of touchscreen users everywhere.

Everything about this puzzle is simpler when using Joystick Re-centering. Instead of being worried on exactly where you're going to touch the screen, you can instead focus on just moving around and making the jumps. As long as your thumb is close to the joystick range when you touch, it'll re-center on your thumb so that you can then accurately choose where you want to move. After getting used to the feature, all of the platforming challenges in can be completed without accidentally lurching off of small platforms at the slightest of mistakes. Is it as easy as just using a physical controller? No, it doesn't quite replace the tactile feedback of using a controller. But, if you're looking to play a platformer on your phone without lugging around a controller, this feature will make things much easier.

www.7zhao.net

If you're not a fan of touchscreens, fixed axis input detection issues in5.0-8486 that caused Xbox One and other controllers to be impossible to configure. 本文来自去找www.7zhao.net

by

The Vulkan backend has been broken on most phones since its addition to Dolphin. And it's not because of anything in the Vulkan backend itself - it's just driver bugs. While was hoping for a driver update to resolve the issue, it appears that won't be happening any time soon. So he dug into the issue himself and found what Dolphin was doing to put the drivers into such a gnarly state. Eventually he found out that 32-bit floating point depth clears were broken on Adreno. This is rather problematic, as Dolphin needs every bit of that precision to accurately emulate some GameCube/Wii games.

欢迎访问www.7zhao.net

But most users on phones are much more concerned about performance than flickering and broken edge-cases, so bit the bullet and made a less accurate path that uses 24-bit depth throughout rendering before resolving it to 32-bit depth at the end. While this causes a rather damaging loss in accuracy, it does allow Vulkan to render better than it once did on some Adreno devices. 欢迎访问www.7zhao.net

Without clears, the screen would quickly become a sea of black.
Despite minor depth issues, some games are now playable!

While this will work for some games, Vulkan on Adreno will have various problems thanks to using 24-bit depth. Our hope that this will tide over users looking to take advantage of their phone's Vulkan support while the driver developers work on various upgrades for their driver. Once 32-bit depth clears are fixed in the Adreno driver, this hack will be removed. 去找(www.7zhao.net欢迎您

by

One of the new features of Android Oreo T.V. Interface is homescreen channels for apps. This lets you have a shortcut to your favorite Hulu/Netflix/Amazon/YouTube channel without having to boot into the main application. But, it doesn't have to just be used for channels like that, any application can use it. has taken advantage of the Homescreen Channels feature in order to give you the ability to directly boot your favorite games without even having to navigate through the Dolphin app!

本文来自去找www.7zhao.net

You can see your favorite games directly in Android!
Highlight a particular game for more information.

With this feature, launching your favorite games is a snap. It also features the ability to display your games with the game banner, a temporary banner for Wii titles until a save is made, or a screenshot taken while playing the game.

内容来自www.7zhao.net

by

This is one of those bugs that just slaps you in the face when things are starting to work. Dolphin on Android has seen a lot of features and improvements this month, there always seems to be more problems just over the horizon.

去找(www.7zhao.net欢迎您

After so much work on getting touchscreen controls working well, a slew of reports hit claiming that configuring emulated Wii Remotes to controllers didn't work at all in Android. This was particularly problematic on Android T.V. devices that didn't really have any other option for using emulated Wii Remotes. investigated what was going on and found out that the bug was essentially... very embarrassing.

www.7zhao.net

BEFORE                                             AFTER
GCPAD_1("gcpad", 0),                          >    GCPAD_1("gcpad", 0),
GCPAD_2("gcpad", 1),                          >    GCPAD_2("gcpad", 1),
GCPAD_3("gcpad", 2),                          >    GCPAD_3("gcpad", 2),
GCPAD_4("gcpad", 3),                          >    GCPAD_4("gcpad", 3),
WIIMOTE_1("wiimote", 1),                      >    WIIMOTE_1("wiimote", 4),
WIIMOTE_2("wiimote", 2),                      >    WIIMOTE_2("wiimote", 5),
WIIMOTE_3("wiimote", 3),                      >    WIIMOTE_3("wiimote", 6),
WIIMOTE_4("wiimote", 4),                      >    WIIMOTE_4("wiimote", 7),
WIIMOTE_EXTENSION_1("wiimote_extension", 1),  >    WIIMOTE_EXTENSION_1("wiimote_extension", 4),
WIIMOTE_EXTENSION_2("wiimote_extension", 2),  >    WIIMOTE_EXTENSION_2("wiimote_extension", 5),
WIIMOTE_EXTENSION_3("wiimote_extension", 3),  >    WIIMOTE_EXTENSION_3("wiimote_extension", 6),
WIIMOTE_EXTENSION_4("wiimote_extension", 4);  >    WIIMOTE_EXTENSION_4("wiimote_extension", 7), 
内容来自www.7zhao.net

If you look at the controller IDs above, you'll see that GCPAD_2 through GCPAD_4 overlapped with WIIMOTE _1 through WIIMOTE_3 . WIIMOTE 4 's controller ID was actually being assinged to WIIMOTE_1 . Needless to say, the issue was very quickly rectified once it was identified. Another offset issue in the code that was less damaging was also addressed in5.0-8512 which was causing the emulated controller selection to be offset by one slot.

内容来自www.7zhao.net

These hotfixes should combine to make Emulated Wii Remotes configurable to controllers on Android while the larger configuration rewrite goes through the review process. The rewrite should make it much harder for things to break like this in the future.

www.7zhao.net

by

Dolphin has three options for Wii Remote Inputs, two of which that require physical Wii Remotes. The third, Emulated Wii Remotes, excels mostly for games that don't do all that much with motion controls. A game likeSuper Mario Galaxy can be completed pretty easily with just mapping "shakes" to a button and using your mouse (or a joystick) for controlling the Wii Remote pointer. On the other hand, games likeRed Steel and can be more difficult due to their insistence on using more precise motions. Others, likeBoom Blox could be completely impossible because it actually takes the strength of the shake for your throw. 本文来自去找www.7zhao.net

Good luck getting too far with Emulated Wii Remotes prior to 5.0-8443.

Thanks to Nintendo still using Wii Remotes as one of the primary input methods on the Wii U, real controllers are still fairly plentiful, but that doesn't excuse some of the flaws within Dolphin's emulated Wii Remotes. returns to the project with a slew of improvements to Dolphin's Emulated Wii Remote code to make doing various motion inputs much easier! 去找(www.7zhao.net欢迎您

Dynamic Motion Strength

Instead of shaking or swinging at a constant strength, you can now configure Dolphin to ramp up the strength of the motion depending on how long you hold the button. This can be useful in games that use shaking for recharging likeNo More Heroes or throwing the baseball at maximum speeds inWii Sports.

欢迎访问www.7zhao.net

Configurable Motion Intensity

Sometimes, simply having shaking get stronger isn't quite enough.Boom Blox has three specific shot types tuned for ranges of shaking. Simply trying to guess how long to hold down a button to get the strength required wouldn't make the game very fun. For situations like these, has added the ability to have three completely separate shake strength options for each axis resulting in up to nine different buttons for various shake directions and strengths.

www.7zhao.net

Boom Blox's INI comes with the strengths tuned to each throw type.

On top of all of that, made the strength of each throw customizable for games that use different ranges for various actions. While this may seem daunting, Dolphin's GameINI system should simplify things by setting the strength of each throw to reasonable values for specific games. For now, only the twoBoom Blox games have customized strength values, but the system is in place so that strength values can be added to more games as they are researched.

本文来自去找www.7zhao.net

Improved Swing Reliability

Some games require more than just waggling in order to proceed. The Wii Remote can also report something called swings . The problem with Dolphin's swinging detection is twofold: it doesn't make what games are looking for with swings clear and it had buggy detection. While games can be picky about their detection, some issues with swings were fixed, including one that caused Dolphin to only report a swing for the first frame of a swing input. previously wouldn't detect your swings when lifting rubble off of others.

www.7zhao.net

The lifting motion here requires configuring swinging up and moving back. If you think about how the swinging motion looks, this makes sense.

This also allows games likeNo More Heroes,Red Steel, andSpectrobe Origins to be more easily completed on emulated Wii Remotes and greatly increases the reliability of swing based actions in all games. Just remember that a swing motion on console is more than just the straight motion Dolphin calls 'swing' and because of that many games need to see two motions to be properly detected! 本文来自去找www.7zhao.net

Increase Default IR Bounds

This was more of a usability problem than an actual bug in the emulator. The default IR limits didn't let you reach the corners of the screen in some games and software. This is because games could calibrate the IR however they choosed, meaning the bounds varied from game to game. Dolphin's defaults just weren't good enough for some titles. Advanced users could work around this through the advanced control configuration by right clicking a button, but, asking that of everyone was a bit unreasonable. 本文来自去找www.7zhao.net

This is actually as close as you can get to the upper right corner of the screen in the System Menu with the old defaults.
The new limits allow you to get to the corner of the screen and beyond!

happily changed the defaults to something more sensible while improving other aspects of emulated Wii Remotes. For games that seem too sensitive with the new defaults, the range can still be manually adjusted by right clicking the configuration buttons and adjusting the slider down. www.7zhao.net

Profile Switching

Even with all of the added customization, some games require even more to be playable on a controller. Games likeWii Party use the Wii Remote in a variety of ways that make it difficult to hook up to a single configuration. In order to make things easier for minigame collections, has made Dolphin's Controller Profile support more robust. The newest feature for this is that you can now have game specific controller profiles and swap between them with hotkeys. This makes it possible to play through Wii minigame collections without having to start and stop to switch controller profiles at every minigame. And while less useful, this update also adds the ability to switch between all profiles on any game. 欢迎访问www.7zhao.net

by

This is one of those options that... it's hard to explain why it's still around outside of ambivalence. Outside of a single WiiWare title, the setting hadn't been enabled in any games by default. In the Skip DCBZ Hack had lain dormant, supposedly a benefit to be enabled for this game. 内容来自www.7zhao.net

With Skip DCBZ Hack on, the game doesn't feel too well.
With the hack removed, the game still loads and plays without bugs!

In the case of , the Skip DCBZ Hack was once needed to work around other inefficiencies in Dolphin in order to make the game boot past the menu. At some point this behavior changed, likely around the time ofDynamic BATs. For some reason, upon its merger many games stopped requiring the Skip DCBZ Hack for unknown reasons, includingWe Love Golf! The stranger part of this is that none of these games actually required MMU emulation whatsoever and why they started working was never truly ascertained. 欢迎访问www.7zhao.net

This feels oddly familiar... 内容来自www.7zhao.net

Regardless of how we got here, the Skip DCBZ Hack is no longer needed and has actually been causing trouble. What actually spurned investigation into was actually the growing issue of users accidentally enabling the Skip DCBZ Hack in older builds and forks where it still resides within the Game Properties page despite its removal in master many months ago. This would lead to wild goose chases trying to figure out why a game that works for everyone else is broken for this user. And when looking through their settings at a glance, everything would look fine! www.7zhao.net

The reason that Skip DCBZ Hack could be so damaging is that games often use this instruction to zero out memory before switching tasks. Skipping it will often cause issues with video playback, loading new levels, or even prevent the game from functioning whatsoever. In the case of , it caused severe graphical issues with most 2D elements.

本文来自去找www.7zhao.net

In order to make sure that the Skip DCBZ Hack could do no more harm, testers verified that it no longer benefited any games. This meant testing every game that had the Skip DCBZ Hack enabled at some point over its history as well as investigating old forum posts and recommendations. Despite this, no good results could be found and the feature was axed. It must be noted that this does not affect a separate DCBZ related hack that bypasses the anti-emulation code inDisney's Cars 2 andDisney Infinity. Because that option was never a part of the GUI, there is little to no risk of it being mistakingly turned on in other builds. copyright www.7zhao.net

Website Improvements

You may have noticed that Dolphin's blog has seen some improvements over the course of July. One of those changes was probably noticable in the this month when we looked at some of the different challenges that the GameCube and Wii hardware present to Dolphin. Featured within it was an interactive chart showing the performance of various GameCube and Wii games. Dolphin's blog now has support for charts which allows for easily creating and displaying interactive data. It's so easy a blog writer can use it... after some instruction. There were also some minor formatting fixes to the blog navigation page.

去找(www.7zhao.net欢迎您

Other parts of the website also saw some major improvements over the month. The download page should be much snappier to use in recent days as a was pushed through by to aid in the construction of the list of downloads. Withdolphin-emu.org hosting every build of Dolphin's master branch all the way back to3.0-749 the old code had become a bit too slow to handle the many thousands of builds. 欢迎访问www.7zhao.net

On the translation side of things, the Farsi and Croatian translations were removed because they were lagging behind, but, Danish, Galician, and Norwegian (Bokmål) have been added in the meantime. Behind the scenes, Dolphin's website has been upgraded from Django 1.7 and Python 2.6 to Django 2.0 and Python 3.6. Overall the improvements should add up to a nicer experience when navigating Dolphin's website and help the blog staff continue to bring you high quality articles moving forward. www.7zhao.net

Last Month's Contributors...

Special thanks to that incremented Dolphin from5.0-8309 through to5.0-8512!

欢迎访问www.7zhao.net

去找(www.7zhao.net欢迎您


本文原文地址:https://dolphin-emu.org/blog/2018/08/01/dolphin-progress-report-july-2018/

以上为Dolphin Progress Report: July 2018文章的全部内容,若您也有好的文章,欢迎与我们分享! 去找(www.7zhao.net欢迎您

Copyright ©2008-2017去找网版权所有   皖ICP备12002049号-2 皖公网安备 34088102000435号   关于我们|联系我们| 免责声明|友情链接|网站地图|手机版