gpt4 book ai didi

android - 在Android中实现类似于iOS的旋转 Activity 指示器

转载 作者:塔克拉玛干 更新时间:2023-11-02 08:29:51 24 4
gpt4 key购买 nike

我正在尝试实现类似于我在 Android 中放置的旋转 Activity 。我相信我应该使用 ProgressDialog。我的问题源于如何实际操作 ProgressDialog 使其看起来像 Activity 指示器。

欢迎任何想法。指向示例的链接甚至会更好。

谢谢。 enter image description here

重新编辑:

我的进程.java

public class myProgress extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);

ProgressDialog d = (ProgressDialog)findViewById(R.id.progres);

主.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/progres"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="center"
>
<ProgressBar
android:id="@+id/progressBar"
android:indeterminate="true"
style="?android:attr/progressBarStyleLarge"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
/>
</RelativeLayout>

最佳答案

我编写了自己的自定义 LoadingIndicatorView。

它由两个文件组成:

  • LoadingIndicatorBarView
  • LoadingIndicatorView

优点:

  • 以编程方式创建,没有 PNG 滑稽 Action ,意味着可扩展和清晰 :D
  • 可自定义的条形颜色和圆角半径(如果你理解我的代码)

缺点:

  • 性能不如 iOS 版本(我只是一个有 iOS 背景的 Android 开发新手,你期望什么?):P

免责声明:

  • 如果您的项目失败了,请不要怪我,我将其作为免费的公共(public)领域代码。

您会注意到我的编码风格和结构与我的 iOS 编程代码非常相似。我以编程方式执行所有操作,如果可以的话,我不使用 XML。

如何使用此加载指示器

将所有三个类的源代码复制并粘贴到它们的 Java 文件中后,您想要使用 LoadingIndicatorView 类,您不需要接触其他类,除非您想要自定义每个栏的颜色或圆角。

在您的 Activity 中创建一个 LoadingIndicatorView 实例:

import com.companyName.myApplication.views.LoadingIndicatorView;

public class MyActivity extends AppCompatActivity
{
public mainLayout RelativeLayout;
...
public LoadingIndicatorView loadingIndicator;

@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);

initViews();
initLayouts();
addViews();
}

public void initViews()
{
mainLayout = new RelativeLayout(this);
mainLayout.setBackgroundColor(Color.BLACK);

...

// ---------------------------------------------------
// 40 here is the radius of the circle
// try and use multiples of 2, e.g. 40, 60, 80 etc
// ---------------------------------------------------
loadingIndicator = new LoadingIndicatorView(this, 40);

// hide until ready to start animating
loadingIndicator.setAlpha(0.0f);
}

public void initLayouts()
{
...

// Need API level 17 for this, set in your AndroidManifeset.xml
mainLayout.setId(View.generateViewId());
loadingIndicator.setId(View.generateViewId());

RelativeLayout.LayoutParams loadingIndicatorLayoutParams = new RelativeLayout.LayoutParams(
(int)(loadingIndicator.radius * 2.0f),
(int)(loadingIndicator.radius * 2.0f)
);

loadingIndicatorLayoutParams.addRule(RelativeLayout.CENTER_IN_PARENT);

loadingIndicator.setLayoutParams(loadingIndicatorLayoutParams);
}

public void addViews()
{
...

mainLayout.addView(loadingIndicator);

setContentView(mainLayout);
}
}

一旦您准备好展示它,例如在按钮点击监听器中,然后你调用:

loadingIndicator.startAnimating();

当你想停止并隐藏指示器时,调用:

loadingIndicator.stopAnimating();

你最终得到这样的结果:

loading indicator screenshot

LoadingIndicatorView.java

package com.companyName.myApplication.views;

import android.app.Activity;
import android.content.Context;
import android.graphics.Color;
import android.graphics.ColorFilter;
import android.graphics.PorterDuff;
import android.os.CountDownTimer;
import android.os.Handler;
import android.os.Looper;
import android.util.Log;
import android.view.View;
import android.view.animation.RotateAnimation;
import android.widget.RelativeLayout;

import java.lang.reflect.Array;
import java.util.ArrayList;
import java.util.Timer;
import java.util.TimerTask;

