SpeedView

SpeedView

项目地址: anastr/SpeedView
简介:Dynamic Speedometer for Android. amazing, powerful, and multi shape :zap:

Dynamic Speedometer for Android. amazing, powerful, and multi shape :zap: , you can change the color of everything.

minSdkVersion=11

Library Size ~ 12 Kb.

API Bintray

  
 

Download

add this line to build.gradle


dependencies {
        compile 'com.github.anastr:speedviewlib:1.0.9'
}

for maven

<dependency>
  <groupId>com.github.anastr</groupId>
  <artifactId>speedviewlib</artifactId>
  <version>1.0.9</version>
  <type>pom</type>
</dependency>

Usage

see The most important methods at Get Started - Wiki.
we have 5 views :

1st SpeedView

   

add SpeedView to your layout


<com.github.anastr.speedviewlib.SpeedView
        android:id="@+id/speedView"
        android:layout_width="250dp"
        android:layout_height="wrap_content" />

change the speed from your code :


SpeedView speedView = (SpeedView) findViewById(R.id.speedView);

// change speed to 50 Km/h
speedView.speedTo(50);

you can change max speed by this line (default : 100)

speedView.setMaxSpeed(220);

/** 
  * see also:
  * speedView.setWithTremble(false);
  * speedView.setIndicatorColor(Color.BLUE);
  * speedView.setHighSpeedColor(Color.RED);
  * .....
  */

2nd DeluxeSpeedView

SpeedView with Blur Effects.

 

add DeluxeSpeedView to your layout


<com.github.anastr.speedviewlib.DeluxeSpeedView
        android:id="@+id/deluxeSpeedView"
        android:layout_width="250dp"
        android:layout_height="wrap_content" />

the same methods in SpeedView

DeluxeSpeedView deluxeSpeedView = (DeluxeSpeedView) findViewById(R.id.deluxeSpeedView);

deluxeSpeedView.speedTo(50);

deluxeSpeedView.setMaxSpeed(220);

special methods for DeluxeSpeedView :

deluxeSpeedView.setWithEffects(false); //def : true

deluxeSpeedView.setSpeedBackgroundColor(Color.YELLOW);

3rd AwesomeSpeedometer

add AwesomeSpeedometer to your layout


<com.github.anastr.speedviewlib.AwesomeSpeedometer
        android:id="@+id/awesomeSpeedometer"
        android:layout_width="300dp"
        android:layout_height="wrap_content"
        app:speedometerWidth="75dp"
        app:indicatorWidth="35dp" />

the same methods in SpeedView

AwesomeSpeedometer awesomeSpeedometer = (AwesomeSpeedometer) findViewById(R.id.awesomeSpeedometer);

awesomeSpeedometer.speedTo(50);

awesomeSpeedometer.setMaxSpeed(220);

special methods for AwesomeSpeedometer :

awesomeSpeedometer.setIndicatorWidth(80); //def : 60dp

awesomeSpeedometer.setTrianglesColor(Color.YELLOW);
awesomeSpeedometer.setSpeedometerColor(Color.RED);

4th RaySpeedometer

add RaySpeedometer to your layout


<com.github.anastr.speedviewlib.RaySpeedometer
        android:id="@+id/raySpeedometer"
        android:layout_width="300dp"
        android:layout_height="wrap_content" />

the same methods in SpeedView.
special methods for RaySpeedometer :

raySpeedometer.setDegreeBetweenMark(3); //def : 5
raySpeedometer.setMarkWidth(2); //def : 3dp
raySpeedometer.setRayColor(Color.RED);

5th PointerSpeedometer

add PointerSpeedometer to your layout


<com.github.anastr.speedviewlib.PointerSpeedometer
        android:id="@+id/pointerSpeedometer"
        android:layout_width="300dp"
        android:layout_height="wrap_content" />

the same methods in SpeedView.
special methods for PointerSpeedometer :

pointerSpeedometer.setUnitTextSize(15); //def : 5dp
pointerSpeedometer.setPointerColor(Color.RED);

Attributes

and also you can change everything in XML, see this Attributes for all Speedometers :


