承接 artisanweblab/spatial 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

artisanweblab/spatial

Composer 安装命令:

composer require artisanweblab/spatial

包简介

PostgreSQL spatial data types extension for Laravel

关键字:

README 文档

README

composer require artisanweblab/spatial

PostgreSQL and PostGIS

PostGIS is a spatial database extender for PostgreSQL object-relational database. It adds support for geographic objects allowing location queries to be run in SQL.

PostGIS Official Documentation

Install PostGIS to your Web server

Install PostGIS to your Docker container

MySQL and MariaDB

MySQL and MariaDB have built-in support for spatial data.

Integration with your project

Prepare your table

Add fields with the required data type:

Laravel 10 and before:

$table->point('point')->isGeometry()->nullable();

Laravel 11 and after:

$table->geometry('point', 'point')->nullable();

Prepare your model

<?php

namespace App\Models;

use ArtisanWebLab\Spatial\Eloquent\Casts\SpatialCast;
use ArtisanWebLab\Spatial\Traits\SpatialTrait;
use Brick\Geo\Point;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;

/**
 * @property integer $id
 * @property string $name
 * @property Point $point
 */
class User extends Model
{
    use HasFactory, SpatialTrait;

    protected $fillable = [
        'name',
        'address',
        'point',
    ];

    protected $casts = [
        'point' => SpatialCast::class,
    ];
}

Example of Input and Output spatial data

<?php

use App\Models\User;
use Brick\Geo\Point;

/** @var User $user */
$user = User::query()->first();

// Longitude, Latitude
$user->point = Point::xy(2.2945022, 48.8582687);

$user->save();

//...

$user = User::query()->first();

get_class($user->point); // Brick\Geo\Point

How to find records by Geometry

<?php

use App\Models\User;
use Brick\Geo\Point;

// Longitude, Latitude
$point = Point::xy(2.2945022, 48.8582687);

$users = User::query()
    ->withSpatialDistance('point', $point)
    ->whereSpatialDistanceSphere('point', $point, '<=', 1000) // 1000 meters
    ->get();

Available Eloquent methods

withSpatialDistance(string $column, Geometry $geometry, string $alias = null): Builder

whereSpatialDistance(string $column, Geometry $geometry, string $operator, int|float $distance, string $boolean = 'and'): Builder

orWhereSpatialDistance(string $column, Geometry $geometry, string $operator, int|float $distance): Builder

Geometry Raw

use Brick\Geo\IO\GeoJSONReader;
use Brick\Geo\IO\GeoJSONWriter;
use Brick\Geo\Point;
use Illuminate\Support\Facades\DB;

// Longitude, Latitude
$point = Point::xy(2.2945022, 48.8582687);

$query = sprintf(
    "ST_AsGeoJSON(ST_Buffer(ST_GeomFromGeoJSON('%s'), 10)) as response",
    (new GeoJSONWriter(false))->write($point)
);

$result = DB::query()->selectRaw($query)->first();

$geometry = $result ? (new GeoJSONReader(true))->read($result->response) : null;
{
    "type":"Polygon",
    "coordinates":[
        [
            [58.8582687,2.2945022],
            [58.666121504,0.34359898],
            //...
        ]
    ]
}

统计信息

  • 总下载量: 475
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 0
  • Forks: 3
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-05-21

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固