com.talosvfx.talos.runtime.ParticleEffectDescriptor Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of talos-libgdx Show documentation
Show all versions of talos-libgdx Show documentation
Talos runtime for use in LibGDX projects
The newest version!
/*******************************************************************************
* Copyright 2019 See AUTHORS file.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
******************************************************************************/
package com.talosvfx.talos.runtime;
import com.badlogic.gdx.files.FileHandle;
import com.badlogic.gdx.graphics.g2d.TextureAtlas;
import com.badlogic.gdx.utils.Array;
import com.badlogic.gdx.utils.GdxRuntimeException;
import com.badlogic.gdx.utils.IntMap;
import com.badlogic.gdx.utils.Json;
import com.talosvfx.talos.runtime.assets.AssetProvider;
import com.talosvfx.talos.runtime.assets.AtlasAssetProvider;
import com.talosvfx.talos.runtime.modules.EmitterModule;
import com.talosvfx.talos.runtime.modules.AbstractModule;
import com.talosvfx.talos.runtime.modules.ParticleModule;
import com.talosvfx.talos.runtime.serialization.ConnectionData;
import com.talosvfx.talos.runtime.serialization.ExportData;
public class ParticleEffectDescriptor {
/**
* graph per each emitter
*/
public Array emitterModuleGraphs = new Array<>();
private AssetProvider assetProvider;
private ParticleEffectInstance processsingEffectReference;
public ParticleEffectDescriptor () {
}
public ParticleEffectDescriptor(FileHandle fileHandle, TextureAtlas atlas) {
setAssetProvider(new AtlasAssetProvider(atlas));
load(fileHandle);
}
public void addEmitter (ParticleEmitterDescriptor emitter) {
emitterModuleGraphs.add(emitter);
}
public void removeEmitter (ParticleEmitterDescriptor emitter) {
emitterModuleGraphs.removeValue(emitter, true);
}
public ParticleEmitterDescriptor createEmitterDescriptor () {
return new ParticleEmitterDescriptor(this);
}
public void load(FileHandle fileHandle) {
Json json = new Json();
ParticleEmitterDescriptor.registerModules();
for (Class clazz: ParticleEmitterDescriptor.registeredModules) {
json.addClassTag(clazz.getSimpleName(), clazz);
}
final ExportData exportData = json.fromJson(ExportData.class, fileHandle.readString());
for (ExportData.EmitterExportData emitter : exportData.emitters) {
ParticleEmitterDescriptor emitterDescriptor = new ParticleEmitterDescriptor(this);
IntMap idMap = new IntMap<>();
for (AbstractModule module: emitter.modules) {
module.setModuleGraph(emitterDescriptor);
if (module instanceof ParticleModule) {
emitterDescriptor.particleModule = (ParticleModule)module;
}
if (module instanceof EmitterModule) {
emitterDescriptor.emitterModule = (EmitterModule)module;
}
idMap.put(module.getIndex(), module);
emitterDescriptor.modules.add(module); // I cannot understand how this was working before. This is needed so that it can later reset requesters.
}
for (ConnectionData connection : emitter.connections) {
final int moduleFromId = connection.moduleFrom;
final int moduleToId = connection.moduleTo;
final int slotFrom = connection.slotFrom;
final int slotTo = connection.slotTo;
AbstractModule moduleFrom = idMap.get(moduleFromId);
AbstractModule moduleTo = idMap.get(moduleToId);
if (moduleFrom == null) {
throw new GdxRuntimeException("No module from found for id: " + moduleFromId);
}
if (moduleTo == null) {
throw new GdxRuntimeException("No module to found for id: " + moduleToId);
}
emitterDescriptor.connectNode(moduleFrom, moduleTo, slotFrom, slotTo);
}
emitterModuleGraphs.add(emitterDescriptor);
}
}
public ParticleEffectInstance createEffectInstance() {
ParticleEffectInstance particleEffectInstance = new ParticleEffectInstance(this);
setEffectReference(particleEffectInstance);
for(ParticleEmitterDescriptor emitterDescriptor: emitterModuleGraphs) {
particleEffectInstance.addEmitter(emitterDescriptor);
}
particleEffectInstance.sortEmitters();
// create default scope
particleEffectInstance.setScope(new ScopePayload());
return particleEffectInstance;
}
public boolean isContinuous() {
for(ParticleEmitterDescriptor emitterDescriptor: emitterModuleGraphs) {
if(emitterDescriptor.getEmitterModule() == null || emitterDescriptor.getParticleModule() == null) {
return false;
}
if(getInstanceReference() == null) {
return false;
}
if(emitterDescriptor.isContinuous()) {
return true;
}
}
return false;
}
public AssetProvider getAssetProvider () {
return assetProvider;
}
public void setAssetProvider (AssetProvider assetProvider) {
this.assetProvider = assetProvider;
}
public void setEffectReference(ParticleEffectInstance particleEffectInstance) {
processsingEffectReference = particleEffectInstance;
}
public ParticleEffectInstance getInstanceReference() {
return processsingEffectReference;
}
}