我在做一个新闻客户端的时候发现,当新闻内容(ViewPage)滑动的时候虽然设置了新闻分类(HorizontalScrollView + RadioGroup)会自动选中当前内容的分类,但是超出屏幕后,不能将选中的分类限制显示在屏幕内(也就是将选中的item移动回屏幕中)。
所以,上效果图感受一下:
代码也很简单,供大家参考,如果有更好的方案请指教。
HorizontalScrollView + RadioGroup(RadioButton)
大概就是获取item的X坐标,然后判断当前坐标 + item宽度是否大于屏幕,超出了则移动HorizontalScrollView的位置到item X坐标的位置,否则则返回到原始坐标0的位置。
screenWidth = mContext.getResources().getDisplayMetrics().widthPixels;//获取屏幕宽度
/**
* 滑动到item的焦点处
*/
private void scrollToFocus() {
//获取滑动列表中的子控件(RadioGroup)选中的View
View item = findViewById(rgLayoutView.getCheckedRadioButtonId());
//选中item(View)的X坐标
int x = (int) item.getX();
/* item坐标是否小于屏幕,大于屏幕则将HorizontalScrollView滑动到item的X坐标位置,否则重置
x坐标 + view的宽度是为了防止当前view的一半位置小于屏幕而不自动滑动 */
if( x + item.getWidth() < screenWidth ) { x = 0; }
//滑动HorizontalScrollView
smoothScrollTo(x, (int) getY());
}
接下来就是监听RadioGroup中的RadioButton发生改变后调用就行了
/**
* 设置子项选中事件监听器
* @param mItemSelectedListener 子项选中事件监听器
*/
public void setOnItemSelectedListener(final OnItemSelectedListener mItemSelectedListener) {
rgLayoutView.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(RadioGroup radioGroup, int i) {
scrollToFocus();//滑动到item的焦点处
}
});
}
主要是做个标记,因为我懒得想然后度娘,发现度娘并没有我想要的。。。然后就发了这个文章。。。