app:unit="m/s" <!-- def : Km/h -->
app:maxSpeed="220" <!-- def : 100 -->
app:withTremble="false" <!-- def : true -->
app:withBackgroundCircle="false" <!-- def : true -->
app:speedometerWidth="35dp" <!-- def : 30dp -->
app:indicatorColor="#2b38e6" 
app:centerCircleColor="#b2f941ff" 
app:lowSpeedColor="#58ed21"
app:mediumSpeedColor="#edd029"
app:highSpeedColor="#ec2f33"
app:markColor="#99000000"
app:textColor="#e23900"
app:textColor="#84ff84"
app:speedTextColor="#000000"

Attributes for DeluxeSpeedView and RaySpeedometer :


app:withEffects="false" <!-- def : true -->
app:speedBackgroundColor="#000077"

Attributes just for AwesomeSpeedometer :


app:speedometerWidth="70dp" <!-- def : 60dp -->
app:indicatorWidth="#30dp" <!-- def : 25dp -->
app:speedometerColor="#ef3737"
app:trianglesColor="#25b9b4"

Attributes just for RaySpeedometer :


app:rayColor="#d8ff0000" <!-- def : WHITE -->
app:degreeBetweenMark="7" <!-- def : 5 -->
app:markWidth="5dp" <!-- def : 3dp -->

Attributes just for PointerSpeedometer :


app:speedometerColor="#ffb26b" <!-- def : #eeeeee -->
app:pointerColor="#ffff00" <!-- def : WHITE -->
app:unitTextSize="15dp" <!-- def : 11dp -->

Coming Soon ...

i well try to draw this Speedometer. if you have any idea, image, template please open new issue and give me the image , and i well try to add it to the Library.

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的 Android 速度仪表盘的代码示例,它使用 Android Sensor API 来监测加速度传感器和地球重力传感器的值,计算设备的速度并显示在屏幕上: ```java import android.app.Activity; import android.content.Context; import android.hardware.Sensor; import android.hardware.SensorEvent; import android.hardware.SensorEventListener; import android.hardware.SensorManager; import android.os.Bundle; import android.widget.TextView; public class SpeedometerActivity extends Activity implements SensorEventListener { private SensorManager sensorManager; private Sensor accelerometer; private Sensor gravity; private TextView speedView; private float[] lastAccelerometer = new float[3]; private float[] lastGravity = new float[3]; private long lastUpdateTime; private float currentSpeed = 0; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_speedometer); speedView = (TextView) findViewById(R.id.speedView); sensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE); accelerometer = sensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER); gravity = sensorManager.getDefaultSensor(Sensor.TYPE_GRAVITY); lastUpdateTime = System.currentTimeMillis(); } @Override protected void onResume() { super.onResume(); sensorManager.registerListener(this, accelerometer, SensorManager.SENSOR_DELAY_NORMAL); sensorManager.registerListener(this, gravity, SensorManager.SENSOR_DELAY_NORMAL); } @Override protected void onPause() { super.onPause(); sensorManager.unregisterListener(this); } @Override public void onSensorChanged(SensorEvent event) { if (event.sensor.getType() == Sensor.TYPE_ACCELEROMETER) { System.arraycopy(event.values, 0, lastAccelerometer, 0, 3); } else if (event.sensor.getType() == Sensor.TYPE_GRAVITY) { System.arraycopy(event.values, 0, lastGravity, 0, 3); } long currentTime = System.currentTimeMillis(); if ((currentTime - lastUpdateTime) > 100) { float[] rotationMatrix = new float[9]; float[] orientation = new float[3]; SensorManager.getRotationMatrix(rotationMatrix, null, lastGravity, lastAccelerometer); SensorManager.getOrientation(rotationMatrix, orientation); float pitch = orientation[1]; float speed = calculateSpeed(pitch); currentSpeed = (currentSpeed * 0.7f) + (speed * 0.3f); speedView.setText(String.format("%.1f km/h", currentSpeed)); lastUpdateTime = currentTime; } } @Override public void onAccuracyChanged(Sensor sensor, int accuracy) { // Do nothing } private float calculateSpeed(float pitch) { float gravity = 9.81f; float acceleration = (float) Math.sin(pitch) * gravity; return acceleration * 3.6f; } } ``` 在这个示例中,我们首先获取加速度传感器和地球重力传感器的引用,然后在 `onResume` 方法中注册这两个传感器的监听器。在 `onSensorChanged` 方法中,我们获取传感器事件的值,并使用这些值计算设备的速度。最后,我们将计算出的速度显示在屏幕上。当应用程序暂停时,我们在 `onPause` 方法中注销传感器的监听器。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值