Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Iris Shaders breaking Distant Horizon Fog #2571

Open
Borous opened this issue Dec 18, 2024 · 1 comment
Open

Iris Shaders breaking Distant Horizon Fog #2571

Borous opened this issue Dec 18, 2024 · 1 comment

Comments

@Borous
Copy link

Borous commented Dec 18, 2024

What happened?

For a good while now Distant Horizons has had an issue wherin if loaded with Iris shaders, without actively using shaders, the fog of DH breaks. Although it was initially believed to be an issue with DH itself, the devs thereof have seemingly concluded that the issue appears to be caused by Iris itself.

This issue persists in both stable and experimental builds of DH when paired with any compatible Iris vers

Attached below are two screenshots that indicate what it looks like when the specifically DH unique fog isnt working.

Screenshots

Image
Image

Log output

No response

Minecraft Version

1.21.1

Iris Version

iris-1.8.1+mc1.21.1.jar

Operating System

Windows 10

What is your GPU?

AMD Radeon RX 7800 XT

Additional context

No response

@Steveplays28
Copy link

Steveplays28 commented Dec 30, 2024

I think shouldOverride should be set to false before the return statement in DHCompatInternal:

if (pipeline.getDHTerrainShader().isEmpty() && pipeline.getDHWaterShader().isEmpty()) {
Iris.logger.warn("No DH shader found in this pack.");
incompatible = true;
return;
}

shouldOverride determines if DH's fog is enabled or disabled in LodRenderEvents:

DhApi.Delayed.configs.graphics().fog().drawMode().setValue(getInstance().shouldOverride ? EDhApiFogDrawMode.FOG_DISABLED : EDhApiFogDrawMode.FOG_ENABLED);

I haven't tested this so it might be wrong.

EDIT: shouldOverride does get set to false when clear() is called. Maybe this isn't the correct fix.

EDIT 2: There should be another check for Iris.isPackInUseQuick() to determine if the fog is drawn, similar to the line above the fog override.

EDIT 3: This section shouldn't also touch the fog draw mode, with the above changes:

// config overrides
if (instance.shouldOverride) {
DhApi.Delayed.configs.graphics().ambientOcclusion().enabled().setValue(false);
DhApi.Delayed.configs.graphics().fog().drawMode().setValue(EDhApiFogDrawMode.FOG_DISABLED);
if (event.value.renderPass == EDhApiRenderPass.OPAQUE_AND_TRANSPARENT) {
Iris.logger.error("Unexpected; somehow the Opaque + Translucent pass ran with shaders on.");
}
} else {
DhApi.Delayed.configs.graphics().ambientOcclusion().enabled().clearValue();
DhApi.Delayed.configs.graphics().fog().drawMode().clearValue();
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants