以下に示すように、シークバーに効果を適用したいと思います。
私が試したことは以下の通りです。完全なコードは以下のとおりです。試してみて、以下のような効果が得られるかどうかをお知らせください。
MainActivity.java
public class MainActivity extends Activity
{
private static int myProgress=0;
private SeekBar seekBar;
private int progressStatus=0;
private Handler myHandler=new Handler();
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.h_processbar);
}
public void beginYourTask(View view)
{
myProgress=0;
seekBar= (SeekBar)findViewById(R.id.seekBar);
seekBar.setMax(100);
new Thread(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
while(progressStatus<100)
{
progressStatus=performTask();
myHandler.post(new Runnable()
{
public void run() {
seekBar.setProgress(progressStatus);
}
});
}
myHandler.post(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
Toast.makeText(getBaseContext(),"Task Completed",Toast.LENGTH_LONG).show();
progressStatus=0;
myProgress=0;
}
});
}
private int performTask()
{
try {
//---Do some task---
Thread.sleep(100);
} catch (InterruptedException e)
{
e.printStackTrace();
}
return ++myProgress;
}
}).start();
}
}
progress_horizontal_green.xml
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@android:id/background">
<shape>
<corners android:radius="5dip" />
<gradient
android:startColor="#ff9d9e9d"
android:centerColor="#ff5a5d5a"
android:centerY="0.75"
android:endColor="#ff747674"
android:angle="270"
/>
</shape>
</item>
<item android:id="@android:id/secondaryProgress">
<clip>
<shape>
<corners android:radius="5dip" />
<gradient
android:startColor="#80ffd300"
android:centerColor="#80ffb600"
android:centerY="0.75"
android:endColor="#a0ffcb00"
android:angle="270"
/>
</shape>
</clip>
</item>
<item android:id="@android:id/progress">
<clip>
<shape>
<corners android:radius="5dip" />
<gradient
android:startColor="#ff54e854"
android:centerColor="#ff004900"
android:endColor="#ff54e854"
android:angle="90"
/>
</shape>
</clip>
</item>
</layer-list>
h_processbar.xml
<Button
android:id="@+id/button1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="beginYourTask"
android:text="Start Task"
android:textColor="#ffffff"
android:layout_margin="10dp"/>
<LinearLayout
android:layout_width="290dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginTop="30dp"
>
<SeekBar
android:id="@+id/seekBar"
android:max="100"
android:progress="60"
android:layout_width="260dp"
android:layout_height="wrap_content"
android:thumb="@drawable/down_arrow_new"
android:progressDrawable="@drawable/progress_horizontal_green"
android:layout_margin="20dp"
/>
</LinearLayout>
down_arrow_new.pngはこちら ダウンロード...
図LHS (左側) に示すように、濃い緑色から始まり、進行するにつれて、薄緑色の色合いとぼかし効果の組み合わせのように見えます。
ぼかし効果がこれを素晴らしいものにします。
どうすればこれを達成できますか?何か考えはありますか?
どんな助けでも大歓迎です。
ありがとうございました。