aboutsummaryrefslogtreecommitdiff
path: root/src/main/kotlin/events/EntityRenderTintEvent.kt
blob: 29b888bacfc09d26034cacdb2a5c52ce8e29f8bc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package moe.nea.firmament.events

import net.minecraft.client.render.GameRenderer
import net.minecraft.client.render.OverlayTexture
import net.minecraft.client.render.entity.state.EntityRenderState
import net.minecraft.entity.Entity
import net.minecraft.entity.LivingEntity
import moe.nea.firmament.util.render.TintedOverlayTexture

/**
 * Change the tint color of a [LivingEntity]
 */
class EntityRenderTintEvent(
	val entity: Entity,
	val renderState: HasTintRenderState
) : FirmamentEvent.Cancellable() {
	init {
		if (entity !is LivingEntity) {
			cancel()
		}
	}

	companion object : FirmamentEventBus<EntityRenderTintEvent>() {
		/**
		 * Static variable containing an override for [GameRenderer.getOverlayTexture]. Should be only set briefly.
		 *
		 * This variable only affects render layers that naturally make use of the overlay texture, have proper overlay UVs set (`overlay u != 0`), and have a shader that makes use of the overlay (does not have the `NO_OVERLAY` flag set in its json definition).
		 *
		 * Currently supported layers: [net.minecraft.client.render.entity.equipment.EquipmentRenderer], [net.minecraft.client.render.entity.model.PlayerEntityModel], as well as some others naturally.
		 *
		 * @see moe.nea.firmament.mixins.render.entitytints.ReplaceOverlayTexture
		 * @see TintedOverlayTexture
		 */
		@JvmField
		var overlayOverride: OverlayTexture? = null
	}

	@Suppress("PropertyName", "FunctionName")
	interface HasTintRenderState {
		/**
		 * Multiplicative tint applied before the overlay.
		 */
		var tint_firmament: Int

		/**
		 * Must be set for [tint_firmament] to have any effect.
		 */
		var hasTintOverride_firmament: Boolean

		// TODO: allow for more specific selection of which layers get tinted
		/**
		 * Specify a [TintedOverlayTexture] to be used. This does not apply to render layers not using the overlay texture.
		 * @see overlayOverride
		 */
		var overlayTexture_firmament: TintedOverlayTexture?
		fun reset_firmament()

		companion object {
			@JvmStatic
			fun cast(state: EntityRenderState): HasTintRenderState {
				return state as HasTintRenderState
			}
		}
	}

}