From afa255e4c319482a486230308214374afe842bb8 Mon Sep 17 00:00:00 2001 From: Anton Tananaev Date: Sun, 12 Aug 2012 13:28:41 +0400 Subject: Fix reverse geocoding (fix #37) --- src/org/traccar/ReverseGeocoderHandler.java | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) (limited to 'src/org/traccar/ReverseGeocoderHandler.java') diff --git a/src/org/traccar/ReverseGeocoderHandler.java b/src/org/traccar/ReverseGeocoderHandler.java index a7123bcec..74dfd10e9 100644 --- a/src/org/traccar/ReverseGeocoderHandler.java +++ b/src/org/traccar/ReverseGeocoderHandler.java @@ -15,16 +15,17 @@ */ package org.traccar; +import org.jboss.netty.channel.Channel; import org.jboss.netty.channel.ChannelHandlerContext; import org.jboss.netty.channel.MessageEvent; -import org.jboss.netty.channel.SimpleChannelHandler; +import org.jboss.netty.handler.codec.oneone.OneToOneDecoder; import org.traccar.geocode.ReverseGeocoder; import org.traccar.model.Position; /** * Reverse geocoding channel event handler */ -public class ReverseGeocoderHandler extends SimpleChannelHandler { +public class ReverseGeocoderHandler extends OneToOneDecoder { /** * Geocoder object @@ -36,14 +37,19 @@ public class ReverseGeocoderHandler extends SimpleChannelHandler { } @Override - public void messageReceived(ChannelHandlerContext ctx, MessageEvent e) { - if (e.getMessage() instanceof Position) { - Position position = (Position) e.getMessage(); + protected Object decode( + ChannelHandlerContext ctx, Channel channel, Object msg) + throws Exception { + + if (msg instanceof Position) { + Position position = (Position) msg; if (geocoder != null) { position.setAddress(geocoder.getAddress( position.getLatitude(), position.getLongitude())); } } + + return msg; } } -- cgit v1.2.3