Penjelajah Area 3D: Panduan penyesuaian

3D Area Explorer adalah solusi yang memungkinkan Anda menjelajahi komunitas dalam 3D yang menawan. Solusi ini memanfaatkan: Petak 3D Fotorealistik Google, Places Search, Place Details, dan Autocomplete API.

Memulai:

Aktifkan

Menyesuaikan pengalaman

Solusi Penjelajah Area 3D sangat dapat disesuaikan, sehingga Anda dapat menyesuaikan pengalaman dengan perjalanan pelanggan. Anda dapat melakukan penyesuaian menggunakan panel kontrol di UI atau menggunakan file config.json.

Siap untuk disesuaikan? Berikut caranya:

Lokasi

Tentukan titik awal pengalaman Anda dengan menyesuaikan lintang dan bujur di file config.json.

Kontrol Kamera

Kontrol perjalanan Anda dengan memilih jenis orbit kamera: jalur melingkar klasik atau gelombang sinus yang menarik.

  • Orbit tetap:

    Ini adalah orbit melingkar pada ketinggian tetap dan di sekitar titik minat tertentu.

    Lihat orbit tetap yang sedang beroperasi dengan menjelajahi kantor Google Sydney.

  • Orbit dinamis:

    Kamera bergerak mulus dalam lintasan gelombang sinus di sekitar lokasi menarik yang ditetapkan. Gerakan unik ini memungkinkan penonton mengamati titik yang menarik dari berbagai ketinggian dan sudut, sehingga menawarkan pengalaman visual yang dinamis dan menyenangkan.

    Lihat cara kerja orbit dinamis dengan menjelajahi menara Eiffel.

Lokasi Menarik (POI):

  • Sesuaikan eksplorasi Anda dengan menentukan jenis tempat yang ingin Anda temukan. Pilih dari museum, taman, sekolah, dan lainnya menggunakan array types di config.json.
  • Tetapkan jumlah maksimum Lokasi Menarik yang ditampilkan dengan menyesuaikan parameter density.
  • Ubah searchRadius (in meters) untuk menyertakan permata tersembunyi di sekitar atau berfokus pada area tertentu.
  • Tetapkan kecepatan yang dipilih untuk gerakan kamera dengan parameter speed (in revolutions per minute).

Memuat Eksplorasi Terlebih Dahulu: Mempelajari Lebih Dalam dengan Penyesuaian URL

3D Area Explorer memungkinkan Anda menentukan eksplorasi terlebih dahulu dengan penyesuaian URL. Hal ini menghilangkan kebutuhan konfigurasi manual, sehingga menyederhanakan pengalaman pengguna.

Membuat URL yang Sempurna:

Cukup tambahkan parameter tertentu ke URL Area Explorer untuk menyetel lokasi dan setelan lainnya terlebih dahulu. Contoh:

https://{base-url}/#location.coordinates.lat=40.7424396&location.coordinates.lng=-74.0061439

URL ini menetapkan titik awal ke lintang dan bujur yang ditentukan, sehingga Anda langsung diantar ke lokasi yang dipilih. Parameter yang Tersedia:

  • location.coordinates.lat: Lintang lokasi yang Anda pilih.
  • location.coordinates.lng: Bujur lokasi yang Anda pilih.
  • poi.types: Daftar jenis POI yang dipisahkan koma yang akan ditampilkan.
  • poi.density: Jumlah maksimum POI yang dipilih.
  • poi.searchRadius: Radius untuk menelusuri POI di sekitar.
  • camera.speed: Kecepatan orbit kamera.
  • camera.orbitType: Jenis orbit kamera ("fixed-orbit" atau "dynamic-orbit").

Manfaat Penyesuaian URL:

  • Sederhanakan pengalaman pengguna dengan menentukan setelan yang Anda pilih terlebih dahulu.
  • Membagikan perjalanan yang ditargetkan dengan lokasi dan POI yang dimuat sebelumnya.
  • Menyematkan pengalaman Area Explorer yang telah dikonfigurasi sebelumnya dengan lancar di dalam situs.

Dengan memanfaatkan penyesuaian URL, Anda dapat membuat pengalaman yang disesuaikan dan mengundang orang lain untuk memulai petualangan yang diseleksi.

