前回はrosjavaでPublisherを作りました。
今回はrosjava_tutorial_pubsubの続きで、Subscriber(Listener.java)を見て行きます。
とりあえずソース貼ります。
/*
* Copyright (C) 2011 Google Inc.
*
* 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 org.ros.tutorials.pubsub;
import org.apache.commons.logging.Log;
import org.ros.message.MessageListener;
import org.ros.namespace.GraphName;
import org.ros.node.Node;
import org.ros.node.NodeMain;
import org.ros.node.topic.Subscriber;
/**
* This is a simple rosjava {@link Subscriber} {@link Node}. It assumes an
* external roscore is already running.
*
* @author damonkohler@google.com (Damon Kohler)
*/
public class Listener implements NodeMain {
@Override
public GraphName getDefaultNodeName() {
return new GraphName("rosjava_tutorial_pubsub/listener");
}
@Override
public void onStart(Node node) {
final Log log = node.getLog();
Subscriber<org.ros.message.std_msgs.string> subscriber =
node.newSubscriber("chatter", "std_msgs/String");
subscriber.addMessageListener(new MessageListener<org.ros.message.std_msgs.string>() {
@Override
public void onNewMessage(org.ros.message.std_msgs.String message) {
log.info("I heard: \"" + message.data + "\"");
}
});
}
@Override
public void onShutdown(Node node) {
}
@Override
public void onShutdownComplete(Node node) {
}
}
今回重要なのは以下の2つですね。
1.まずSubscriberの作成は以下です。Publisherのときと同じで文字列で型を入れてますね。
Subscriber<org.ros.message.std_msgs.String> subscriber =
node.newSubscriber("chatter", "std_msgs/String");
2.メッセージリスナーの登録。C++でのコールバック関数登録ですね。
関数を定義をそのまま引数に入れています。
subscriber.addMessageListener(new MessageListener<org.ros.message.std_msgs.String>() {
@Override
public void onNewMessage(org.ros.message.std_msgs.String message) {
log.info("I heard: \"" + message.data + "\"");
}
});
MessageListenerは以下のような定義です。
ログはnode.getLog().info("hogehoge")という形式ですね。
これでPubSubができました。実行方法は過去記事を参照ください。
public interface MessageListener{ void onNewMessage(T message); }
ログはnode.getLog().info("hogehoge")という形式ですね。
これでPubSubができました。実行方法は過去記事を参照ください。
0 件のコメント:
コメントを投稿