El archivo config.xml

Muchos aspectos del comportamiento de una aplicación pueden controlarse con un archivo de configuración global, config.xml . Este archivo XML independiente de la plataforma se arregla basado en la especificación del W3C Empaquetado aplicaciones Web (Widgets) y extendido a especificar funciones API Cordova centrales, plugins y configuración específica de la plataforma.

Para los proyectos creados con la CLI Cordova (descrito en la interfaz de línea de comandos), este archivo puede encontrarse en el directorio de nivel superior:

    app/config.xml

Tenga en cuenta que antes de versión 3.3.1-0.2.0, el archivo existía en app/www/config.xml , y que tenerlo aquí es apoyado todavía.

Cuando se usa la CLI para construir un proyecto, las versiones de este archivo pasivo se copian en varios platforms/ subdirectorios, por ejemplo:

    app/platforms/ios/AppName/config.xml
    app/platforms/blackberry10/www/config.xml
    app/platforms/android/res/xml/config.xml

Esta sección detalla las opciones de configuración global y multiplataforma. Consulte las siguientes secciones para las opciones específicas de la plataforma:

Además de las diversas opciones de configuración detalladas a continuación, también puede configurar el conjunto básico de una aplicación de imágenes para cada plataforma de destino. Ver los iconos y salpicadura pantallas para obtener más información.

Elementos de configuración del núcleo

Este ejemplo muestra el valor predeterminado config.xml generados por la CLI create comando, que se describe en la interfaz de línea de comandos:

    <widget id="com.example.hello" version="0.0.1">
        <name>HelloWorld</name>
        <description>
            A sample Apache Cordova application that responds to the deviceready event.
        </description>
        <author email="dev@callback.apache.org" href="http://cordova.io">
            Apache Cordova Team
        </author>
        <content src="index.html" />
        <access origin="*" />
    </widget>

Los siguientes elementos de configuración aparecen en el archivo config.xml de primer nivel y se admiten todas las plataformas soportadas Cordova:

  • Atributo id del elemento <widget> proporciona identificador de reversa-dominio de la aplicación y la versión de su número de versión completa expresada en notación de mayor/menor/parche.

    La etiqueta widget también puede tener atributos que especifican las versiones alternativas, a saber versionCode para Android y CFBundleVersion para iOS. Vea la sección de versiones adicionales debajo para más detalles.

  • El elemento <name> especifica nombre formal de la aplicación, como aparece en la pantalla principal del dispositivo y dentro de la tienda app interfaces.

  • Los elementos <description> y <author> especifican metadatos e información de contacto que puede aparecer en anuncios de la tienda app.

  • Opcional <content> elemento define la página de inicio de la aplicación en el directorio web de alto nivel de activos. El valor predeterminado es index.html, que habitualmente aparece en el directorio de nivel superior www de un proyecto.

  • elementos <access> definen el conjunto de dominios externos que puede comunicarse con la aplicación. El valor predeterminado que se muestra arriba le permite acceder a cualquier servidor. Consulte a la guía de lista blanca de dominio para obtener más detalles.

  • La etiqueta <preference> establece varias opciones como pares de nombre / valor de atributos. De cada preferencia name es sensible a las mayúsculas. Muchas preferencias son exclusivos para plataformas específicas, como se indica en la parte superior de esta página. Las siguientes secciones detallan las preferencias que se aplican a más de una plataforma.

Versiones adicionales

Ambos, Android y iOS apoyar una segunda cadena de versión (o número) además de la visible en tiendas de aplicaciones, versionCode para Android y CFBundleVersion para iOS. A continuación es un ejemplo que establece explícitamente versionCode y CFBundleVersion

    <widget id="io.cordova.hellocordova"
      version="0.0.1"
      android-versionCode="7"
      ios-CFBundleVersion="3.3.3">

Si no se especifica la versión alternativa, se utilizarán los siguientes valores predeterminados:

    // assuming version = MAJOR.MINOR.PATCH-whatever
    versionCode = PATCH + MINOR * 100 + MAJOR * 10000
    CFBundleVersion = "MAJOR.MINOR.PATCH"

Preferencias globales

Las siguientes preferencias globales se aplican a todas las plataformas:

  • Fullscreen permite ocultar la barra de estado en la parte superior de la pantalla. El valor predeterminado es false. Ejemplo:

    <preference name="Fullscreen" value="true" />
    