Penyesuaian lebih lanjut

Bagian sebelumnya mempelajari penyesuaian yang dapat diakses melalui UI atau file konfigurasi. Namun, ada juga beberapa parameter bawaan lain yang dapat Anda ubah untuk menyesuaikan aplikasi lebih lanjut.

Untuk melakukan penyesuaian lanjutan ini, Anda harus melihat kode dalam file src/utils/cesium.js yang terletak di direktori src. Variabel berikut dapat diubah untuk mengubah tampilan dan nuansa aplikasi

Tinggi kamera

Kontrol seberapa tinggi kamera memosisikan dirinya saat terbang ke suatu titik dengan menyesuaikan nilai CAMERA_HEIGHT. Nilai yang lebih tinggi akan memberikan tampilan panoramik yang lebih jauh, sedangkan nilai yang lebih rendah akan mendekatkan Anda ke detail area

// Camera height (in meters) above the target when flying to a point.
const CAMERA_HEIGHT = 100;
  • Setelan: CAMERA_HEIGHT
  • Nilai Default: 100
  • Deskripsi: Menentukan tinggi kamera di atas lokasi target saat terbang ke suatu titik.
  • Contoh Nilai:
    • 50: Tampilan yang lebih dekat, yang menekankan detail.
    • 200: Perspektif yang lebih panorama.

Kemiringan kamera

Kemiringan awal kamera ditentukan oleh BASE_PITCH. Gunakan nilai negatif untuk kemiringan ke bawah dan nilai positif untuk tampilan ke atas. Untuk menambahkan gerakan dinamis yang halus ke eksplorasi Anda, ubah AUTO_ORBIT_PITCH_AMPLITUDE.

// Pitch 30 degrees downwards
const BASE_PITCH = -30;
// change the pitch by 10 degrees over time
const AUTO_ORBIT_PITCH_AMPLITUDE = 10;
  • Setelan: BASE_PITCH dan AUTO_ORBIT_PITCH_AMPLITUDE
  • Nilai Default:
    • BASE_PITCH: -30 (pitching 30 derajat ke bawah)
    • AUTO_ORBIT_PITCH_AMPLITUDE: 10 (mengubah pitch sebesar 10 derajat dari waktu ke waktu)

Deskripsi: Pitch kamera adalah kemiringan visual peta, yang diukur dalam derajat. Hal ini juga dikenal sebagai kemiringan. Setelan ini menentukan pitch awal dan penyesuaian pitch dinamis kamera selama rotasi otomatis.

Contoh Nilai:

  • BASE_PITCH: 0 (kamera level)
  • AUTO_ORBIT_PITCH_AMPLITUDE: 0 (tanpa variasi nada)

Rentang dan Zoom Kamera

Parameter ini menetapkan jumlah zoom yang diterapkan saat berfokus pada titik tertentu. Nilai yang lebih kecil berarti zoom yang lebih dekat.

// Distance variation relative to initial range.
const RANGE_AMPLITUDE_RELATIVE = 0.55;

// Determines how much the camera should zoom in or out
const ZOOM_FACTOR = 20;

Setelan: RANGE_AMPLITUDE_RELATIVE dan ZOOM_FACTOR

Nilai Default:

  • RANGE_AMPLITUDE_RELATIVE: 0,55 (variasi jarak relatif)
  • ZOOM_FACTOR: 20 (faktor zoom kamera)

Deskripsi: Setelan ini menentukan variasi rentang selama gerakan kamera dan tingkat zoom untuk melihat lebih dekat.

Contoh Nilai:

  • RANGE_AMPLITUDE_RELATIVE: 1 (variasi rentang penuh)
  • ZOOM_FACTOR: 10 (lebih sedikit zoom)
// Camera heading (rotation), pitch (tilt), and range (distance) for resetting view.
const CAMERA_OFFSET = {
  heading: 0, // No rotation offset.
  pitch: Cesium.Math.toRadians(BASE_PITCH),
  range: 800, // 800 meters from the center.
};

Reset Kamera

