python画一个玫瑰和一个爱心

yipeiwu_com5年前Python基础

节日用心准备的礼物,使用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装饰器

深入浅出学习python装饰器

之前就了解到了装饰器, 但是就会点皮毛, 而且对其调用方式感到迷茫,正好现在的项目我想优化,就想到了用装饰器, 因此深入研究了下装饰器. 先看下代码: import time #...

Python os模块学习笔记

一、os模块概述 Python os模块包含普遍的操作系统功能。例如文件的复制、创建、修改、删除文件及文件夹... 二、常用方法 1、os.listdir()   返...

Python实现选择排序

选择排序: 选择排序(Selection sort)是一种简单直观的 排序算法 。它的工作原理如下。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元...

20行python代码实现人脸识别

20行python代码实现人脸识别

OpenCV 是最流行的计算机视觉库,原本用 C 和 C++ 开发,现在也支持 Python。 它使用机器学习算法在图像中搜索人的面部。对于人脸这么复杂的东西,并没有一个简单的检测能对...

Python数据分析之双色球统计两个红和蓝球哪组合比例高的方法

Python数据分析之双色球统计两个红和蓝球哪组合比例高的方法

本文实例讲述了Python数据分析之双色球统计两个红和蓝球哪组合比例高的方法。分享给大家供大家参考,具体如下: 统计两个红球和蓝球,哪个组合最多,显示前19组数据 #!/usr/bi...