/**
* Created by Zhang on 11/02/16.
*/
public class LoadingIndicatorView extends RelativeLayout
{
private Context context;

private int numberOfBars;

public ArrayList<LoadingIndicatorBarView> arrBars;

public float radius;

private boolean isAnimating;
private int currentFrame;

private final Handler handler = new Handler();
private Runnable playFrameRunnable;

public LoadingIndicatorView(Context context, float radius)
{
super(context);

this.context = context;
this.radius = radius;
this.numberOfBars = 12;

initViews();
initLayouts();
addViews();
spreadBars();
}

public void initViews()
{
arrBars = new ArrayList<LoadingIndicatorBarView>();

for(int i = 0; i < numberOfBars; i++)
{
LoadingIndicatorBarView bar = new LoadingIndicatorBarView(context, radius / 10.0f);

arrBars.add(bar);
}
}

public void initLayouts()
{
for(int i = 0; i < numberOfBars; i++)
{
LoadingIndicatorBarView bar = arrBars.get(i);

bar.setId(View.generateViewId());

RelativeLayout.LayoutParams barLayoutParams = new RelativeLayout.LayoutParams(
(int)(radius / 5.0f),
(int)(radius / 2.0f)
);

barLayoutParams.addRule(ALIGN_PARENT_TOP);
barLayoutParams.addRule(CENTER_HORIZONTAL);

bar.setLayoutParams(barLayoutParams);
}
}

public void addViews()
{
for(int i = 0; i < numberOfBars; i++)
{
LoadingIndicatorBarView bar = arrBars.get(i);

addView(bar);
}
}

public void spreadBars()
{
int degrees = 0;

for(int i = 0; i < arrBars.size(); i++)
{
LoadingIndicatorBarView bar = arrBars.get(i);

rotateBar(bar, degrees);

degrees += 30;
}
}

private void rotateBar(LoadingIndicatorBarView bar, float degrees)
{
RotateAnimation animation = new RotateAnimation(0, degrees, radius / 10.0f, radius);
animation.setDuration(0);
animation.setFillAfter(true);

bar.setAnimation(animation);
animation.start();
}

public void startAnimating()
{
setAlpha(1.0f);

isAnimating = true;

playFrameRunnable = new Runnable()
{
@Override
public void run()
{
playFrame();
}
};

// recursive function until isAnimating is false
playFrame();
}

public void stopAnimating()
{
isAnimating = false;

setAlpha(0.0f);

invalidate();

playFrameRunnable = null;
}

private void playFrame()
{
if(isAnimating)
{
resetAllBarAlpha();
updateFrame();

handler.postDelayed(playFrameRunnable, 0);
}
}

private void updateFrame()
{
if (isAnimating)
{
showFrame(currentFrame);
currentFrame += 1;

if (currentFrame > 11)
{
currentFrame = 0;
}
}
}

private void resetAllBarAlpha()
{
LoadingIndicatorBarView bar = null;

for (int i = 0; i < arrBars.size(); i++)
{
bar = arrBars.get(i);

bar.setAlpha(0.5f);
}
}

private void showFrame(int frameNumber)
{
int[] indexes = getFrameIndexesForFrameNumber(frameNumber);

gradientColorBarSets(indexes);
}

private int[] getFrameIndexesForFrameNumber(int frameNumber)
{
if(frameNumber == 0)
{
return indexesFromNumbers(0, 11, 10, 9);
}
else if(frameNumber == 1)
{
return indexesFromNumbers(1, 0, 11, 10);
}
else if(frameNumber == 2)
{
return indexesFromNumbers(2, 1, 0, 11);
}
else if(frameNumber == 3)
{
return indexesFromNumbers(3, 2, 1, 0);
}
else if(frameNumber == 4)
{
return indexesFromNumbers(4, 3, 2, 1);
}
else if(frameNumber == 5)
{
return indexesFromNumbers(5, 4, 3, 2);
}
else if(frameNumber == 6)
{
return indexesFromNumbers(6, 5, 4, 3);
}
else if(frameNumber == 7)
{
return indexesFromNumbers(7, 6, 5, 4);
}
else if(frameNumber == 8)
{
return indexesFromNumbers(8, 7, 6, 5);
}
else if(frameNumber == 9)
{
return indexesFromNumbers(9, 8, 7, 6);
}
else if(frameNumber == 10)
{
return indexesFromNumbers(10, 9, 8, 7);
}
else
{
return indexesFromNumbers(11, 10, 9, 8);
}
}

private int[] indexesFromNumbers(int i1, int i2, int i3, int i4)
{
int[] indexes = {i1, i2, i3, i4};
return indexes;
}

private void gradientColorBarSets(int[] indexes)
{
float alpha = 1.0f;

LoadingIndicatorBarView barView = null;

for(int i = 0; i < indexes.length; i++)
{
int barIndex = indexes[i];

barView = arrBars.get(barIndex);


barView.setAlpha(alpha);
alpha -= 0.125f;
}

invalidate();
}
}

