python畫(huà)一個(gè)玫瑰和一個(gè)愛(ài)心
節(jié)日用心準(zhǔn)備的禮物,使用python畫(huà)玫瑰和愛(ài)心,供大家參考,具體內(nèi)容如下
#!/usr/bin/env python
#coding=utf-8
#女生節(jié)禮物
import rospy
from sensor_msgs.msg import LaserScan
import numpy
import copy
node_name = "Test_Maker"
class Test_Maker():
def __init__(self):
self.Define()
rospy.Timer(rospy.Duration(0.5), self.Timer_CB1)
rospy.Timer(rospy.Duration(0.5), self.Timer_CB2)
rospy.Timer(rospy.Duration(0.5), self.Timer_CB3)
rospy.Timer(rospy.Duration(0.5), self.Timer_CB4)
rospy.spin()
def Define(self):
self.pub_scan1 = rospy.Publisher('test/test_scan1', LaserScan, queue_size=1)
self.pub_scan2 = rospy.Publisher('test/test_scan2', LaserScan, queue_size=1)
self.pub_scan3 = rospy.Publisher('test/test_scan3', LaserScan, queue_size=1)
#慎用?。。?!
self.pub_scan4 = rospy.Publisher('test/test_scan4', LaserScan, queue_size=1)
def Timer_CB1(self, e):
data = LaserScan()
data.header.frame_id = "base_link"
data.angle_min = 0
data.angle_max = numpy.pi*2
data.angle_increment = numpy.pi*2 / 200
data.range_max = numpy.Inf
data.range_min = 0
theta = 0
for i in range(200):
r = 8.* numpy.sin(5. * theta )
data.ranges.append(copy.deepcopy(r))
data.intensities.append(theta)
r = 8.* numpy.sin(5. * -theta)
data.ranges.append(copy.deepcopy(r))
data.intensities.append(theta)
theta += data.angle_increment
data.header.stamp = rospy.Time.now()
self.pub_scan1.publish(data)
def Timer_CB2(self, e):
data = LaserScan()
data.header.frame_id = "base_link"
data.angle_min = 0
data.angle_max = numpy.pi*2
data.angle_increment = numpy.pi*2 / 200
data.range_max = numpy.Inf
data.range_min = 0
theta = 0
for i in range(200):
r = 8. * numpy.cos(5. * theta) + 1
data.intensities.append(theta)
data.ranges.append(copy.deepcopy(r))
r = 8. * numpy.cos(5. * -theta) + 1
data.intensities.append(theta)
data.ranges.append(copy.deepcopy(r))
theta += data.angle_increment
data.header.stamp = rospy.Time.now()
self.pub_scan2.publish(data)
def Timer_CB3(self, e):
data = LaserScan()
data.header.frame_id = "base_link"
data.angle_min = 0
data.angle_max = numpy.pi*2
data.angle_increment = numpy.pi*2 / 50
data.range_max = numpy.Inf
data.range_min = 0
theta = 0
for i in range(200):
r = 2. * numpy.sin(5. * theta) + 1
data.intensities.append(theta)
data.ranges.append(copy.deepcopy(r))
r = 2. * numpy.sin(5. * -theta) + 1
data.intensities.append(theta)
data.ranges.append(copy.deepcopy(r))
theta += data.angle_increment
data.header.stamp = rospy.Time.now()
self.pub_scan3.publish(data)
#慎用?。。。?
def Timer_CB4(self, e):
data = LaserScan()
data.header.frame_id = "base_link"
data.angle_min = 0
data.angle_max = numpy.pi*2
data.angle_increment = data.angle_max / 200
data.range_max = numpy.Inf
data.range_min = 0
theta = 0
for i in range(200):
r = 9. * numpy.arccos(numpy.sin(theta)) + 9
data.ranges.append(r)
theta += data.angle_increment
data.header.stamp = rospy.Time.now()
self.pub_scan4.publish(data)
if __name__ == '__main__':
node_name = 'Test_Maker'
rospy.init_node(node_name)
try:
Test_Maker()
except rospy.ROSInterruptException:
rospy.logerr('%s error'%node_name)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
linux環(huán)境打包python工程為可執(zhí)行程序的過(guò)程
本次需求,在ubuntu上面開(kāi)發(fā)的python代碼程序需要打包成一個(gè)可執(zhí)行程序然后交付給甲方,因?yàn)椴荒苤苯咏o源碼給甲方,所以尋找方法將python開(kāi)發(fā)的源碼打包成一個(gè)可執(zhí)行程序,本次在ubuntu上打包python源碼的方法和在window上打包的有點(diǎn)類(lèi)似,感興趣的朋友跟隨小編一起看看吧2024-01-01
python百行代碼自制電腦端網(wǎng)速懸浮窗的實(shí)現(xiàn)
這篇文章主要介紹了python百行代碼自制電腦端網(wǎng)速懸浮窗的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
對(duì)Python中小整數(shù)對(duì)象池和大整數(shù)對(duì)象池的使用詳解
今天小編就為大家分享一篇對(duì)Python中小整數(shù)對(duì)象池和大整數(shù)對(duì)象池的使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-07-07
Python實(shí)現(xiàn)從N個(gè)數(shù)中找到最大的K個(gè)數(shù)
這篇文章主要介紹了Python實(shí)現(xiàn)從N個(gè)數(shù)中找到最大的K個(gè)數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-04-04
Python實(shí)現(xiàn)對(duì)字典分別按鍵(key)和值(value)進(jìn)行排序的方法分析
這篇文章主要介紹了Python實(shí)現(xiàn)對(duì)字典分別按鍵(key)和值(value)進(jìn)行排序的方法,結(jié)合實(shí)例形式分析了Python基于sorted函數(shù)及operator庫(kù)進(jìn)行字典排序的相關(guān)操作技巧,需要的朋友可以參考下2018-12-12
Python實(shí)現(xiàn)迪杰斯特拉算法過(guò)程解析
這篇文章主要介紹了Python實(shí)現(xiàn)迪杰斯特拉算法過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
執(zhí)行Django數(shù)據(jù)遷移時(shí)報(bào) 1091錯(cuò)誤及解決方法
這篇文章主要介紹了執(zhí)行Django數(shù)據(jù)遷移,報(bào)錯(cuò) 1091,需要的朋友可以參考下2019-10-10