Saat pengguna ingin mereset kamera ke posisi semula, nilai CAMERA_OFFSET akan digunakan. Setelan ini mencakup arah (rotasi), kemiringan), dan rentang (seberapa jauh kamera dari pusat).

  • Setelan: CAMERA_OFFSET
  • Nilai Default:
    • heading: 0 (tidak ada offset rotasi)
    • pitch: Cesium.Math.toRadians(-30) (pitch 30 derajat ke bawah)
    • range: 800 (800 meter dari pusat)
  • Deskripsi: Menentukan arah, kemiringan, dan rentang kamera untuk mereset tampilan.
  • Contoh Nilai:
    • heading: 45 (derajat, tampilan barat laut)
    • range: 1.500 meter (lebih jauh dari pusat)

Koordinat Awal:

START_COORDINATES menentukan bujur, lintang, dan tinggi awal untuk kamera. Di sinilah eksplorasi akan dimulai, jadi tetapkan ke area yang ingin Anda lihat oleh pengguna terlebih dahulu.

// Default camera start position in longitude, latitude, and altitude.
const START_COORDINATES = {
  longitude: 0,
  latitude: 60,
  height: 15000000, // 15,000 km above the surface
};
  • Setelan: START_COORDINATES
  • Nilai Default:

    • longitude: 0
    • latitude: 60
    • height: 15000000 (15.000 km di atas permukaan)
  • Contoh Nilai:

    • longitude: -122.4934, latitude: 37.7951 (Jembatan Gerbang Golden)
    • height: 2000 (posisi awal yang lebih dekat)

Memuat lokasi yang telah ditentukan

