Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/FastCrossSectionLineFactory.java @ 2764:f8a1a8af338e
Issue 667.
Added data to jfreechart data source in waterlevel exporter.
flys-artifacts/trunk@4501 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Raimund Renkert <raimund.renkert@intevation.de> |
---|---|
date | Thu, 24 May 2012 10:45:12 +0000 |
parents | d626ae185305 |
children |
line wrap: on
line source
package de.intevation.flys.artifacts.model; import de.intevation.flys.artifacts.cache.CacheFactory; import de.intevation.flys.model.CrossSection; import de.intevation.flys.model.FastCrossSectionLine; import net.sf.ehcache.Cache; import net.sf.ehcache.Element; import java.util.List; import org.apache.log4j.Logger; public class FastCrossSectionLineFactory { private static Logger log = Logger.getLogger(FastCrossSectionLineFactory.class); public static final String CACHE_NAME = "fast-cross-section-lines"; private FastCrossSectionLineFactory() { } public static FastCrossSectionLine getCrossSectionLine( CrossSection cs, double km ) { Cache cache = CacheFactory.getCache(CACHE_NAME); boolean debug = log.isDebugEnabled(); if (cache == null) { if (debug) { log.debug("No cross section chunk cache configured."); } List<FastCrossSectionLine> lines = cs.getFastLines(km, km); return lines.isEmpty() ? null : lines.get(0); } String cacheKey = FastCrossSectionChunk.createHashKey(cs, km); Element element = cache.get(cacheKey); FastCrossSectionChunk fcsc; if (element != null) { if (debug) { log.debug("Found cross section chunk in cache id: " + cs.getId() + " km: " + km); } fcsc = (FastCrossSectionChunk)element.getValue(); } else { if (debug) { log.debug("Not found cross section chunk in cache id: " + cs.getId() + " km: " + km + " -> loading"); } fcsc = new FastCrossSectionChunk(cs, km); element = new Element(cacheKey, fcsc); cache.put(element); } return fcsc.getCrossSectionLine(km); } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :