对于Android应用程序,我需要电池电量精确到2位小数。如何使电池电量精确到两位小数?
答案 0 :(得分:0)
自API 21起,可以使用以下命令获取当前电池电量百分比:
BatteryManager bm = (BatteryManager)getSystemService(BATTERY_SERVICE);
int batLevel = bm.getIntProperty(BatteryManager.BATTERY_PROPERTY_CAPACITY);
或者,您也可以使用以下plugin获取Android的电池电量统计信息:
import com.robinpowered.react.battery.DeviceBatteryPackage; // <--- import
public class MainActivity extends Activity implements DefaultHardwareBackBtnHandler {
......
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mReactRootView = new ReactRootView(this);
mReactInstanceManager = ReactInstanceManager.builder()
.setApplication(getApplication())
.setBundleAssetName("index.android.bundle")
.setJSMainModuleName("index.android")
.addPackage(new MainReactPackage())
.addPackage(new DeviceBatteryPackage()) // <------ add this line to yout MainActivity class
.setUseDeveloperSupport(BuildConfig.DEBUG)
.setInitialLifecycleState(LifecycleState.RESUMED)
.build();
mReactRootView.startReactApplication(mReactInstanceManager, "AndroidRNSample", null);
setContentView(mReactRootView);
}
......
}
或使用此plugin获取Android和iOS的电池电量统计信息
'use strict';
var React = require('react-native');
var BatteryManager = require('NativeModules').BatteryManager;
var {
AppRegistry,
StyleSheet,
Text,
View,
DeviceEventEmitter,
} = React;
var RCTBattery = React.createClass({
getInitialState: function() {
return {batteryLevel: null, charging:false};
},
onBatteryStatus: function(info){
this.setState({batteryLevel: info.level});
this.setState({charging: info.isPlugged});
},
componentDidMount: function(){
BatteryManager.updateBatteryLevel(function(info){
this._subscription = DeviceEventEmitter.addListener('BatteryStatus', this.onBatteryStatus);
this.setState({batteryLevel: info.level});
this.setState({charging: info.isPlugged});
}.bind(this));
},
componentWillUnmount: function(){
this._subscription.remove();
},
render: function() {
var chargingText;
if(this.state.charging){
chargingText =<Text style={styles.instructions}>Charging </Text>;
} else {
chargingText =<Text style={styles.instructions}>Not Charging </Text>;
}
return (
<View style={styles.container}>
<Text style={styles.welcome}>
Battery Level {this.state.batteryLevel}
</Text>
{chargingText}
</View>
);
}
});
var styles = StyleSheet.create({
container: {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
backgroundColor: '#F5FCFF',
},
welcome: {
fontSize: 20,
textAlign: 'center',
margin: 10,
},
instructions: {
textAlign: 'center',
color: '#333333',
marginBottom: 5,
},
});
AppRegistry.registerComponent('RCTBattery', () => RCTBattery);
我希望这会有所帮助。