Android Open Source - MrParkingNavigator Registration Information






From Project

Back to project page MrParkingNavigator.

License

The source code is released under:

MIT License

If you think the Android project MrParkingNavigator listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.

Java Source Code

/*
Copyright (c) 2011, Sony Ericsson Mobile Communications AB
/*from w  ww.  j  a  va2s  .c om*/
All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:

 * Redistributions of source code must retain the above copyright notice, this
  list of conditions and the following disclaimer.

 * Redistributions in binary form must reproduce the above copyright notice,
  this list of conditions and the following disclaimer in the documentation
  and/or other materials provided with the distribution.

 * Neither the name of the Sony Ericsson Mobile Communications AB nor the names
  of its contributors may be used to endorse or promote products derived from
  this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

package com.sonyericsson.extras.liveware.extension.util.registration;

import com.sonyericsson.extras.liveware.aef.notification.Notification;
import com.sonyericsson.extras.liveware.aef.registration.Registration;
import com.sonyericsson.extras.liveware.extension.util.Dbg;
import com.sonyericsson.extras.liveware.extension.util.ExtensionService;
import com.sonyericsson.extras.liveware.extension.util.sensor.AccessorySensor;

import android.content.ContentValues;
import android.content.Context;

/**
 * Provides information needed during extension registration
 */
public abstract class RegistrationInformation {

  public static int API_NOT_REQUIRED = 0;

  /**
   * Get the required notifications API version
   *
   * @return Required notification API version, or 0 if not supporting
   * notification.
   * @see Registration.ExtensionColumns#NOTIFICATION_API_VERSION
   * @see #getSourceRegistrationConfigurations
   * @see ExtensionService#onViewEvent
   * @see ExtensionService#onRefreshRequest
   */
  public abstract int getRequiredNotificationApiVersion();

  /**
   * Get the extension registration information.
   *
   * @return The registration configuration.
   * @see ExtensionService#onRegisterResult
   */
  public abstract ContentValues getExtensionRegistrationConfiguration();

  /**
   * Get all source registration configurations. The extensions specific id
   * must be set if there are more than one source. Override this method if
   * this is a notification extension
   *
   * @param extensionSpecificId The extension specific id.
   * @return The source registration information.
   * @see Notification.SourceColumns#EXTENSION_SPECIFIC_ID
   * @see #getRequiredNotificationApiVersion()
   */
  public ContentValues[] getSourceRegistrationConfigurations() {
    throw new IllegalArgumentException(
      "getSourceRegistrationConfiguration() not implemented. Notification extensions must override this method");
  }

  /**
   * Checks if the widget size is supported. Override this to provide
   * extension specific implementation.
   *
   * @param width  The widget width.
   * @param height The widget height.
   * @return True if the widget size is supported.
   */
  public boolean isWidgetSizeSupported(int width, int height) {
    throw new IllegalArgumentException(
      "isWidgetSizeSupported() not implemented. Widget extensions must override this method");
  }

  /**
   * Get the required widget API version
   *
   * @return Required API widget version, or 0 if not supporting widget.
   * @see #isWidgetSizeSupported
   * @see Registration.ApiRegistrationColumns#WIDGET_API_VERSION
   */
  abstract public int getRequiredWidgetApiVersion();

  /**
   * Get the target widget API version
   *
   * @return Required API widget version, or 0 if not supporting widget.
   * Returns required widget API version by default.
   * @see #isWidgetSizeSupported
   * @see ExtensionService#createWidgetExtension
   * @see Registration.ApiRegistrationColumns#WIDGET_API_VERSION
   */
  public int getTargetWidgetApiVersion() {
    return getRequiredWidgetApiVersion();
  }

  /**
   * Checks if the display size is supported.
   *
   * @param width  The display width.
   * @param height The display height.
   * @return True if the display size is supported.
   * @see ExtensionService#createControlExtension
   */
  public boolean isDisplaySizeSupported(final int width, final int height) {
    throw new IllegalArgumentException(
      "isDisplaySizeSupported() not implemented. Control extensions must override this method");
  }

  /**
   * Get the required control API version
   *
   * @return Required API control version, or 0 if not supporting control.
   * @see #isDisplaySizeSupported
   * @see ExtensionService#createControlExtension
   * @see Registration.ApiRegistrationColumns#CONTROL_API_VERSION
   */
  abstract public int getRequiredControlApiVersion();

  /**
   * Get the target control API version
   *
   * @return Required API control version, or 0 if not supporting control.
   * Returns required control API version by default.
   * @see #isDisplaySizeSupported
   * @see ExtensionService#createControlExtension
   * @see Registration.ApiRegistrationColumns#CONTROL_API_VERSION
   */
  public int getTargetControlApiVersion() {
    return getRequiredControlApiVersion();
  }

