google-maps - 如何在 Flutter 中更改谷歌地图标记的图标大小?

标签 google-maps flutter dart

我在我的 flutter 应用程序中使用 google_maps_flutter 来使用谷歌地图我有自定义标记图标,我使用 BitmapDescriptor.fromAsset("images/car.png") 但是我在 map 上的图标太大了,我想让它变小,但我找不到任何选项,是否有任何选项可以更改自定义标记图标。 这是我的 flutter 代码:

mapController.addMarker(
        MarkerOptions(
          icon: BitmapDescriptor.fromAsset("images/car.png"),

          position: LatLng(
            deviceLocations[i]['latitude'],
            deviceLocations[i]['longitude'],
          ),
        ),
      );

这是我的安卓模拟器的截图:

如图所示,我的自定义图标太大了

最佳答案

TL;DR:只要能够将任何图像编码为 Uint8List 等原始字节,您就可以将其用作标记。


到目前为止,您可以使用 Uint8List 数据通过 Google map 创建标记。这意味着你可以使用 raw 数据来绘制任何你想要的 map 标记,只要你保持正确的编码格式(在这个特定的场景中,它是一个 png)。

我将举两个例子,你可以:

  1. 选择一个本地资源并动态地将其大小更改为您想要的任何大小并在 map 上渲染(Flutter Logo 图像);
  2. 在 Canvas 中绘制一些东西并将其渲染为标记,但这可以是任何渲染小部件。

除此之外,您甚至可以将渲染小部件转换为静态图像,因此也可以将其用作标记。


1。使用 Assets

首先,创建一个处理 Assets 路径并接收大小的方法(这可以是宽度、高度或两者,但只使用一个将保持比例)。

import 'dart:ui' as ui;

Future<Uint8List> getBytesFromAsset(String path, int width) async {
  ByteData data = await rootBundle.load(path);
  ui.Codec codec = await ui.instantiateImageCodec(data.buffer.asUint8List(), targetWidth: width);
  ui.FrameInfo fi = await codec.getNextFrame();
  return (await fi.image.toByteData(format: ui.ImageByteFormat.png)).buffer.asUint8List();
}

然后,只需使用正确的描述符将其添加到您的 map 中:

final Uint8List markerIcon = await getBytesFromAsset('assets/images/flutter.png', 100);
final Marker marker = Marker(icon: BitmapDescriptor.fromBytes(markerIcon));

这将分别产生 50、100 和 200 宽度的以下内容。

asset_example


2。使用 Canvas

您可以使用 Canvas 绘制任何您想要的东西,然后将其用作标记。下面将生成一些简单的圆角框,其中包含 Hello world! 文本。

所以,首先使用 Canvas 绘制一些东西:

Future<Uint8List> getBytesFromCanvas(int width, int height) async {
  final ui.PictureRecorder pictureRecorder = ui.PictureRecorder();
  final Canvas canvas = Canvas(pictureRecorder);
  final Paint paint = Paint()..color = Colors.blue;
  final Radius radius = Radius.circular(20.0);
  canvas.drawRRect(
      RRect.fromRectAndCorners(
        Rect.fromLTWH(0.0, 0.0, width.toDouble(), height.toDouble()),
        topLeft: radius,
        topRight: radius,
        bottomLeft: radius,
        bottomRight: radius,
      ),
      paint);
  TextPainter painter = TextPainter(textDirection: TextDirection.ltr);
  painter.text = TextSpan(
    text: 'Hello world',
    style: TextStyle(fontSize: 25.0, color: Colors.white),
  );
  painter.layout();
  painter.paint(canvas, Offset((width * 0.5) - painter.width * 0.5, (height * 0.5) - painter.height * 0.5));
  final img = await pictureRecorder.endRecording().toImage(width, height);
  final data = await img.toByteData(format: ui.ImageByteFormat.png);
  return data.buffer.asUint8List();
}

然后以相同的方式使用它,但这次提供您想要的任何数据(例如宽度和高度)而不是 Assets 路径。

final Uint8List markerIcon = await getBytesFromCanvas(200, 100);
final Marker marker = Marker(icon: BitmapDescriptor.fromBytes(markerIcon));

给你。

canvas_example

关于google-maps - 如何在 Flutter 中更改谷歌地图标记的图标大小?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53633404/

相关文章:

Dart 对象到 native - UnimplementedError : structured clone of other type

dart - 引发了另一个异常: '(BuildContext, int) => dynamic'类型不是 '(BuildContext, int) => Widget'类型的子类型

flutter - Flutter:是否可以在main.dart中一次实现一个 snackbar ,例如在连接状态更改时在所有屏幕上实现一次

jquery - 单击 map 中的标记打开一个对话框

javascript - 右键单击标记 - Google map V3

javascript - 在静态谷歌地图上绘制路线

dart - 没有 AppBar 的 Flutter 应用设计

http - 关于 HttpException 没有被捕获

flutter - 如何在 flutter 中制作更粗的下划线文本

android - Google maps android api 使用哪个证书?