Merge pull request #671 from Abextm/camera-hacks
Add option to relax the camera's upper pitch limit
This commit is contained in:
@@ -286,4 +286,6 @@ public interface Client extends GameEngine
|
|||||||
boolean isClanMember(String name);
|
boolean isClanMember(String name);
|
||||||
|
|
||||||
Preferences getPreferences();
|
Preferences getPreferences();
|
||||||
|
|
||||||
|
void setCameraPitchRelaxerEnabled(boolean enabled);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -54,4 +54,14 @@ public interface ZoomConfig extends Config
|
|||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ConfigItem(
|
||||||
|
keyName = "relaxCameraPitch",
|
||||||
|
name = "Vertical camera",
|
||||||
|
description = "Relax the camera's upper pitch limit"
|
||||||
|
)
|
||||||
|
default boolean relaxCameraPitch()
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -30,6 +30,7 @@ import com.google.inject.Inject;
|
|||||||
import com.google.inject.Provides;
|
import com.google.inject.Provides;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import net.runelite.api.Client;
|
import net.runelite.api.Client;
|
||||||
|
import net.runelite.api.events.ConfigChanged;
|
||||||
import net.runelite.api.events.ScriptEvent;
|
import net.runelite.api.events.ScriptEvent;
|
||||||
import net.runelite.client.config.ConfigManager;
|
import net.runelite.client.config.ConfigManager;
|
||||||
import net.runelite.client.plugins.Plugin;
|
import net.runelite.client.plugins.Plugin;
|
||||||
@@ -107,4 +108,22 @@ public class ZoomPlugin extends Plugin
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void startUp()
|
||||||
|
{
|
||||||
|
client.setCameraPitchRelaxerEnabled(zoomConfig.relaxCameraPitch());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void shutDown()
|
||||||
|
{
|
||||||
|
client.setCameraPitchRelaxerEnabled(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Subscribe
|
||||||
|
public void onConfigChanged(ConfigChanged ev)
|
||||||
|
{
|
||||||
|
client.setCameraPitchRelaxerEnabled(zoomConfig.relaxCameraPitch());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,109 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2018 Abex
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice, this
|
||||||
|
* list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
|
||||||
|
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||||
|
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
package net.runelite.mixins;
|
||||||
|
|
||||||
|
import net.runelite.api.mixins.FieldHook;
|
||||||
|
import net.runelite.api.mixins.Inject;
|
||||||
|
import net.runelite.api.mixins.Mixin;
|
||||||
|
import net.runelite.api.mixins.Shadow;
|
||||||
|
import net.runelite.rs.api.RSClient;
|
||||||
|
|
||||||
|
@Mixin(RSClient.class)
|
||||||
|
public abstract class CameraMixin implements RSClient
|
||||||
|
{
|
||||||
|
private static final int STANDARD_PITCH_MAX = 383;
|
||||||
|
private static final int NEW_PITCH_MAX = 512;
|
||||||
|
|
||||||
|
@Shadow("clientInstance")
|
||||||
|
static RSClient client;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
static boolean pitchRelaxEnabled = false;
|
||||||
|
|
||||||
|
@Shadow("visibilityMaps")
|
||||||
|
static boolean[][][][] visibilityMaps;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
static int lastPitch = 128;
|
||||||
|
|
||||||
|
static
|
||||||
|
{
|
||||||
|
// The first index is pitch. In the default client it is 9, here it is 13 because we increase the pitch limit
|
||||||
|
visibilityMaps = new boolean[13][35][53][53];
|
||||||
|
for (boolean[][][] z : visibilityMaps)
|
||||||
|
{
|
||||||
|
for (boolean[][] y : z)
|
||||||
|
{
|
||||||
|
for (boolean[] x : y)
|
||||||
|
{
|
||||||
|
for (int i = 0; i < x.length; i++)
|
||||||
|
{
|
||||||
|
x[i] = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@FieldHook("cameraPitch")
|
||||||
|
@Inject
|
||||||
|
static void onCameraPitchChanged(int idx)
|
||||||
|
{
|
||||||
|
int newPitch = client.getCameraPitch();
|
||||||
|
int pitch = newPitch;
|
||||||
|
if (pitchRelaxEnabled)
|
||||||
|
{
|
||||||
|
// This works because the vanilla camera movement code only moves %2
|
||||||
|
if (lastPitch > STANDARD_PITCH_MAX && newPitch == STANDARD_PITCH_MAX)
|
||||||
|
{
|
||||||
|
pitch = lastPitch;
|
||||||
|
if (pitch > NEW_PITCH_MAX)
|
||||||
|
{
|
||||||
|
pitch = NEW_PITCH_MAX;
|
||||||
|
}
|
||||||
|
client.setCameraPitch(pitch);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
lastPitch = pitch;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
public void setCameraPitchRelaxerEnabled(boolean enabled)
|
||||||
|
{
|
||||||
|
if (pitchRelaxEnabled == enabled)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
pitchRelaxEnabled = enabled;
|
||||||
|
if (!enabled)
|
||||||
|
{
|
||||||
|
int pitch = client.getCameraPitch();
|
||||||
|
if (pitch > STANDARD_PITCH_MAX)
|
||||||
|
{
|
||||||
|
client.setCameraPitch(STANDARD_PITCH_MAX);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -472,4 +472,7 @@ public interface RSClient extends RSGameEngine, Client
|
|||||||
@Import("preferences")
|
@Import("preferences")
|
||||||
@Override
|
@Override
|
||||||
RSPreferences getPreferences();
|
RSPreferences getPreferences();
|
||||||
|
|
||||||
|
@Import("cameraPitch")
|
||||||
|
void setCameraPitch(int pitch);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user