  /**
   * Check if the sensor is supported.
   *
   * @param sensor The sensor.
   * @return True if sensor is supported.
   */
  public boolean isSensorSupported(final AccessorySensor sensor) {
    throw new IllegalArgumentException(
      "isSensorSupported() not implemented. Sensor extensions must override this method");
  }

  /**
   * Get the required sensor API version
   *
   * @return Required API sensor version, or 0 if not supporting sensor.
   * @see #isDisplaySizeSupported
   * @see Registration.ApiRegistrationColumns#SENSOR_API_VERSION
   */
  abstract public int getRequiredSensorApiVersion();

  /**
   * Get the target sensor API version
   *
   * @return Target API sensor version, or 0 if not supporting sensor. Returns
   * required sensor API version by default.
   * @see #isDisplaySizeSupported
   * @see #getRequiredSensorApiVersion()
   * @see Registration.ApiRegistrationColumns#SENSOR_API_VERSION
   */
  public int getTargetSensorApiVersion() {
    return getRequiredSensorApiVersion();
  }

  /**
   * Return true if low power mode is supported by the control extension.
   *
   * @return True if low power mode is supported
   */
  public boolean supportsLowPowerMode() {
    return false;
  }

  /**
   * Return true if the control extension wants to intercept the back button
   * of the connected accessory
   *
   * @return True if extension wants to intercept back button
   */
  public boolean controlInterceptsBackButton() {
    return false;
  }

  /**
   * Return true if the sources shall be updated when the extension service is
   * created. This might be handy if the extension use dynamic sources and the
   * source can change when the extension service is not running.
   *
   * @return True if the source registration shall be update when the
   * extension service is created.
   */
  public boolean isSourcesToBeUpdatedAtServiceCreation() {
    return false;
  }

  /**
   * Check if widget shall be supported for this host application by checking
   * that the host application has device with a supported widget size. This
   * method can be override to provide extension specific implementations.
   *
   * @param context         The context.
   * @param hostApplication The host application.
   * @return True if widget shall be supported.
   */
  public boolean isSupportedWidgetAvailable(final Context context,
                                            final HostApplicationInfo hostApplication) {
    if (getRequiredWidgetApiVersion() == API_NOT_REQUIRED) {
      return false;
    }

    if (hostApplication.getWidgetApiVersion() == 0) {
      return false;
    }

    if (getRequiredWidgetApiVersion() > hostApplication.getWidgetApiVersion()) {
      if (Dbg.DEBUG) {
        Dbg.w("isSupportedWidgetAvailable: required widget API version not supported");
      }
      return false;
    }

    for (DeviceInfo device : hostApplication.getDevices()) {
      if (isWidgetSizeSupported(device.getWidgetWidth(), device.getWidgetHeight())) {
        return true;
      }
    }

    return false;
  }

  /**
   * Check if sensor shall be supported for this host application by checking
   * if the host application has at least one supported sensor. This method
   * can be override to provide extension specific implementations.
   *
   * @param context         The context.
   * @param hostApplication The host application.
   * @return True if sensor shall be supported.
   */
  public boolean isSupportedSensorAvailable(final Context context,
                                            final HostApplicationInfo hostApplication) {
    if (getRequiredSensorApiVersion() == API_NOT_REQUIRED) {
      return false;
    }

    if (hostApplication.getSensorApiVersion() == 0) {
      return false;
    }

    if (getRequiredSensorApiVersion() > hostApplication.getSensorApiVersion()) {
      if (Dbg.DEBUG) {
        Dbg.w("isSupportedSensorAvailable: required sensor API version not supported");
      }
      return false;
    }

    for (DeviceInfo device : hostApplication.getDevices()) {
      for (AccessorySensor sensor : device.getSensors()) {
        if (isSensorSupported(sensor)) {
          return true;
        }
      }
    }
    return false;
  }

  /**
   * Check if control shall be supported for this host application by checking
   * that the host application has a device with a supported display size.
   * This method can be override to provide extension specific
   * implementations.
   *
   * @param context         The context.
   * @param hostApplication The host application.
   * @return True if control shall be supported.
   */
  public boolean isSupportedControlAvailable(final Context context,
                                             final HostApplicationInfo hostApplication) {
    if (getRequiredControlApiVersion() == API_NOT_REQUIRED) {
      return false;
    }

    if (hostApplication.getControlApiVersion() == 0) {
      return false;
    }

    if (getRequiredControlApiVersion() > hostApplication.getControlApiVersion()) {
      if (Dbg.DEBUG) {
        Dbg.w("isSupportedControlAvailable: required control API version not supported");
      }
      return false;
    }

    for (DeviceInfo device : hostApplication.getDevices()) {
      for (DisplayInfo display : device.getDisplays()) {
        if (isDisplaySizeSupported(display.getWidth(), display.getHeight())) {
          return true;
        }
      }
    }

    return false;
  }
}




