1

coordinates on the picture

I clicked on the HTML image to display the coordinates. I want the coordinates to appear in the NINOX number field. How can I do this? Thank you.

POINT

let t := this;
let imageUrl := "https://share.ninox.com/4m02831o55c2vmnb8fopajfdmclj22n7j1o9";
html("
<link rel='stylesheet' href='https://unpkg.com/leaflet@1.9.4/dist/leaflet.css' crossorigin='' />
<script src='https://unpkg.com/leaflet@1.9.4/dist/leaflet.js' crossorigin=''></script>

<!-- 地圖容器 -->
<div id='map' style='height: 600px; width: 100%;'></div>

<!-- 座標顯示 -->
<div id='cursor-coords' style='position: absolute; bottom: 10px; right: 10px; 
    background: white; padding: 5px; border: 1px solid black; z-index: 1000;'>
    座標: [X: 0, Y: 0]
</div>

<script>
// 初始化地圖和圖片
setTimeout(function(){
    var map = L.map('map', {
        crs: L.CRS.Simple,  // 使用簡單座標系統
        minZoom: -2         // 最小縮放級別
    });

    // 定義圖片範圍
    var bounds = [[0, 0], [2400, 3200]];  
    var imageUrl = '" +
imageUrl +
"';

    // 顯示背景圖片
    L.imageOverlay(imageUrl, bounds).addTo(map);
    map.fitBounds(bounds);

    // 點擊事件 - 計算座標並顯示
    map.on('click', function(e) {
        var x = Math.round((e.latlng.lng - bounds[0][1]) * (3200 / (bounds[1][1] - bounds[0][1])));
        var y = Math.round((bounds[1][0] - e.latlng.lat) * (2400 / (bounds[1][0] - bounds[0][0])));

        // 顯示座標於 HTML
        document.getElementById('cursor-coords').innerText =
            '座標: [X: ' + x + ', Y: ' + y + ']';
    });
}, 1000);
</script>

<style>
#cursor-coords {
    font-size: 14px;
    font-weight: bold;
}
</style>
")

I ultimately want to mark the location on the picture (notation with symbols) and add subtable data

thanks.

8 replies

null
    • gold_cat
    • 12 days ago
    • Reported - view

    I am also looking forward to a solution. 

    • info.39
    • 11 days ago
    • Reported - view
    map.on('click', function(e) {
            var x = Math.round((e.latlng.lng - bounds[0][1]) * (3200 / (bounds[1][1] - bounds[0][1])));
            var y = Math.round((bounds[1][0] - e.latlng.lat) * (2400 / (bounds[1][0] - bounds[0][0])));
            database.update('"+raw(this)+"','"+fieldId(this,"X")+"',x);
            database.update('"+raw(this)+"','"+fieldId(this,"Y")+"',y);
            document.getElementById('cursor-coords').innerText =
                '座標: [X: ' + x + ', Y: ' + y + ']';
        });
    
      • szormpas
      • 11 days ago
      • Reported - view

        Hi,

      According to the Ninox release notes regarding 'database.update':

      "We do not recommend using the calls mentioned above as they will be phased out after the 3.8.0 release. We're also working on more standardized ways to support these use cases in the future."

      Do you know if Ninox has changed the plans for this global function?

      • info.39
      • 11 days ago
      • Reported - view

       While I am not working for Ninox and have no direct contact to the dev team, I know that a lot of solutions implemented with customers are using this functionality extensively. I have heard, that in case of a removal of these functions, there is going to be a replacement. However, since the 3.8.0 patch notes, nothing has changed and there is basically complete silence about these functions. 
      My personal guess is, they will work unchanged for a long time. 

      • szormpas
      • 11 days ago
      • Reported - view

        Hi, thanks for the update.

      I use javascript Fetch API to update the Ninox database. Based on your experience, which do you think is better (database.update vs Fetch API)?

      If you've got a minute, I'd appreciate your thoughts.

      • info.39
      • 11 days ago
      • Reported - view

       
      fetch API = 1+ API calls. In Public cloud, this can lead to issues with the limited volume of available calls.
      database.update works even when offline on mobile apps.
      I prefer the latter in every case.

      • cyan_silver
      • 10 days ago
      • Reported - view

       
      Thank you, it's working fine now

    • cyan_silver
    • 6 days ago
    • Reported - view

    I have an idea,
    Step 1: Click on the position on the drawing, and a dot will appear at the corresponding position.
    Step 2: X and Y coordinate data will appear at the same time
    Step 3: Click the button to add sub-table data (coordinates = current coordinates). After adding the data, there will be tiles on the picture.

    I would like to ask you how to improve the following problems:
    1. The picture will move when you click it for the first time.
    2. Any solution that can be simplified or optimized

    thank you all