fingertip_pos_publisher.py
Go to the documentation of this file.
1 #!/usr/bin/env python
2 # Software License Agreement (BSD License)
3 #
4 # Copyright (c) 2008, Willow Garage, Inc.
5 # All rights reserved.
6 #
7 # Redistribution and use in source and binary forms, with or without
8 # modification, are permitted provided that the following conditions
9 # are met:
10 #
11 # * Redistributions of source code must retain the above copyright
12 # notice, this list of conditions and the following disclaimer.
13 # * Redistributions in binary form must reproduce the above
14 # copyright notice, this list of conditions and the following
15 # disclaimer in the documentation and/or other materials provided
16 # with the distribution.
17 # * Neither the name of Willow Garage nor the names of its
18 # contributors may be used to endorse or promote products derived
19 # from this software without specific prior written permission.
20 #
21 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24 # FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25 # COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26 # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27 # BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28 # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29 # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31 # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32 # POSSIBILITY OF SUCH DAMAGE.
33 
34 import roslib
35 import rospy
36 import tf
37 from geometry_msgs.msg import Vector3
38 
39 roslib.load_manifest('hand_kinematics')
40 
41 if __name__ == '__main__':
42  rospy.init_node('tf_tippos_publisher')
43  listener = tf.TransformListener()
44  tip_pos_pub = []
45  tip_pos_pub.append(rospy.Publisher('fftip/position/', Vector3, queue_size=10))
46  tip_pos_pub.append(rospy.Publisher('mftip/position/', Vector3, queue_size=10))
47  tip_pos_pub.append(rospy.Publisher('rftip/position/', Vector3, queue_size=10))
48  tip_pos_pub.append(rospy.Publisher('lftip/position/', Vector3, queue_size=10))
49  tip_pos_pub.append(rospy.Publisher('thtip/position/', Vector3, queue_size=10))
50  rate = rospy.Rate(10.0)
51  while not rospy.is_shutdown():
52  try:
53  listener.waitForTransform(
54  '/rh_palm', '/rh_fftip', rospy.Time.now(), rospy.Duration(1.0))
55  try:
56  (trans, rot) = listener.lookupTransform(
57  '/rh_palm', '/rh_fftip', rospy.Time(0))
59  continue
60  tip_pos_pub[0].publish(Vector3(trans[0], trans[1], trans[2]))
61  try:
62  (trans, rot) = listener.lookupTransform(
63  '/rh_palm', '/rh_mftip', rospy.Time(0))
65  continue
66  tip_pos_pub[1].publish(Vector3(trans[0], trans[1], trans[2]))
67  try:
68  (trans, rot) = listener.lookupTransform(
69  '/rh_palm', '/rh_rftip', rospy.Time(0))
71  continue
72  tip_pos_pub[2].publish(Vector3(trans[0], trans[1], trans[2]))
73  try:
74  (trans, rot) = listener.lookupTransform(
75  '/rh_palm', '/rh_lftip', rospy.Time(0))
77  continue
78  tip_pos_pub[3].publish(Vector3(trans[0], trans[1], trans[2]))
79  try:
80  (trans, rot) = listener.lookupTransform(
81  '/rh_palm', '/rh_thtip', rospy.Time(0))
83  continue
84  tip_pos_pub[4].publish(Vector3(trans[0], trans[1], trans[2]))
85  except:
86  continue
87 
88  rate.sleep()


hand_kinematics
Author(s): Juan Antonio Corrales Ramon (UPMC),, Guillaume Walck (CITEC)
autogenerated on Wed Oct 14 2020 04:05:07