python画一个玫瑰和一个爱心


Posted in Python onAugust 18, 2020

节日用心准备的礼物,使用python画玫瑰和爱心,供大家参考,具体内容如下

#!/usr/bin/env python
#coding=utf-8
#女生节礼物
 
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)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python中sys.argv参数用法实例分析
May 20 Python
python删除列表内容
Aug 04 Python
Flask框架使用DBUtils模块连接数据库操作示例
Jul 20 Python
详解配置Django的Celery异步之路踩坑
Nov 25 Python
pip指定python位置安装软件包的方法
Jul 12 Python
Python爬虫爬取Bilibili弹幕过程解析
Oct 10 Python
将tf.batch_matmul替换成tf.matmul的实现
Jun 18 Python
如何基于pandas读取csv后合并两个股票
Sep 25 Python
Python根据URL地址下载文件并保存至对应目录的实现
Nov 15 Python
python实现简单的学生管理系统
Feb 22 Python
基于flask实现五子棋小游戏
May 25 Python
Python机器学习实战之k-近邻算法的实现
Nov 27 Python
python爱心表白 每天都是浪漫七夕!
Aug 18 #Python
Python实现全排列的打印
Aug 18 #Python
python递归实现快速排序
Aug 18 #Python
pyqt5的QWebEngineView 使用模板的方法
Aug 18 #Python
python递归全排列实现方法
Aug 18 #Python
python使用PIL给图片添加文字生成海报示例
Aug 17 #Python
Python在for循环中更改list值的方法【推荐】
Aug 17 #Python
You might like
台湾中原大学php教程孙仲岳主讲
2008/01/07 PHP
PHP中session跨子域的三种实现方法
2016/07/25 PHP
PHP5中使用mysqli的prepare操作数据库的介绍
2019/03/18 PHP
TNC vs IO BO3 第二场2.13
2021/03/10 DOTA
js function使用心得
2010/05/10 Javascript
jquery异步循环获取功能实现代码
2010/09/19 Javascript
20款超赞的jQuery插件 Web开发人员必备
2011/02/26 Javascript
javascript对talbe进行动态添加、删除、验证实现代码
2012/03/29 Javascript
利用js(jquery)操作Cookie的方法说明
2013/12/19 Javascript
详解JavaScript中getFullYear()方法的使用
2015/06/10 Javascript
《JavaScript函数式编程》读后感
2015/08/07 Javascript
使用js获取地址栏参数的方法推荐(超级简单)
2016/06/14 Javascript
js实现可旋转的立方体模型
2016/10/16 Javascript
详解JavaScript中this的指向问题
2017/01/20 Javascript
angular-cli修改端口号【angular2】
2017/04/19 Javascript
js中字符型和数值型数字的互相转化方法(必看)
2017/04/25 Javascript
如何通过setTimeout理解JS运行机制详解
2019/03/23 Javascript
微信小程序地图导航功能实现完整源代码附效果图(推荐)
2019/04/28 Javascript
vue-week-picker实现支持按周切换的日历
2019/06/26 Javascript
在Vue中实现随hash改变响应菜单高亮
2020/03/09 Javascript
使用Node.js实现base64和png文件相互转换的方法
2020/03/11 Javascript
在IIS服务器上以CGI方式运行Python脚本的教程
2015/04/25 Python
简单掌握Python中glob模块查找文件路径的用法
2016/07/05 Python
解决python3 安装完Pycurl在import pycurl时报错的问题
2018/10/15 Python
详细整理python 字符串(str)与列表(list)以及数组(array)之间的转换方法
2019/08/30 Python
Python requests HTTP验证登录实现流程
2020/11/05 Python
香港No.1得奖零食网:香港零食大王
2016/07/22 全球购物
英国的领先快速时尚零售商:In The Style
2019/03/25 全球购物
DogBuddy荷兰:找到你最完美的狗保姆
2019/04/17 全球购物
门卫班长岗位职责
2013/12/15 职场文书
高中政治教学反思
2014/01/18 职场文书
小露珠教学反思
2014/04/30 职场文书
鲁迅故里导游词
2015/02/05 职场文书
2015新学期家长寄语
2015/02/26 职场文书
2015年人事科工作总结
2015/04/28 职场文书
新西兰:最新留学学习计划书写作指南
2019/07/15 职场文书