读.bag中指定的topic / 将.bag中的点云保存为.pcd

close all
clc
clear all

fid = fopen('Training.txt','w');

bag=rosbag('Training.bag');

BagSel1 = select(bag,'Topic','/NewTopic');
BagSel2 = select(bag,'Topic','/NewTopicCloud');
MsgStructs1 = readMessages(BagSel1,'DataFormat','struct');
MsgStructs2 = readMessages(BagSel2,'DataFormat','struct');


for i=1:39855
%     SingleBoxType{i} = MsgStructs1{i,1}.SingleBoxType;
    
    if(~isempty(MsgStructs1{i,1}.SingleBoxType) && i~=2514)
        fprintf(fid,'Number:%i\r\n',i);
        fprintf(fid,'Center:%f,%f,%f\r\n',MsgStructs1{i,1}.SingleBoxCenter(1),MsgStructs1{i,1}.SingleBoxCenter(2),MsgStructs1{i,1}.SingleBoxCenter(3));
        fprintf(fid,'Size:%f,%f,%f\r\n',MsgStructs1{i,1}.SingleBoxSize(1),MsgStructs1{i,1}.SingleBoxSize(2),MsgStructs1{i,1}.SingleBoxSize(3));
        fprintf(fid,'Velocity:%f\r\n',MsgStructs1{i,1}.SingleBoxVelocity);
        fprintf(fid,'Type:');
        fprintf(fid,'%c',MsgStructs1{i,1}.SingleBoxType);
        fprintf(fid,'\r\n');
        fprintf(fid,'\r\n');
        
       % 将该帧点云保存为pcd 
        str = strcat(int2str(i),'.pcd');
        xyz = rosReadXYZ(MsgStructs2{i,1});
        ptCloud = pointCloud(xyz);
        pcwrite(ptCloud,str);

    end
    

end


fclose(fid);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值