1、在看火种通讯录的联系人界面,导航条:A,B,C....不随滚动也移动。研究了如何制作该效果:
利用FrameLayout布局
FrameLayout是最简单的一个布局对象。它被定制为你屏幕上的一个空白备用区域,之后你可以在其中填充一个单一对象 — 比如,一张你要发布的图片。所有的子元素将会固定在屏幕的左上角;你不能为FrameLayout中的一个子元素指定一个位置。后一个子元素将会直接在前 一个子元素之上进行覆盖填充,把它们部份或全部挡住(除非后一个子元素是透明的)。
简单:FrameLayout中的元素是一层层叠加...
导航条的制作:自定义控件,根据每个字母的高度,将每个字母画上去。
//导航条控件
public class ContactLetter extends View
{
public ContactLetter(Context context)
{
super(context);
}
public ContactLetter(Context context, AttributeSet attrs)
{
super(context, attrs);
}
@Override
protected void onDraw(Canvas canvas)
{
//画每个字母
super.onDraw(canvas);
Paint paint = new Paint();
paint.setAntiAlias(true);
paint.setColor(Color.GRAY);
float middle_h = middle_view.getHeight() - logolayout.getHeight() - (phone_but.getHeight() * 2) - 14;
font_h = middle_h / keywords.length;
paint.setTextSize(font_h);
paint.setColor(Color.rgb(128, 141, 167));
for (int i = 0; i < keywords.length; i++)
{
float font_w = paint.measureText(keywords[i]);// 字体的宽度
canvas.drawText(keywords[i], start_x - font_w / 2, font_h * (i + 1), paint);
}
}
}
2、如何响应每个字母的按键:
自定义一个监听器,根据MotionEvent event中的event.getX(),event.getY(),根据坐标来定位是哪个字母。
phone_layout = (LinearLayout) findViewById(R.id.keyword_phone_layout);
phone_layout.addView(new HBContactLetter(context));
phone_layout.setOnTouchListener(touchlis_letter);
private OnTouchListener touch_letter = new OnTouchListener()
{
@Override
public boolean onTouch(View v, MotionEvent event)
{
float x1 = event.getX();
float y1 = event.getY();
if (event.getAction() == MotionEvent.ACTION_DOWN)
{
for (int i = 0; i < keywords.length; i++)
{
if (((x1 >= 0) && (x1 < 40)) && (y1 >= (font_h * i) && y1 < (font_h * (i + 1))))
{
mDialogText.setText(keywords[i]);
mDialogText.setVisibility(View.VISIBLE);
if (phone_isDispaly)
{
int index = getSelIndex_Phone(keywords[i]);
if (index != -1 && (index + 1) < group.size())
{
phone_listview.setSelection(index + 1);
}
}
3、android:layout_gravity是本元素对父元素的重力方向。
android:gravity是本元素所有子元素的重力方向。