Skip to main content

Display a 3D model

This example shows how to display a 3D model on a map.

In the example, a sports car model is rendered on a map by using a Model Layer. This layer has the ability to render 3D models on the map.

Location data from a GeoJSON source is also used to position the model on the map.

model_layer.dart
import 'dart:convert';

import 'package:flutter/material.dart';
import 'package:mapbox_maps_flutter/mapbox_maps_flutter.dart';
import 'page.dart';

class ModelLayerPage extends ExamplePage {
ModelLayerPage() : super(const Icon(Icons.view_in_ar), 'Model layer');

@override
Widget build(BuildContext context) {
return ModelLayerWidget();
}
}

class ModelLayerWidget extends StatefulWidget {
ModelLayerWidget();

final _state = _ModelLayerState();
MapboxMap? getMapboxMap() => _state.mapboxMap;

@override
State<StatefulWidget> createState() {
return _state;
}
}

class _ModelLayerState extends State<ModelLayerWidget> {
MapboxMap? mapboxMap;

var position = Position(24.9458, 60.17180);
var modelPosition = Position(24.94457012371287, 60.171958417023674);

@override
Widget build(BuildContext context) {
return MapWidget(
cameraOptions: CameraOptions(
center: Point(coordinates: position),
zoom: 18.5,
bearing: 98.82,
pitch: 85),
key: const ValueKey<String>('mapWidget'),
onMapCreated: _onMapCreated,
onStyleLoadedListener: _onStyleLoaded);
}

_onMapCreated(MapboxMap mapboxMap) async {
this.mapboxMap = mapboxMap;
}

_onStyleLoaded(StyleLoadedEventData data) async {
addModelLayer();
}

addModelLayer() async {
var value = Point(coordinates: modelPosition);
if (mapboxMap == null) {
throw Exception("MapboxMap is not ready yet");
}

final buggyModelId = "model-test-id";
final buggyModelUri =
"https://github.com/KhronosGroup/glTF-Sample-Models/raw/d7a3cc8e51d7c573771ae77a57f16b0662a905c6/2.0/Buggy/glTF/Buggy.gltf";
await mapboxMap?.style.addStyleModel(buggyModelId, buggyModelUri);

final carModelId = "model-car-id";
final carModelUri = "asset://assets/sportcar.glb";
await mapboxMap?.style.addStyleModel(carModelId, carModelUri);

await mapboxMap?.style
.addSource(GeoJsonSource(id: "sourceId", data: json.encode(value)));

var modelLayer = ModelLayer(id: "modelLayer-buggy", sourceId: "sourceId");
modelLayer.modelId = buggyModelId;
modelLayer.modelScale = [0.15, 0.15, 0.15];
modelLayer.modelRotation = [0, 0, 90];
modelLayer.modelType = ModelType.COMMON_3D;
mapboxMap?.style.addLayer(modelLayer);

var modelLayer1 = ModelLayer(id: "modelLayer-car", sourceId: "sourceId");
modelLayer1.modelId = carModelId;
modelLayer1.modelScale = [0.15, 0.15, 0.15];
modelLayer1.modelRotation = [0, 0, 90];
modelLayer1.modelType = ModelType.COMMON_3D;
mapboxMap?.style.addLayer(modelLayer1);
}
}
Was this example helpful?