久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

  • <legend id='79NG5'><style id='79NG5'><dir id='79NG5'><q id='79NG5'></q></dir></style></legend>

    <small id='79NG5'></small><noframes id='79NG5'>

    <i id='79NG5'><tr id='79NG5'><dt id='79NG5'><q id='79NG5'><span id='79NG5'><b id='79NG5'><form id='79NG5'><ins id='79NG5'></ins><ul id='79NG5'></ul><sub id='79NG5'></sub></form><legend id='79NG5'></legend><bdo id='79NG5'><pre id='79NG5'><center id='79NG5'></center></pre></bdo></b><th id='79NG5'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='79NG5'><tfoot id='79NG5'></tfoot><dl id='79NG5'><fieldset id='79NG5'></fieldset></dl></div>
    <tfoot id='79NG5'></tfoot>
      <bdo id='79NG5'></bdo><ul id='79NG5'></ul>
      1. 僅當縮放級別&gt;時,才在閃亮的傳單地圖中顯

        Show layer in leaflet map in Shiny only when zoom level gt; 8 with LayersControl?(僅當縮放級別gt;時,才在閃亮的傳單地圖中顯示圖層8 層控制?)
        <i id='SysYj'><tr id='SysYj'><dt id='SysYj'><q id='SysYj'><span id='SysYj'><b id='SysYj'><form id='SysYj'><ins id='SysYj'></ins><ul id='SysYj'></ul><sub id='SysYj'></sub></form><legend id='SysYj'></legend><bdo id='SysYj'><pre id='SysYj'><center id='SysYj'></center></pre></bdo></b><th id='SysYj'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='SysYj'><tfoot id='SysYj'></tfoot><dl id='SysYj'><fieldset id='SysYj'></fieldset></dl></div>

        <small id='SysYj'></small><noframes id='SysYj'>

      2. <legend id='SysYj'><style id='SysYj'><dir id='SysYj'><q id='SysYj'></q></dir></style></legend>
        <tfoot id='SysYj'></tfoot>

                <tbody id='SysYj'></tbody>
                <bdo id='SysYj'></bdo><ul id='SysYj'></ul>
                1. 本文介紹了僅當縮放級別&gt;時,才在閃亮的傳單地圖中顯示圖層8 層控制?的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

                  問題描述

                  我只想在圖層控件中單擊圖層并且縮放級別大于某個數字時才顯示圖層,例如8. 原因之一是必須執行一些昂貴的計算才能獲得層坐標.我想使用圖層控件而不是額外的輸入按鈕(出于光學原因).

                  I want to show a layer only when its clicked in the LayersControl and the zoom level is greater than a certain number, e.g. 8. One of the reasons is, that some expensive computations must be performed to get the layer coordinates. I want to use the layerscontrol and not an extra input button (for optical reasons).

                  如果在圖層控件中單擊圖層按鈕,有沒有辦法檢索該值?

                  Is there a way to retrieve the value, if the layer button is clicked in the layerscontrol?

                  這是一個簡單的例子(不工作):

                  Here is a simple example (not working):

                  library(leaflet) 
                  library(shiny)
                  
                  ui <- fluidPage(
                    leafletOutput("map", width = "100%", height = "700")
                  )
                  
                  server <- function(input, output){
                    output$map <- renderLeaflet({
                      leaflet() %>% addTiles() %>% setView(10.4, 50.3, 7) %>%
                        addLayersControl(overlayGroups = c("marker"),
                                         options = layersControlOptions(collapsed = FALSE))
                    })
                  
                    observe({
                     # if (input$marker == TRUE){ # how to get value if layercontrol is clicked?
                        if (input$map_zoom > 8) {
                          leafletProxy("map") %>% addMarkers(lng = 10.5, lat = 50, group = "marker")
                        }
                    #  }
                    })
                  }
                  
                  shinyApp(ui = ui, server = server)
                  

                  推薦答案

                  這是第一個運行的版本.也許 smdy 想出了 sthg "cleaner" :).

                  Here is a first running version. Maybe smdy comes up with sthg "cleaner" :).

                  這里做個小解釋:

                  挑戰 1:input$marker 不作為閃亮的輸入存在.打開您的應用程序(在瀏覽器中),右鍵單擊您感興趣的標記輸入,然后在瀏覽器中選擇檢查元素"或等效標簽.您將看到該輸入的代碼.那為什么你不能訪問它.要查看您從閃亮中知道的輸入類型的差異,請創建一個 textinput 或 sthg 并同時創建檢查元素".您會看到閃亮的輸入有一個 id,....標記輸入沒有

                  Challenge 1: input$marker does not exist as shiny input. Open your app (in a browser), make a right click on the marker input you are interested in and select "Inspect Element" or the equivilant label in your browser. You will see the code of that input. So why cant you access it. To see the difference to the kind of input you know from shiny, create a textinput or sthg and make "inspect element" as well. You see that the shiny-inputs have an id,....the marker input does not

                  挑戰 2:訪問沒有 id 的輸入:(從這里開始,您應該知道如何將消息從 JS 發送到 R 并返回:您將在此處找到一篇非常好的文章:https://ryouready.wordpress.com/2013/11/20/sending-data-from-client-到服務器并返回使用閃亮/)如何訪問輸入:嗯,這基本上只是通過谷歌找到正確的片段.最后是:document.getElementsByTagName("input").(注意:從這里開始我假設你只有一個輸入)并且知道這有點棘手.嘗試訪問這個輸入.通過 console.log() 您可以打印到 javascript 控制臺(并通過F12"-> 控制臺 (JS) 在正在運行的應用程序中打開它.)您可以將此輸入打印為 HtMLCollection,但不能訪問它,這可能會非?;靵y.

                  Challenge 2: Access input that does not have an id: (From here on you should know how to send messages from JS to R and back: A very good article you will find here: https://ryouready.wordpress.com/2013/11/20/sending-data-from-client-to-server-and-back-using-shiny/) How to access the input: Well, thats basically just finding the right snippet via google. In the end this: document.getElementsByTagName("input"). (Attention: From here on I assume you only have one input) And know it gets a bit tricky. Try to access this input. Via console.log() you can print to javascript console (and open it in the running app via "F12" --> Console (JS).) You can print this input as HtMLCollection but can not access it, which can be very confusing.

                  挑戰 3:訪問?? HTMLCollection

                  您無法訪問它的原因(簡而言之)是在構建DOM"之前調用了JS代碼.如果在<body></body>"之后調用腳本,它會完全正常工作.但這對于普通的香草光澤并不是那么容易.您可以嘗試 window.onload()document.ready().到目前為止,對我來說最可靠的是使用: session$onFlushed() 并觸發將該函數中的 JSCode 從 R 發送到JS".(然后通過 Shiny.onInputChange("marker", inputs[0].checked); 將值作為輸入發送回 R) --> 這將產生所需的input$marker".然而,這個函數只觸發一次,這是完全正確的行為.但是當你點擊按鈕時你不會有更新.

                  The reason (in short) why you can not access it is that the JS code is called before the "DOM" is build. It would work totally fine if the script is called after "<body></body>". But thats not that easy with plain vanilla shiny. You can try window.onload() or document.ready(). What is the most reliable for me so far is to use: session$onFlushed() and trigger to send the JSCode within that function from R to "JS". (And then send the value as an input back to R via Shiny.onInputChange("marker", inputs[0].checked); ) --> This will produce the desired "input$marker". However, this function only fires once, which is totally right behaviour. But you wont have updates when you click the button.

                  挑戰 4:更新 input$marker那么漂亮的版本是有一個函數 .onclicked()/一個輸入監聽器.也許有人可以找到解決方案.我嘗試了一個閃亮的解決方法,我告訴閃亮通過 autoInvalidate() 不斷獲取輸入的值.

                  Challenge 4: Update input$marker Well the pretty version would be to have a function .onclicked()/ a listener for the input. Maybe somebody could find a solution. I tried a workaround in shiny, that i tell shiny to constantly get value of the input via autoInvalidate().

                  挑戰 5:好吧,沒那么難,因為它只是有光澤,但為了完整性.鑒于問題中提供的代碼,標記將在加載一次時保留.一旦不滿足縮放標準,不確定是要保留還是刪除它.無論如何,如果你想讓它消失,%>% clearMarkers() 是你的朋友.

                  Challenge 5: Well, not that difficult, because it is shiny only, but for sake of completeness. Given the provided code in the question, the marker will stay when loaded once. Not sure if you want it to stay or to be removed once your zooming criteria is not met. Anyway, if you want it to disappear, %>% clearMarkers() is your friend.

                  library(leaflet)
                  library(shiny)
                  
                  getInputwithJS <- '
                  Shiny.addCustomMessageHandler("findInput",
                    function(message) {
                    var inputs = document.getElementsByTagName("input");
                    Shiny.onInputChange("marker", inputs[0].checked);
                  }
                  );
                  '
                  
                  ui <- fluidPage(
                  
                    leafletOutput("map", width = "100%", height = "700"),
                    tags$head(tags$script(HTML(getInputwithJS)))
                  )
                  
                  server <- function(input, output, session){
                    global <- reactiveValues(DOMRdy = FALSE)
                    output$map <- renderLeaflet({
                      leaflet() %>% addTiles() %>% setView(10.4, 50.3, 7) %>%
                        addLayersControl(overlayGroups = c("marker"),
                                         options = layersControlOptions(collapsed = FALSE))
                    })
                  
                    autoInvalidate <- reactiveTimer(1)
                  
                    observe({
                      autoInvalidate()
                      if(global$DOMRdy){
                        session$sendCustomMessage(type = "findInput", message = "")      
                      }
                    })
                  
                    session$onFlushed(function() {
                      global$DOMRdy <- TRUE
                    })
                  
                    observe({
                      if (!is.null(input$marker)){
                        if (input$marker == TRUE){ # how to get value if layercontrol is clicked?
                          if (input$map_zoom > 8) {
                            leafletProxy("map") %>% addMarkers(lng = 10.5, lat = 50, group = "marker")
                          }else{
                            leafletProxy("map") %>% clearMarkers()
                          }
                        }
                      }
                    })
                  }
                  
                  shinyApp(ui = ui, server = server)
                  

                  這篇關于僅當縮放級別&gt;時,才在閃亮的傳單地圖中顯示圖層8 層控制?的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

                  【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

                  相關文檔推薦

                  Check if a polygon point is inside another in leaflet(檢查一個多邊形點是否在傳單中的另一個內部)
                  Changing leaflet markercluster icon color, inheriting the rest of the default CSS properties(更改傳單標記群集圖標顏色,繼承其余默認 CSS 屬性)
                  Trigger click on leaflet marker(觸發點擊傳單標記)
                  How can I change the default loading tile color in LeafletJS?(如何更改 LeafletJS 中的默認加載磁貼顏色?)
                  Adding Leaflet layer control to sidebar(將 Leaflet 圖層控件添加到側邊欄)
                  Leaflet - get latitude and longitude of a marker inside a pop-up(Leaflet - 在彈出窗口中獲取標記的緯度和經度)
                2. <legend id='rtMon'><style id='rtMon'><dir id='rtMon'><q id='rtMon'></q></dir></style></legend>
                  1. <tfoot id='rtMon'></tfoot>

                      <i id='rtMon'><tr id='rtMon'><dt id='rtMon'><q id='rtMon'><span id='rtMon'><b id='rtMon'><form id='rtMon'><ins id='rtMon'></ins><ul id='rtMon'></ul><sub id='rtMon'></sub></form><legend id='rtMon'></legend><bdo id='rtMon'><pre id='rtMon'><center id='rtMon'></center></pre></bdo></b><th id='rtMon'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='rtMon'><tfoot id='rtMon'></tfoot><dl id='rtMon'><fieldset id='rtMon'></fieldset></dl></div>

                        <small id='rtMon'></small><noframes id='rtMon'>

                            <tbody id='rtMon'></tbody>
                            <bdo id='rtMon'></bdo><ul id='rtMon'></ul>
                            主站蜘蛛池模板: 成人一区二 | 久久国产精品一区二区三区 | 九九热最新地址 | www亚洲免费国内精品 | 国产综合一区二区 | 97免费视频在线观看 | 精品国产一区二区三区免费 | 中文精品视频 | 久久精品综合 | 精品成人av | 在线视频 亚洲 | 久草热播 | 久草高清视频 | 婷婷久 | 国产在线精品一区二区三区 | 色www精品视频在线观看 | 久久久高清 | 中文字幕一区二区三区乱码在线 | 欧美视频免费在线 | 国产日韩欧美一区 | 91麻豆产精品久久久久久夏晴子 | 亚洲人成人一区二区在线观看 | 特a毛片 | 日韩欧美国产一区二区三区 | 免费观看一级特黄欧美大片 | 免费在线黄色av | 中文字幕亚洲视频 | 亚洲在线视频 | 国产精品自拍啪啪 | 无吗视频| 国产美女自拍视频 | 日韩中文在线视频 | 中文字幕一区二区三区四区五区 | 日韩精品激情 | 国产精品国产精品国产专区不卡 | 成人在线免费网站 | 免费看a | 久草在线在线精品观看 | 欧美一区二区综合 | 国产在线1| 亚洲精品免费视频 |