Preferencias de múltiples plataformas

A más de una plataforma, pero no a todos ellos se aplican las siguientes preferencias:

  • DisallowOverscroll (boolean, valor predeterminado false): Si no quieres la interfaz para mostrar cualquier regeneración cuando los usuarios se pasa al principio o al final del contenido se establece en true.

    <preference name="DisallowOverscroll" value="true"/>
    

    Se aplica a iOS y Android. En iOS, overscroll gestos causa contenido a repuntar a su posición original. En Android, que producen un efecto brillante más sutil a lo largo del borde superior o inferior del contenido.

  • BackgroundColor: definir color de fondo de la aplicación. Admite un valor hexadecimal de cuatro bytes, con el primer byte que representan el canal alfa y valores RGB estándar para los siguientes tres bytes. Este ejemplo especifica azul:

    <preference name="BackgroundColor" value="0xff0000ff"/>
    

    Se aplica a Android y BlackBerry. Anula CSS disponibles en todas las plataformas, por ejemplo: body{background-color: blue;}.

  • HideKeyboardFormAccessoryBar (boolean, valor predeterminado false): establece en true para ocultar la barra de herramientas adicional que aparece encima del teclado, ayudando a los usuarios navegar desde la entrada de una forma a otra.

    <preference name="HideKeyboardFormAccessoryBar" value="true"/>
    

    Se aplica para BlackBerry.

  • Orientation(string, el valor predeterminado de default ): le permite bloquear orientación y evitar que roten en respuesta a cambios en la orientación de la interfaz. Los valores posibles son default , landscape o portrait . Ejemplo:

    <preference name="Orientation" value="landscape" />
    

    Además, puede especificar cualquier valor de orientación específica de la plataforma si colocas el <preference> elemento dentro de un <platform> elemento:

    <platform name="android">
        <preference name="Orientation" value="sensorLandscape" />
    </platform>
    

    Se aplica a Android, iOS, WP8, Amazon OS fuego y Firefox OS.

    Nota: el default valor significa Cordova tira a la entrada de preferencia de orientación del archivo de manifiesto/configuración de la plataforma que permite la plataforma a la suplencia a su comportamiento por defecto.

    Para iOS, para especificar tanto retrato y modo apaisado usted utilizaría la plataforma valor específico all:

    <platform name="ios">
        <preference name="Orientation" value="all" />
    </platform>
    

La función de elemento

Si utilizas el CLI para construir aplicaciones, usted utilice el comando plugin para habilitar dispositivo APIs. No se modifique el archivo config.xml de nivel superior, por lo que el elemento < feature > no se aplica a su flujo de trabajo. Si trabajas directamente en un SDK y usando el archivo config.xml de específicas de la plataforma como fuente, se utiliza la etiqueta < feature > para habilitar APIs de nivel de dispositivo y plugins externos. A menudo aparecen con valores personalizados en archivos específicos para cada plataforma config.xml . Por ejemplo, aquí es cómo especificar el dispositivo API para los proyectos de Android:

    <feature name="Device">
        <param name="android-package" value="org.apache.cordova.device.Device" />
    </feature>

Aquí es cómo aparece el elemento de iOS proyectos:

    <feature name="Device">
        <param name="ios-package" value="CDVDevice" />
    </feature>

Ver la referencia de la API para obtener más información sobre cómo especificar cada función. Consulte a la guía de desarrollo del Plugin para obtener más información sobre plugins.

El elemento platform

Cuando utilice la CLI para construir aplicaciones, a veces es necesario especificar preferencias u otros elementos específicos para una determinada plataforma. Utilice el elemento < platform > para especificar la configuración que sólo debe aparecer en un archivo específico de plataforma única config.xml . Por ejemplo, aquí es cómo especificar que android sólo debe emplear la opción de pantalla completa:

    <platform name="android">
        <preference name="Fullscreen" value="true" />
    </platform>

El elemento hook

Representa la secuencia de comandos personalizada que será llamado por Córdoba cuando se produce cierta acción (por ejemplo, después se agrega el plugin o plataforma preparar lógica se invoca). Esto es útil cuando se necesita extender la funcionalidad de Cordova por defecto. Para más información vea la guía de los ganchos.

<hook type="after_plugin_install" src="scripts/afterPluginInstall.js" />