COLOR的定義是采用ARGB的方式,以int型數字來表示。
Color.argb((int) 255, 32, 40, 50)
Alpha 是透明度,范圍: 0——255,位于int的高8位;(0是完全透明,255是完全不透明)
RED 是紅,范圍: 0——255,位于int的8-16位;
Green 是綠,范圍: 0——255,位于int的16-24位;
Blue 是透明度,范圍: 0——255,位于int的低8位
argb()方法的參數依次為透明度,紅,綠,藍的大小,可以理解為濃度,這里組合起來的就是黑色。
在程序中直接控制
setBackgroundColor(Color.argb((int) alpha, 32,40,50));
如果是直接在java代碼中定義。這里要注意哦。透明度不可以省去哦?。?!就像這樣0xFF080287,前面的0x代表16進制。
intmycolor = 0xff123456;
Button btn = (Button) findViewById(R.id.btn);
btn.setBackgroundColor(mycolor);
利用靜態方法argb來設置顏色:
Button btn = (Button) findViewById(R.id.btn);
btn.setBackgroundColor(Color.argb(0xff,0x00, 0x00,0x00));
這種方法必須使用0x開頭,而不是用我們常用的#。值也必須用8位表示 ,不接受6位的顏色表示。分組一下0x|ff|ff00ff,0x是代表顏色整數的標記,ff是表示透明度,ff00ff表示RGB顏色值
6位(#000000)就是RGB值
8位(#1e000000)ARGB 頭兩位是透明度,00是完全透明,ff是完全不透明,后6位是RGB值,
比較適中的透明度值是int color = Color.argb ( 127, 255, 0, 255 ); // 半透明的紫色
其中第一個參數表示透明,0表示完全透明,255(ff)表示完全不透明;后三位分別代表RGB的值了。
在滑動布局中標題欄背景色漸變實現
private void initListeners() {
// 獲取頂部輪播圖高度后,設置滾動監聽
ViewTreeObserver vto = banner.getViewTreeObserver();
vto.addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
@Override
public void onGlobalLayout() {
banner.getViewTreeObserver().removeGlobalOnLayoutListener(
this);
imageHeight = banner.getHeight();
scrollView.setScrollViewListener(new ObservableScrollview.ScrollViewListener() {
@Override
public void onScrollChanged(ObservableScrollview scrollView, int x, int y, int oldx, int oldy) {
// Log.i("TAG", "y--->" + y + " height-->" + height);
if (y <= 0) {
tv_title.setBackgroundColor(Color.argb((int) 0, 32, 40, 50));//AGB由相關工具獲得,或者美工提供
} else if (y > 0 && y <= imageHeight) {
float scale = (float) y / imageHeight;
float alpha = (255 * scale);
rl_title_bg.setBackgroundColor(Color.argb((int) alpha, 32,40,50));
} else {
// rl_title_bg.setBackgroundResource(R.mipmap.title_bg);
rl_title_bg.setBackgroundColor(Color.argb((int) 255, 32, 40, 50));
}
}
});
}
});
}