Android 自定义加载微调器图标
我使用以下布局实现了加载微调器图标:Android 自定义加载微调器图标,android,android-layout,android-spinner,android-xml,Android,Android Layout,Android Spinner,Android Xml,我使用以下布局实现了加载微调器图标: <RelativeLayout android:id="@+id/spinner" android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center_horizontal" android:layout_marginTop="50dp"> <ProgressBar
<RelativeLayout
android:id="@+id/spinner"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center_horizontal"
android:layout_marginTop="50dp">
<ProgressBar
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:indeterminate="true"
/>
</RelativeLayout>
但它使用默认的Android微调器。我想用我从中获得的加载图标替换微调器,该图标如下所示:
如何使用此自定义微调器替换默认的Android微调器?我建议利用。老实说,你的纺纱机并没有那么酷,使它成为1比1 如果找不到正常的解决方案。你可以提出你的观点
class DrawThread extends Thread{
private boolean runFlag = false;
private SurfaceHolder surfaceHolder;
private Bitmap picture;
private Matrix matrix;
private long prevTime;
public DrawThread(SurfaceHolder surfaceHolder, Resources resources){
this.surfaceHolder = surfaceHolder;
picture = BitmapFactory.decodeResource(resources, R.drawable.spinner);
matrix = new Matrix();
matrix.postScale(3.0f, 3.0f);
matrix.postTranslate(100.0f, 100.0f);
prevTime = System.currentTimeMillis();
}
public void setRunning(boolean run) {
runFlag = run;
}
@Override
public void run() {
Canvas canvas;
while (runFlag) {
long now = System.currentTimeMillis();
long elapsedTime = now - prevTime;
if (elapsedTime > 30){
prevTime = now;
matrix.preRotate(2.0f, picture.getWidth() / 2, picture.getHeight() / 2);
}
canvas = null;
try {
canvas = surfaceHolder.lockCanvas(null);
synchronized (surfaceHolder) {
canvas.drawColor(Color.BLACK);
canvas.drawBitmap(picture, matrix, null);
}
}
finally {
if (canvas != null) {
surfaceHolder.unlockCanvasAndPost(canvas);
}
}
}
}
}
public class MySurfaceView extends SurfaceView implements SurfaceHolder.Callback {
private DrawThread drawThread;
public MySurfaceView(Context context) {
super(context);
getHolder().addCallback(this);
}
@Override
public void surfaceChanged(SurfaceHolder holder, int format, int width,
int height) {
}
@Override
public void surfaceCreated(SurfaceHolder holder) {
drawThread = new DrawThread(getHolder(), getResources());
drawThread.setRunning(true);
drawThread.start();
}
@Override
public void surfaceDestroyed(SurfaceHolder holder) {
boolean retry = true;
drawThread.setRunning(false);
while (retry) {
try {
drawThread.join();
retry = false;
} catch (InterruptedException e) {
}
}
}
}
这是我在项目中使用的:
<ProgressBar
android:id="@+id/updateProgressBar"
android:layout_width="40dp"
android:layout_height="40dp"
android:drawingCacheQuality="high"
android:indeterminateDuration="2000"
android:indeterminateDrawable="@drawable/splash_spinner"
/>
只需使用自定义图像覆盖
不可定义的
如果要使PNG图像旋转并充当进度条,只需创建一个旋转
布局并在该布局上插入PNG即可
在res
->drawable
内部,创建一个名为rotate.xml
的新文件
<rotate xmlns:android="http://schemas.android.com/apk/res/android"
android:drawable="@drawable/pokeball" <--Insert your image here
android:fillAfter="false"
android:fromDegrees="0"
android:interpolator="@android:anim/linear_interpolator"
android:pivotX="50%"
android:pivotY="50%"
android:repeatCount="infinite"
android:startOffset="0"
android:toDegrees="718" />
有助于u@Naveentamakar,但没有帮助。我看不到设置自定义加载图像的选项。如何使其旋转?你会用GIF吗?它自己旋转。您只需要一个简单的png,ProgressBar负责旋转
<ProgressBar
android:id="@+id/progress_bar"
android:layout_width="16dp"
android:layout_height="16dp"
android:layout_margin="16dp"
android:alpha="0.5"
android:indeterminateDrawable="@drawable/rotate"
android:visibility="gone"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="parent" />