import android.widget.ProgressBar;
import android.graphics.drawable.GradientDrawable;
import android.graphics.drawable.ClipDrawable;
import android.view.Gravity;
import android.graphics.drawable.Drawable;
import android.graphics.drawable.LayerDrawable;
public void setColours(ProgressBar progressBar,
int bgCol1, int bgCol2,
int fg1Col1, int fg1Col2, int value1,
int fg2Col1, int fg2Col2, int value2)
{
//If solid colours are required for an element, then set
//that elements Col1 param s the same as its Col2 param
//(eg fg1Col1 == fg1Col2).
//fgGradDirection and/or bgGradDirection could be parameters
//if you require other gradient directions eg LEFT_RIGHT.
GradientDrawable.Orientation fgGradDirection
= GradientDrawable.Orientation.TOP_BOTTOM;
GradientDrawable.Orientation bgGradDirection
= GradientDrawable.Orientation.TOP_BOTTOM;
//Background
GradientDrawable bgGradDrawable = new GradientDrawable(
bgGradDirection, new int[]{bgCol1, bgCol2});
bgGradDrawable.setShape(GradientDrawable.RECTANGLE);
bgGradDrawable.setCornerRadius(5);
ClipDrawable bgclip = new ClipDrawable(
bgGradDrawable, Gravity.LEFT, ClipDrawable.HORIZONTAL);
bgclip.setLevel(10000);
//SecondaryProgress
GradientDrawable fg2GradDrawable = new GradientDrawable(
fgGradDirection, new int[]{fg2Col1, fg2Col2});
fg2GradDrawable.setShape(GradientDrawable.RECTANGLE);
fg2GradDrawable.setCornerRadius(5);
ClipDrawable fg2clip = new ClipDrawable(
fg2GradDrawable, Gravity.LEFT, ClipDrawable.HORIZONTAL);
//Progress
GradientDrawable fg1GradDrawable = new GradientDrawable(
fgGradDirection, new int[]{fg1Col1, fg1Col2});
fg1GradDrawable.setShape(GradientDrawable.RECTANGLE);
fg1GradDrawable.setCornerRadius(5);
ClipDrawable fg1clip = new ClipDrawable(
fg1GradDrawable, Gravity.LEFT, ClipDrawable.HORIZONTAL);
//Setup LayerDrawable and assign to progressBar
Drawable[] progressDrawables = {bgclip, fg2clip, fg1clip};
LayerDrawable progressLayerDrawable = new LayerDrawable(progressDrawables);
progressLayerDrawable.setId(0, android.R.id.background);
progressLayerDrawable.setId(1, android.R.id.secondaryProgress);
progressLayerDrawable.setId(2, android.R.id.progress);
//Copy the existing ProgressDrawable bounds to the new one.
Rect bounds = progressBar.getProgressDrawable().getBounds();
progressBar.setProgressDrawable(progressLayerDrawable);
progressBar.getProgressDrawable().setBounds(bounds);
// setProgress() ignores a change to the same value, so:
if (value1 == 0)
progressBar.setProgress(1);
else
progressBar.setProgress(0);
progressBar.setProgress(value1);
// setSecondaryProgress() ignores a change to the same value, so:
if (value2 == 0)
progressBar.setSecondaryProgress(1);
else
progressBar.setSecondaryProgress(0);
progressBar.setSecondaryProgress(value2);
//now force a redraw
progressBar.invalidate();
}
一个示例调用将是:
setColours(myProgressBar,
0xff303030, //bgCol1 grey
0xff909090, //bgCol2 lighter grey
0xff0000FF, //fg1Col1 blue
0xffFFFFFF, //fg1Col2 white
50, //value1
0xffFF0000, //fg2Col1 red
0xffFFFFFF, //fg2Col2 white
75); //value2
ProgressBar bar;
private Handler progressBarHandler = new Handler();
GradientDrawable progressGradientDrawable = new GradientDrawable(
GradientDrawable.Orientation.LEFT_RIGHT, new int[]{
0xff1e90ff,0xff006ab6,0xff367ba8});
ClipDrawable progressClipDrawable = new ClipDrawable(
progressGradientDrawable, Gravity.LEFT, ClipDrawable.HORIZONTAL);
Drawable[] progressDrawables = {
new ColorDrawable(0xffffffff),
progressClipDrawable, progressClipDrawable};
LayerDrawable progressLayerDrawable = new LayerDrawable(progressDrawables);
int status = 0;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// TODO Auto-generated method stub
setContentView(R.layout.startup);
bar = (ProgressBar) findViewById(R.id.start_page_progressBar);
bar.setProgress(0);
bar.setMax(100);
progressLayerDrawable.setId(0, android.R.id.background);
progressLayerDrawable.setId(1, android.R.id.secondaryProgress);
progressLayerDrawable.setId(2, android.R.id.progress);
bar.setProgressDrawable(progressLayerDrawable);
}
LayerDrawable progressBarDrawable = new LayerDrawable(
new Drawable[]{
new GradientDrawable(GradientDrawable.Orientation.TOP_BOTTOM,
new int[]{Color.parseColor("#ff0000ff"),Color.parseColor("#ff0000ff")}),
new ClipDrawable(
new GradientDrawable(GradientDrawable.Orientation.TOP_BOTTOM,
new int[]{Color.parseColor("#ff00ff00"),Color.parseColor("#ff00ff00")}),
Gravity.START,
ClipDrawable.HORIZONTAL),
new ClipDrawable(
new GradientDrawable(GradientDrawable.Orientation.TOP_BOTTOM,
new int[]{Color.parseColor("#ffff0000"),Color.parseColor("#ffff0000")}),
Gravity.START,
ClipDrawable.HORIZONTAL)
});
progressBarDrawable.setId(0,android.R.id.background);
progressBarDrawable.setId(1,android.R.id.secondaryProgress);
progressBarDrawable.setId(2,android.R.id.progress);
((ProgressBar)findViewById(R.id.progressBar)).setProgressDrawable(progressBarDrawable);
30 回答
我'm sorry that it'不是答案,但是什么推动了从代码设置它的要求?如果正确定义,
.setProgressDrawable
应该可以正常工作在修改默认进度条的外观时遇到同样的问题 . 这里有一些有希望帮助人们的信息:)
xml文件的名称必须只包含字符:
a-z0-9_.
(即没有大写字母!)要引用你的"drawable",它是
R.drawable.filename
要覆盖默认外观,请使用
myProgressBar.setProgressDrawable(...)
,但是您需要不能仅将自定义布局称为R.drawable.filename
,需要将其检索为Drawable
:对于水平ProgressBar,您也可以使用
ColorFilter
,如下所示:Note: 这会修改应用中所有进度条的外观 . 要仅修改一个特定的进度条,请执行以下操作:
如果progressBar不确定,则使用
getIndeterminateDrawable()
而不是getProgressDrawable()
.从Lollipop(API 21)开始,您可以设置进度色调:
对于我的不确定进度条(微调器),我只是在drawable上设置了一个颜色过滤器 . 效果很好而且只有一条线 .
将颜色设置为红色的示例:
这不是以编程方式,但我认为它可以帮助很多人!我尝试了很多,最有效的方法是将这些行添加到.xml文件中的ProgressBar中:
所以最后这段代码为我做了:
此解决方案适用于 API 21+
这是一个老问题,但这里没有提到使用主题 . 如果你的默认主题是使用
AppCompat
,你的ProgressBar
的颜色将是你定义的colorAccent
.更改
colorAccent
也会更改ProgressBar
的颜色,但是更改也会反映在多个位置 . 所以,如果你想为特定的PregressBar
想要一种不同的颜色,你可以通过将主题应用于ProgressBar
来实现:colorAccent
ProgressBar
中添加android:theme
属性:所以它看起来像这样:
因此,您只需为您的特定
ProgressBar
更改colorAccent
.Note :使用
style
将无效 . 您只需要使用android:theme
. 你可以在这里找到更多主题:https://plus.google.com/u/0/+AndroidDevelopers/posts/JXHKyhsWHAH根据一些建议,您可以指定一个形状并使用颜色进行剪裁,然后进行设置 . 我以编程方式工作 . 这是我怎么做的..
首先确保导入drawable库..
import android.graphics.drawable.*;
然后使用类似下面的代码;
如果不确定:
这对我有用:
如今在2016年我发现一些前Lollipop设备不符合
colorAccent
设置,因此我对所有API的最终解决方案现在如下:对于奖励积分,它不使用任何弃用的代码 . 试试吧!
在这个答案中可能有一件事没有提到:
如果您的主题继承自
Theme.AppCompat
,则ProgressBar
将假定您在主题中定义为"colorAccent"
的颜色 .所以,使用..
..将自动调整ProgressBar的颜色到
@color/custom_color
.我是如何在水平ProgressBar中完成的:
您可以尝试更改样式,主题或使用android:indeterminateTint =“@ color / yourColor”在任何地方,但只有一种方法可以在任何Android SKD版本上使用:
如果进度条不是不确定的,请使用:
如果进度条不确定,请使用:
Android真是太乱了!
这就是我所做的 . 工作 .
ProgressBar:
progressdrawable.xml:
这里使用渐变来根据需要改变颜色 . 并且android:toDegrees = "X"增加X的值并且进度条快速旋转 . 减少并且旋转缓慢 . 根据您的需要定制 .
sample:
这个解决方案对我有用:
最简单的解决方案如果要更改布局xml文件中的颜色,请使用以下代码并使用 indeterminateTint 属性作为所需颜色 .
All API
如果使用所有API只是在样式中创建主题
style.xml
并在使用过程中
API level 21 and higher
如果在API级别21及更高版本中使用,只需使用此代码:
还有一点,主题解决方案确实有效,如果你继承了一个基本主题,那么对于app compact,你的主题应该是:
然后在进度条主题中设置它
对于水平样式ProgressBar,我使用:
一个示例调用将是:
如果您不需要“二次进度”,只需将value2设置为value1 .
使用android.support.v4.graphics.drawable.DrawableCompat:
发布添加关于PaulieG's answer的信息,因为ateiob让我解释一下......
我可以说
ProgressBar
代码中的错误/问题/优化忽略了将进度设置为值的尝试(或者至少在编写本文时,我查看了当前版本的Android源代码)它已经在了 .调用
ProgressBar.setProgressDrawable()
后,您的进度条将为空(因为您更改了可绘制部分) .这意味着您需要设置进度并重新绘制 . 但是,如果您只是将进度设置为保留值,它将不执行任何操作 .
您必须先将其设置为0,然后再将其设置为“旧”值,并且该栏将重绘 .
总结一下:
保留"old"进度值
更新drawable / color(使条形空白)
将进度重置为0(否则下一行不执行任何操作)
将进度重置为"old"值(修复栏)
无效
以下是我的方法:
至于HappyEngineer的解决方案,我认为这是一个类似的解决方法,手动设置“进度”偏移量 . 无论哪种情况,上述代码都适合您 .
这有助于我通过代码为进度条设置自定义颜色 . 希望能帮助到你
将此自定义样式应用于进度栏 .
@ drawable / progress.xml -
将此类图像用于进度条 .
为获得更好的效果,您可以使用多个进度图像请不要犹豫使用图像,因为Android平台本身使用图像进行处理 . 代码是从sdk中提取的:)
根据muhammad-adil建议使用SDK ver 21及更高版本
在XML中为我工作,很容易 .
使用attr非常简单,如果你正在处理multistyle应用程序:
试试这种方式:
在属性attrs.xml下面声明
粘贴到styles.xml中的代码下面
使用下面的进度条
以下是以编程方式更改ProgressBar颜色的代码 .
Horizontal ProgressBar
使用rectangle shape
drawable作为背景,ClipDrawable
使用rectangle shape
构建进度(主要和次要) . 着色将颜色更改为某些色调 . 分别为 If you want targeted colors 所有三个,您可以使用ProgressBar.setProgressDrawable()
如下:请注意,初始化
LayerDrawable
时,可绘制层的顺序很重要 . 第一个drawable应该是背景 . 根据我的实验,切换ID不起作用 . 如果将填充设置为progressbar
,则此方法将不起作用 . 如果需要填充,则可以使用容器作为进度条,例如LinearLayout
.Horizontal progress bar custom material style :
要更改背景颜色和水平进度条的进度 .
通过设置样式属性将其应用于进度条,对于自定义材质样式和自定义进度条检查http://www.zoftino.com/android-progressbar-and-custom-progressbar-examples