1 /* 2 * Copyright (C) 2022 Huawei Device Co., Ltd. 3 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * you may not use this file except in compliance with the License. 5 * You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software 10 * distributed under the License is distributed on an "AS IS" BASIS, 11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 * See the License for the specific language governing permissions and 13 * limitations under the License. 14 */ 15 16 #ifndef SATELLITE_STATUS_H 17 #define SATELLITE_STATUS_H 18 19 #include <mutex> 20 #include <parcel.h> 21 #include <vector> 22 23 namespace OHOS { 24 namespace Location { 25 class SatelliteStatus : public Parcelable { 26 public: 27 SatelliteStatus(); 28 explicit SatelliteStatus(SatelliteStatus &satelliteStatus); 29 ~SatelliteStatus() override = default; 30 GetSatellitesNumber()31 inline int GetSatellitesNumber() const 32 { 33 return satellitesNumber_; 34 } 35 SetSatellitesNumber(int num)36 inline void SetSatellitesNumber(int num) 37 { 38 satellitesNumber_ = num; 39 } 40 GetSatelliteIds()41 inline std::vector<int> GetSatelliteIds() const 42 { 43 return satelliteIds_; 44 } 45 SetSatelliteIds(std::vector<int> ids)46 inline void SetSatelliteIds(std::vector<int> ids) 47 { 48 std::unique_lock<std::mutex> lock(mutex_); 49 for (std::vector<int>::iterator it = ids.begin(); it != ids.end(); ++it) { 50 satelliteIds_.push_back(*it); 51 } 52 } 53 SetSatelliteId(int id)54 inline void SetSatelliteId(int id) 55 { 56 std::unique_lock<std::mutex> lock(mutex_); 57 satelliteIds_.push_back(id); 58 } 59 GetCarrierToNoiseDensitys()60 inline std::vector<double> GetCarrierToNoiseDensitys() const 61 { 62 return carrierToNoiseDensitys_; 63 } 64 SetCarrierToNoiseDensitys(std::vector<double> cn0)65 inline void SetCarrierToNoiseDensitys(std::vector<double> cn0) 66 { 67 std::unique_lock<std::mutex> lock(mutex_); 68 for (std::vector<double>::iterator it = cn0.begin(); it != cn0.end(); ++it) { 69 carrierToNoiseDensitys_.push_back(*it); 70 } 71 } 72 SetCarrierToNoiseDensity(double cn0)73 inline void SetCarrierToNoiseDensity(double cn0) 74 { 75 std::unique_lock<std::mutex> lock(mutex_); 76 carrierToNoiseDensitys_.push_back(cn0); 77 } 78 GetAltitudes()79 inline std::vector<double> GetAltitudes() const 80 { 81 return altitudes_; 82 } 83 SetAltitudes(std::vector<double> altitudes)84 inline void SetAltitudes(std::vector<double> altitudes) 85 { 86 std::unique_lock<std::mutex> lock(mutex_); 87 for (std::vector<double>::iterator it = altitudes.begin(); it != altitudes.end(); ++it) { 88 altitudes_.push_back(*it); 89 } 90 } 91 SetAltitude(double altitude)92 inline void SetAltitude(double altitude) 93 { 94 std::unique_lock<std::mutex> lock(mutex_); 95 altitudes_.push_back(altitude); 96 } 97 GetAzimuths()98 inline std::vector<double> GetAzimuths() const 99 { 100 return azimuths_; 101 } 102 SetAzimuths(std::vector<double> azimuths)103 inline void SetAzimuths(std::vector<double> azimuths) 104 { 105 std::unique_lock<std::mutex> lock(mutex_); 106 for (std::vector<double>::iterator it = azimuths.begin(); it != azimuths.end(); ++it) { 107 azimuths_.push_back(*it); 108 } 109 } 110 SetAzimuth(double azimuth)111 inline void SetAzimuth(double azimuth) 112 { 113 std::unique_lock<std::mutex> lock(mutex_); 114 azimuths_.push_back(azimuth); 115 } 116 GetCarrierFrequencies()117 inline std::vector<double> GetCarrierFrequencies() const 118 { 119 return carrierFrequencies_; 120 } 121 SetCarrierFrequencies(std::vector<double> cfs)122 inline void SetCarrierFrequencies(std::vector<double> cfs) 123 { 124 std::unique_lock<std::mutex> lock(mutex_); 125 for (std::vector<double>::iterator it = cfs.begin(); it != cfs.end(); ++it) { 126 carrierFrequencies_.push_back(*it); 127 } 128 } 129 SetCarrierFrequencie(double cf)130 inline void SetCarrierFrequencie(double cf) 131 { 132 std::unique_lock<std::mutex> lock(mutex_); 133 carrierFrequencies_.push_back(cf); 134 } 135 GetConstellationTypes()136 inline std::vector<int> GetConstellationTypes() const 137 { 138 return constellationTypes_; 139 } 140 SetConstellationTypes(std::vector<int> types)141 inline void SetConstellationTypes(std::vector<int> types) 142 { 143 std::unique_lock<std::mutex> lock(mutex_); 144 for (std::vector<int>::iterator it = types.begin(); it != types.end(); ++it) { 145 constellationTypes_.push_back(*it); 146 } 147 } 148 SetConstellationType(int type)149 inline void SetConstellationType(int type) 150 { 151 std::unique_lock<std::mutex> lock(mutex_); 152 constellationTypes_.push_back(type); 153 } 154 155 void ReadFromParcel(Parcel& parcel); 156 bool Marshalling(Parcel& parcel) const override; 157 static std::unique_ptr<SatelliteStatus> Unmarshalling(Parcel& parcel); 158 private: 159 int satellitesNumber_; 160 std::vector<int> satelliteIds_; 161 std::vector<double> carrierToNoiseDensitys_; 162 std::vector<double> altitudes_; 163 std::vector<double> azimuths_; 164 std::vector<double> carrierFrequencies_; 165 std::vector<int> constellationTypes_; 166 std::mutex mutex_; 167 }; 168 } // namespace Location 169 } // namespace OHOS 170 #endif // SATELLITE_STATUS_H 171