pessek/pessek_mapsopen

使用开源技术构建的地图

安装: 2

依赖项: 0

建议者: 0

安全: 0

星星: 0

关注者: 1

分支: 0

开放问题: 0

类型:elgg-plugin

4.0 2021-10-26 19:14 UTC

This package is not auto-updated.

Last update: 2024-09-26 07:45:37 UTC


README

Elgg 4.0

用于使用开源技术构建的地图的API和UI

屏幕截图

User Map

功能

  • 通过Nominatim进行地理编码和反向地理编码
  • 使用Leaflet.js构建的地图
  • 默认地图瓦片由Open Street Maps提供(可在视图中自定义)
  • 用户地图
  • 群组地图
  • 群组成员地图

用法

任意位置的地图

echo elgg_view('page/components/map', [
	'markers' => [
		'Berlin, Germany',
		'London, UK',
		'Paris, France',
	]
]);

自定义图标地图

$berlin = hypeJunction\MapsOpen\Marker::fromLocation('Berlin, Germany');
$berlin->icon = 'smile-o';
$berlin->color = 'green';
$berlin->tooltip = '<b>Berlin is a happy place</b>';

$paris = hypeJunction\MapsOpen\Marker::fromLocation('Paris, France');
$paris->icon = 'coffee';
$paris->color = 'black';
$paris->tooltip = '<img src="https://s-media-cache-ak0.pinimg.com/736x/ca/ea/57/caea57268e1dee696f3c20a5a0f895f2.jpg" alt="Paris" />';

echo elgg_view('page/components/map', [
	'markers' => [
		$berlin,
		$paris,
	],
		]);

实体地图

echo elgg_view('page/components/map', [
	'markers' => elgg_get_entities_from_metadata([
		'types' => 'object',
		'subtypes' => 'place',
		'metadata_name_value_pairs' => [
			'venue_type' => 'cafe',
		],
		'limit' => 0,
	]),
	'center' => hypeJunction\MapsOpen\Marker::fromLocation('London, UK');
		]);

带数据源和搜索的地图

echo elgg_view('page/components/map', [
	// Set src to json data source
	// Data set should be an export of Marker instances
	'src' => '/path/to/data/source/json',
	'show_search' => true,
		]);

更改标记图标和颜色

使用 'marker','<entity_type>' 钩子。支持的颜色:'red', 'darkred', 'orange', 'green', 'darkgreen', 'blue', 'purple', 'darkpuple', 'cadetblue'

elgg_register_plugin_hook_handler('marker', 'object', function($hook, $type, $return, $params) {

	$entity = elgg_extract('entity', $params);

	if ($entity instanceof Event) {
		$return->icon = 'calendar';
		$return->color = 'darkpurple'
	}

	return $return;
})

更改弹出内容

maps/tooltip/<entity_type>/<entity_subtype>maps/tooltip/<entity_type>/default 添加视图;

致谢