Як уникнути рожевих плиток, коли перегляд БД / Таблиця порожній?


10

У мене є просторові погляди в тому сенсі, що вони вибирають якийсь просторовий стовпчик з іншої таблиці. Ця таблиця публікується за допомогою геосервера. Ця таблиця в прямому ефірі, а колись взагалі немає даних. Якщо в таблиці немає даних, відображається wms - все, redа помилка в консолі firebug - це: введіть тут опис зображення

WMS повернув:

>  <?xml version="1.0" encoding="UTF-8" standalone="no"?><!DOCTYPE
> ServiceExceptionReport SYSTEM
> "http://192.168.70.65:80/geoserver/schemas/wms/1.1.1/WMS_exception_1_1_1.dtd"> <ServiceExceptionReport version="1.1.1" >   <ServiceException>
>           java.lang.NullPointerException
>     null
>     </ServiceException></ServiceExceptionReport>

Код:

function init(){    
            OpenLayers.IMAGE_RELOAD_ATTEMPTS = 1;
                OpenLayers.Util.onImageLoadErrorColor = "transparent";    

                map = new OpenLayers.Map('map', {   
                    projection: new OpenLayers.Projection("EPSG:900913"),
                    displayProjection: new OpenLayers.Projection("EPSG:4326"),
                    numZoomLevels: 21,
                    maxExtent: new OpenLayers.Bounds(-20037508, -20037508,20037508, 20037508.34),   
                    controls: [
                        new OpenLayers.Control.Navigation(),
                        new OpenLayers.Control.PanZoomBar(),
                        new OpenLayers.Control.LayerSwitcher({'ascending':false}),                       
                        new OpenLayers.Control.ScaleLine(),
                        new OpenLayers.Control.MousePosition(),
                        new OpenLayers.Control.OverviewMap(),
                        new OpenLayers.Control.KeyboardDefaults()
                    ]   


                });

Використання GeoExt:

<script src="http://localhost/geoserver/www/ext/adapter/ext/ext-base.js" type="text/javascript"></script>
        <script src="http://localhost/geoserver/www/ext/ext-all.js"  type="text/javascript"></script>
        <link rel="stylesheet" type="text/css" href="http://localhost/geoserver/www/ext/resources/css/ext-all.css"/>

        <link rel="stylesheet" href="http://localhost/geoserver/www/openLayers/theme/default/style.css" type="text/css" />
        <script src="http://localhost/geoserver/www/openLayers/OpenLayers.js" type="text/javascript"></script>

        <script src="http://localhost/geoserver/www/geoext/lib/GeoExt.js" type="text/javascript"></script>        
        <link rel="stylesheet" type="text/css" href="http://localhost/geoserver/www/geoext/resources/css/geoext-all.css"/>


        <script>

            OpenLayers.Util.onImageLoadErrorColor = 1;
            OpenLayers.Util.onImageLoadErrorColor = "transparent";          

            Ext.BLANK_IMAGE_URL = "http://localhost/geoserver/www/ext/resources/images/default/s.gif";
            var app, items = [], controls = [];
            var lon = 85.344;
            var lat = 27.7;
            var zoom = 12;
            var url = "http://localhost/geoserver/wms";



            Ext.onReady(function() {            
                app = new Ext.Viewport({
                    layout: "border",
                    items: items
                });     

Яке Ваше запитання?
underdark

@underdark, коли у перегляду немає даних, тобто немає рядка, шар є таким, як показано на малюнку
kinkajou

... а ви хочете знати, як позбутися червоної плитки?
андермаркет

@underdark так, чи є такий спосіб
kinkajou

Відповіді:


5

Ви спробували це для додавання зображення за замовчуванням на помилку зображення:

OpenLayers.Util.onImageLoadError = function(){
     this.src = "images/blank.png";
};

чудове рішення спрацювало для мене.
kinkajou

23

Новіші версії OpenLayers (пост 2.11) повинні використовувати для цього класи CSS.

.olImageLoadError { 
    /* when OL encounters a 404, don't display the pink image */
    display: none !important;
} 

1
Від style.css: .olImageLoadError {фон-колір: рожевий; непрозорість: 0,5; фільтр: альфа (непрозорість = 50); / * IE * /}
ca0v

5

Встановіть такі параметри в OpenLayers:

// Avoid pink error tiles
OpenLayers.IMAGE_RELOAD_ATTEMPTS = 3;
OpenLayers.Util.onImageLoadErrorColor = "transparent";

Довідковий документ / навчальний посібник:

http://workshops.opengeo.org/stack-intro/openlayers.html

Зверніть увагу, що 3 є дуже високою толерантністю для спроб перезавантаження IMHO і може бути знижена до 1.


Я додав ці параметри, але все-таки однакову помилку Я також додав код
kinkajou

Ви повинні встановити парами перед тим, як буде створений будь-який об'єкт відкритих шарів.
unicoletti

за допомогою geoext ця змінна була оголошена вгорі, як показує моя редакція, але вона все ще не працює. Це працює лише тоді, коли я використовую лише відкриті шари будь-які проблеми з моєю ініціалізацією?
kinkajou

Ви могли пояснити, що ви використовували геотекст з самого початку. Це також у faq: catb.org/esr/faqs/smart-questions.html
unicoletti

моє погано :( добре деякі мої сторінки використовують лише відкриті шари, а інші використовують geoext + openlayers спробували це, використовуючи лише відкритий шар, добре працює, але застряг з іншими
kinkajou

3

Це просто працювало для мене OpenLayers V2.13.1

.olTileImage.olImageLoadError {
    display: none !important;
}
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.