1 /* 2 * Copyright (C) 2013 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package android.hardware; 18 19 import android.content.Context; 20 import android.os.RemoteException; 21 import android.os.ServiceManager; 22 import android.util.Log; 23 24 /** 25 * Class that operates consumer infrared on the device. 26 * 27 * <p> 28 * To obtain an instance of the system infrared transmitter, call 29 * {@link android.content.Context#getSystemService(java.lang.String) 30 * Context.getSystemService()} with 31 * {@link android.content.Context#CONSUMER_IR_SERVICE} as the argument. 32 * </p> 33 */ 34 public final class ConsumerIrManager { 35 private static final String TAG = "ConsumerIr"; 36 37 private final String mPackageName; 38 private final IConsumerIrService mService; 39 40 /** 41 * @hide to prevent subclassing from outside of the framework 42 */ 43 public ConsumerIrManager(Context context) { 44 mPackageName = context.getPackageName(); 45 mService = IConsumerIrService.Stub.asInterface( 46 ServiceManager.getService(Context.CONSUMER_IR_SERVICE)); 47 } 48 49 /** 50 * Check whether the device has an infrared emitter. 51 * 52 * @return true if the device has an infrared emitter, else false. 53 */ 54 public boolean hasIrEmitter() { 55 if (mService == null) { 56 Log.w(TAG, "no consumer ir service."); 57 return false; 58 } 59 60 try { 61 return mService.hasIrEmitter(); 62 } catch (RemoteException e) { 63 throw e.rethrowFromSystemServer(); 64 } 65 } 66 67 /** 68 * Transmit an infrared pattern 69 * <p> 70 * This method is synchronous; when it returns the pattern has 71 * been transmitted. Only patterns shorter than 2 seconds will 72 * be transmitted. 73 * </p> 74 * 75 * @param carrierFrequency The IR carrier frequency in Hertz. 76 * @param pattern The alternating on/off pattern in microseconds to transmit. 77 */ 78 public void transmit(int carrierFrequency, int[] pattern) { 79 if (mService == null) { 80 Log.w(TAG, "failed to transmit; no consumer ir service."); 81 return; 82 } 83 84 try { 85 mService.transmit(mPackageName, carrierFrequency, pattern); 86 } catch (RemoteException e) { 87 throw e.rethrowFromSystemServer(); 88 } 89 } 90 91 /** 92 * Represents a range of carrier frequencies (inclusive) on which the 93 * infrared transmitter can transmit 94 */ 95 public final class CarrierFrequencyRange { 96 private final int mMinFrequency; 97 private final int mMaxFrequency; 98 99 /** 100 * Create a segment of a carrier frequency range. 101 * 102 * @param min The minimum transmittable frequency in this range segment. 103 * @param max The maximum transmittable frequency in this range segment. 104 */ 105 public CarrierFrequencyRange(int min, int max) { 106 mMinFrequency = min; 107 mMaxFrequency = max; 108 } 109 110 /** 111 * Get the minimum (inclusive) frequency in this range segment. 112 */ 113 public int getMinFrequency() { 114 return mMinFrequency; 115 } 116 117 /** 118 * Get the maximum (inclusive) frequency in this range segment. 119 */ 120 public int getMaxFrequency() { 121 return mMaxFrequency; 122 } 123 }; 124 125 /** 126 * Query the infrared transmitter's supported carrier frequencies 127 * 128 * @return an array of 129 * {@link android.hardware.ConsumerIrManager.CarrierFrequencyRange} 130 * objects representing the ranges that the transmitter can support, or 131 * null if there was an error communicating with the Consumer IR Service. 132 */ 133 public CarrierFrequencyRange[] getCarrierFrequencies() { 134 if (mService == null) { 135 Log.w(TAG, "no consumer ir service."); 136 return null; 137 } 138 139 try { 140 int[] freqs = mService.getCarrierFrequencies(); 141 if (freqs.length % 2 != 0) { 142 Log.w(TAG, "consumer ir service returned an uneven number of frequencies."); 143 return null; 144 } 145 CarrierFrequencyRange[] range = new CarrierFrequencyRange[freqs.length / 2]; 146 147 for (int i = 0; i < freqs.length; i += 2) { 148 range[i / 2] = new CarrierFrequencyRange(freqs[i], freqs[i+1]); 149 } 150 return range; 151 } catch (RemoteException e) { 152 throw e.rethrowFromSystemServer(); 153 } 154 } 155 } 156