LoadingIndicatorBarView.java

package com.companyName.myApplication.views;

import android.content.Context;
import android.graphics.Color;
import android.widget.RelativeLayout;

import com.companyName.myApplication.helper_classes.ToolBox;

/**
* Created by Zhang on 11/02/16.
*/
public class LoadingIndicatorBarView extends RelativeLayout
{
private Context context;
private float cornerRadius;

public LoadingIndicatorBarView(Context context, float cornerRadius)
{
super(context);

this.context = context;
this.cornerRadius = cornerRadius;

initViews();
}

public void initViews()
{
setBackground(ToolBox.roundedCornerRectWithColor(
Color.argb(255, 255, 255, 255), cornerRadius));

setAlpha(0.5f);
}

public void resetColor()
{
setBackground(ToolBox.roundedCornerRectWithColor(
Color.argb(255, 255, 255, 255), cornerRadius));

setAlpha(0.5f);
}
}

工具箱.java

package com.companyName.myApplication.helper_classes;

import android.content.Context;
import android.content.res.Configuration;
import android.content.res.Resources;
import android.graphics.Paint;
import android.graphics.drawable.ShapeDrawable;
import android.graphics.drawable.shapes.RoundRectShape;

/**
* Created by Zhang on 3/02/16.
*/
public class ToolBox
{
private static ToolBox instance;
public Context context;

private ToolBox()
{

}

public synchronized static ToolBox getInstance()
{
if(instance == null)
{
instance = new ToolBox();
}

return instance;
}

public static ShapeDrawable roundedCornerRectOutlineWithColor(int color, float cornerRadius,
float strokeWidth)
{
float[] radii = new float[] {
cornerRadius, cornerRadius,
cornerRadius, cornerRadius,
cornerRadius, cornerRadius,
cornerRadius, cornerRadius
};

RoundRectShape roundedCornerShape = new RoundRectShape(radii, null, null);

ShapeDrawable shape = new ShapeDrawable();
shape.getPaint().setColor(color);
shape.setShape(roundedCornerShape);
shape.getPaint().setStrokeWidth(strokeWidth);
shape.getPaint().setStyle(Paint.Style.STROKE);

return shape;
}

public static ShapeDrawable roundedCornerRectWithColor(int color, float cornerRadius)
{
float[] radii = new float[] {
cornerRadius, cornerRadius,
cornerRadius, cornerRadius,
cornerRadius, cornerRadius,
cornerRadius, cornerRadius
};

RoundRectShape roundedCornerShape = new RoundRectShape(radii, null, null);

ShapeDrawable shape = new ShapeDrawable();
shape.getPaint().setColor(color);
shape.setShape(roundedCornerShape);

return shape;
}

public static ShapeDrawable roundedCornerRectWithColor(int color, float topLeftRadius, float
topRightRadius, float bottomRightRadius, float bottomLeftRadius)
{
float[] radii = new float[] {
topLeftRadius, topLeftRadius,
topRightRadius, topRightRadius,
bottomRightRadius, bottomRightRadius,
bottomLeftRadius, bottomLeftRadius
};

RoundRectShape roundedCornerShape = new RoundRectShape(radii, null, null);

ShapeDrawable shape = new ShapeDrawable();
shape.getPaint().setColor(color);
shape.setShape(roundedCornerShape);

return shape;
}

public static int getScreenWidth()
{
return Resources.getSystem().getDisplayMetrics().widthPixels;
}

public static int getScreenHeight()
{
return Resources.getSystem().getDisplayMetrics().heightPixels;
}

public static int getScreenOrientation(Context context)
{
return context.getResources().getConfiguration().orientation;
}

public static boolean isLandscapeOrientation(Context context)
{
return getScreenOrientation(context) == Configuration.ORIENTATION_LANDSCAPE;
}

}

这个工具箱类是我的便利助手类,用于在我的所有项目中创建圆角形状等。

希望对你有帮助:D

关于android - 在Android中实现类似于iOS的旋转 Activity 指示器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7228783/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com