Java Source Code List

com.sonyericsson.extras.liveware.aef.control.Control.java
com.sonyericsson.extras.liveware.aef.control.package-info.java
com.sonyericsson.extras.liveware.aef.notification.Notification.java
com.sonyericsson.extras.liveware.aef.notification.package-info.java
com.sonyericsson.extras.liveware.aef.registration.Registration.java
com.sonyericsson.extras.liveware.aef.registration.package-info.java
com.sonyericsson.extras.liveware.aef.sensor.Sensor.java
com.sonyericsson.extras.liveware.aef.sensor.package-info.java
com.sonyericsson.extras.liveware.extension.util.Dbg.java
com.sonyericsson.extras.liveware.extension.util.ExtensionService.java
com.sonyericsson.extras.liveware.extension.util.ExtensionUtils.java
com.sonyericsson.extras.liveware.extension.util.control.ControlExtension.java
com.sonyericsson.extras.liveware.extension.util.control.ControlListItem.java
com.sonyericsson.extras.liveware.extension.util.control.ControlObjectClickEvent.java
com.sonyericsson.extras.liveware.extension.util.control.ControlTouchEvent.java
com.sonyericsson.extras.liveware.extension.util.control.ControlViewGroup.java
com.sonyericsson.extras.liveware.extension.util.control.ControlView.java
com.sonyericsson.extras.liveware.extension.util.notification.DelayedContentObserver.java
com.sonyericsson.extras.liveware.extension.util.notification.NotificationUtil.java
com.sonyericsson.extras.liveware.extension.util.registration.DeviceInfoHelper.java
com.sonyericsson.extras.liveware.extension.util.registration.DeviceInfo.java
com.sonyericsson.extras.liveware.extension.util.registration.DisplayInfo.java
com.sonyericsson.extras.liveware.extension.util.registration.HostApplicationInfo.java
com.sonyericsson.extras.liveware.extension.util.registration.IRegisterCallback.java
com.sonyericsson.extras.liveware.extension.util.registration.InputInfo.java
com.sonyericsson.extras.liveware.extension.util.registration.KeyPadInfo.java
com.sonyericsson.extras.liveware.extension.util.registration.RegisterExtensionTask.java
com.sonyericsson.extras.liveware.extension.util.registration.RegistrationAdapter.java
com.sonyericsson.extras.liveware.extension.util.registration.RegistrationInformation.java
com.sonyericsson.extras.liveware.extension.util.sensor.AccessorySensorEventListener.java
com.sonyericsson.extras.liveware.extension.util.sensor.AccessorySensorEvent.java
com.sonyericsson.extras.liveware.extension.util.sensor.AccessorySensorException.java
com.sonyericsson.extras.liveware.extension.util.sensor.AccessorySensorManager.java
com.sonyericsson.extras.liveware.extension.util.sensor.AccessorySensorType.java
com.sonyericsson.extras.liveware.extension.util.sensor.AccessorySensor.java
ru.mail.parking.App.java
ru.mail.parking.Preferences.java
ru.mail.parking.floors.FloorNavigator.java
ru.mail.parking.floors.Floor.java
ru.mail.parking.floors.Place.java
ru.mail.parking.sw2.SwControlFlow.java
ru.mail.parking.sw2.screens.SwBaseScreen.java
ru.mail.parking.sw2.screens.SwEnterPlaceScreen.java
ru.mail.parking.sw2.screens.SwFreePlacesScreen.java
ru.mail.parking.sw2.screens.SwNavigatorScreen.java
ru.mail.parking.sw2.screens.SwPlaceScreen.java
ru.mail.parking.sw2.system.SwReceiver.java
ru.mail.parking.sw2.system.SwRegInfo.java
ru.mail.parking.sw2.system.SwService.java
ru.mail.parking.ui.AboutActivity.java
ru.mail.parking.ui.DataDetailsActivity.java
ru.mail.parking.ui.EnterPlaceActivity.java
ru.mail.parking.ui.MultiscrollView.java
ru.mail.parking.ui.NavigatorActivity.java
ru.mail.parking.ui.NavigatorFloorView.java
ru.mail.parking.ui.SettingsActivity.java
ru.mail.parking.utils.NetworkAwaiter.java
ru.mail.parking.utils.NetworkStateReceiver.java
ru.mail.parking.utils.Utils.java
ru.mail.parking.widget.MainReceiver.java
ru.mail.parking.widget.MainWidgetProvider.java
ru.mail.parking.widget.SmartUpdate.java
ru.mail.parking.widget.UpdateService.java