boost库安装、编译、配置(linux+vscode)、使用

安装、编译、配置

一.创建目录并拷贝boost压缩包

cd ~/
mkdir boost_sources
cp /mnt/hgfs/Linux_share/boost_1_82_0.tar.gz
tar -zxvf boost_1_82_0.tar.gz

二.运行bootstrap.sh工程编译构建程序

cd boost_1_82_0/
./bootstrap.sh

三.源码根目录下生成了b2程序,运行b2程序如下

./b2

四.把boost库头文件和lib库文件安装在默认的Linux系统头文件和库文件的搜索路径下

./b2 install

若果报错权限不够就 sudo!!!这一步必须要编译通过,否则没法引用库文件

五.配置(可不配置)

在这里插入图片描述
includePath要包含到boost文件

六.测试

#include <iostream>
#include <boost/bind.hpp>
#include <string>
using namespace std;
 
class Hello
{
public:
	void say(string name) 
	{ cout << name << " say: hello world!" << endl; }
};
 
int main()
{
	Hello h;
	auto func = boost::bind(&Hello::say, &h, "zhang san");
	func();
	return 0;
}

使用

boost文档

1.polygon 、disjoint

disjoint
两种创建polygon的方法,并进行多边形并集检测disjoint

  1. c_array 数组创建
#include <iostream>
#include <boost/geometry.hpp>
#include <boost/polygon/polygon.hpp>
#include <boost/geometry/geometries/point_xy.hpp>
#include <boost/geometry/geometries/adapted/c_array.hpp>
BOOST_GEOMETRY_REGISTER_C_ARRAY_CS(cs::cartesian)
namespace bg = boost::geometry;

int main(){

  double points[][2] = {{2.0, 1.3}, {4.1, 3.0}, {5.3, 2.6}, {2.9, 0.7}, {2.0, 1.3}}; //需要包含 <boost/geometry/geometries/adapted/c_array.hpp>
  double points2[][2] = {{2.0, 1.3}, {4.1, 3.0}, {5.3, 2.6}, {2.9, 0.7}, {2.0, 1.3}};
  bg::model::polygon<bg::model::d2::point_xy<double>> poly3, poly4;
  bg::append(poly3, points);
  bg::append(poly4, points2);

  bool res = boost::geometry::disjoint(poly4, poly3);
  std::cout << "res: " << !res << std::endl;

}
  1. bg::model::point
#include <iostream>
#include <boost/geometry.hpp>
#include <boost/polygon/polygon.hpp>
#include <boost/geometry/geometries/point_xy.hpp>
namespace bg = boost::geometry;

int main(){

    using geo_point = bg::model::point<int, 2, bg::cs::cartesian>;
    geo_point p1(1, 1), p2(1, 2), p3(2, 1), p4(2, 2);
    geo_point p5(1, 1), p6(3, 4), p7(4, 3), p8(4, 4);

    bg::model::polygon<geo_point> poly1, poly2;
    bg::append(poly1, p1);
    bg::append(poly1, p2);
    bg::append(poly1, p3);
    bg::append(poly1, p4);

    bg::append(poly2, p5);
    bg::append(poly2, p6);
    bg::append(poly2, p7);
    bg::append(poly2, p8);

    bool res = boost::geometry::disjoint(poly1, poly2);
    std::cout << "res: " << !res << std::endl;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值