Objek location di config.json menetapkan pusat area. Ini adalah sudut pandang awal kamera di penampil Cesium.coordinates: Menentukan lintang (lat) dan bujur (lng) untuk lokasi yang akan digeser kamera terlebih dahulu. Sesuaikan nilai ini untuk menyetel kamera ke lokasi tertentu di bumi.

  {
  "location": {
    "coordinates": { "lat": null, "lng": null }
  },

Konfigurasi ini memungkinkan Anda memulai aplikasi 3D Place Navigator dengan melakukan zoom ke lokasi tertentu yang Anda pilih. Anda dapat menggunakan alat Geocoding Google untuk mendapatkan koordinat lintang dan bujur alamat atau nama tempat dengan menentukannya di objek lokasi:

  1. Akses Alat Geocoding.
  2. Membuat Permintaan Geocoding Klik bagian "Coba Sendiri", lalu masukkan lokasi yang Anda pilih di kolom "Alamat". Anda dapat menentukan alamat, nama tempat, atau bahkan penanda.
  3. Buat Koordinat Klik tombol "Jalankan" untuk mengirimkan permintaan Anda. Alat ini akan menampilkan respons yang berisi berbagai informasi tentang lokasi, termasuk koordinat lintang dan bujurnya yang ditampilkan di bagian geometry.location.
  4. Gunakan geocode Salin nilai lintang dan bujur yang diambil dari respons, lalu tempelkan ke objek coordinates dalam konfigurasi Anda.

Catatan: Geocode yang digunakan dengan cara ini harus mengikuti persyaratan yang diuraikan dalam Persyaratan Layanan Google Maps Platform bagian 3.4, yaitu geocode tidak boleh disimpan dalam cache selama lebih dari 30 hari dan harus dimuat ulang setelah itu.

gambar

Konfigurasi ini akan menggunakan alat Geocoding untuk secara otomatis menentukan koordinat kantor pusat Google di Mountain View, California, dan meluncurkan aplikasi Place Navigator 3D Anda dengan kamera dipusatkan pada lokasi tersebut.

Penyesuaian lanjutan

Anda dapat melakukan penyesuaian tambahan dengan mempelajari kode lebih dalam. Bagian berikut akan memandu Anda melalui beberapa opsi

Tambahkan jalur kamera baru

Secara otomatis, solusi ini menerapkan dua jalur kamera yang berbeda:

fixed-orbit" | "dynamic-orbit"

Namun, jika ingin membuat jalur kamera baru, Anda dapat menerapkannya menggunakan

/src/utils/cesium.js dalam fungsi calculateAutoOrbitFrame.

Untuk menggunakan penghitungan jalur baru ini di panel konfigurasi,lihat implementasi di demo/src/camera-settings.js.

Menambahkan jenis tempat lainnya

Daftar jenis tempat untuk konfigurasi dapat disesuaikan di file demo/src/place-settings.js. Mulai baris 4 adalah jenis tempat yang tersedia dalam demo.

Jika ingin menggunakan jenis tempat tertentu tanpa mengubah sumber demo, Anda cukup menambahkannya ke file config.json di bagian poi.types

Menyesuaikan gaya (css)

Untuk gaya, kita menggunakan variabel CSS. Fungsi ini didukung di setiap browser utama dan memungkinkan perubahan satu baris di tempat terpusat serta memperbarui properti CSS tertentu. Variabel CSS kita ditentukan di src/main.css. Di tempat ini, Anda dapat menyesuaikan warna, setelan font, dan padding atau margin untuk seluruh aplikasi.

Menempatkan data tambahan

Untuk menempatkan data tambahan, Anda harus memperbarui file src/utils/cesium.js dan membaca dokumentasi cesium tentang cara menambahkan GeoJSON atau data yang direferensikan secara geografis lainnya ke globe.

Menghapus bagian konfigurasi

Aplikasi JavaScript kita memiliki tiga bagian utama dalam file konfigurasi: demo/src/[config-panel.js](config-panel.js): location, poi, dan camera. Setiap bagian ini menyediakan opsi konfigurasi untuk berbagai aspek aplikasi. Developer dapat menyesuaikan bagian ini berdasarkan kebutuhan spesifik mereka.

1.Menghapus bagian tertentu dari konfigurasi

  • Bagian Lokasi

Untuk menghapus bagian location, temukan baris berikut dalam kode Anda dan beri komentar atau hapus:

const locationConfig = { ...config.location, ...customConfig.location };
  • Bagian POI

Untuk menghapus bagian poi, temukan baris berikut dalam kode Anda dan berikan komentar atau hapus:

const poiConfig = { ...config.poi, ...customConfig.poi };
  • Bagian Kamera

Untuk menghapus bagian camera, temukan baris berikut dalam kode Anda dan beri komentar atau hapus:

const cameraConfig = { ...config.camera, ...customConfig.camera };

2. Memperbarui Konfigurasi Gabungan

Setelah menghapus suatu bagian, penting untuk memperbarui objek konfigurasi gabungan. Objek ini menggabungkan konfigurasi default dengan penyesuaian apa pun. Hapus properti yang sesuai dari objek combinedConfig:

const combinedConfig = {
 location: { ...config.location, ...customConfig.location }, // Remove if location section is removed

 poi: { ...config.poi, ...customConfig.poi }, // Remove if poi section is removed
 camera: { ...config.camera, ...customConfig.camera }, // Remove if camera section is removed
};

3. Menyesuaikan Elemen UI

Jika menghapus bagian juga berarti menghapus elemen UI terkait, perbarui kode sesuai dengan kode html. Misalnya, jika ingin menghapus bagian tertentu dari panel Admin seperti kecepatan kamera, Anda harus mengupdate kode js dan html untuk itu.

4. Menghapus Bagian Setelan Kamera

Untuk menghapus bagian setelan kamera dari UI, temukan baris berikut dan komentari atau hapus:

const cameraSettingsSecgetCameraSettingsSection(cameraConfig);

Menghapus Ringkasan Bagian Lokasi

const locationSection = await getLocationSettingsSection(locationConfig);

Kesimpulan

Dalam dokumen ini, kami telah menjelajahi berbagai opsi penyesuaian yang tersedia di Area Explorer untuk menyesuaikan pengalaman eksplorasi 3D Anda. Dengan mengubah perilaku kamera, menyesuaikan kemiringan visual, dan mengubah tingkat zoom, Anda dapat membuat pengalaman yang unik dan menarik yang menampilkan setelan dan lokasi menarik yang dipilih.

Jangan lupa untuk bereksperimen dengan berbagai konfigurasi dan menyesuaikan parameter agar sesuai dengan kebutuhan spesifik Anda. Dengan memanfaatkan kekuatan penyesuaian, Anda dapat membuat perjalanan yang imersif dan dipersonalisasi yang memikat audiens dan mewujudkan visi Anda.