このリンクに示されているように、動的ビューでViewPagerを使用しています。各ページをビューページャーに追加しています。各ページを作成してページャーアダプタに追加するためのコードは次のとおりです。
public View createPage( )
{
TableLayout table = new TableLayout(mycontext);
TableRow row = new TableRow(mycontext);
for(int i=0; i <= num_of_views; i++)
{
TableLayout catTable = new TableLayout(mycontext);
TableLayout.LayoutParams params = new TableLayout.LayoutParams();
params.height = LayoutParams.MATCH_PARENT;
TableRow catName = new TableRow(mycontext);
catName.setGravity(0x03);
catName.setLayoutParams(params);
TextView cat = new TextView(mycontext);
TableRow.LayoutParams RowParams=
new TableRow.LayoutParams(pixeltoDp(0),pixeltoDp(85));
RowParams.weight = 1;
cat.setLayoutParams(RowParams);
cat.setPadding(35, 0, 5, 0);
cat.setGravity(0x13);
cat.setSingleLine(true);
cat.setHorizontallyScrolling(true);
cat.setFocusable(true);
cat.setFocusableInTouchMode(true);
cat.setLines(1);
cat.setText(data.getCats().get(i).getName());
cat.setTextColor(color);
cat.setSelected(true);
catName.addView(cat);
catTable.addView(catName);
for(int j=0; j < 5; j++)
{
TableRow trChild = new TableRow(mycontext);
trChild.setLayoutParams(params);
trChild.setGravity(0x11);
for (int k=0; k<4; k++)
{
TextView app = new TextView(mycontext);
TableRow.LayoutParams tableRowParams=
new TableRow.LayoutParams(pixeltoDp(0),pixeltoDp(80));
margin = pixeltoDp(11);
tableRowParams.weight = 1;
app.setLayoutParams(tableRowParams);
app.setGravity(0x11);
app.setSingleLine(true);
app.setTextSize(pixeltoDp(12));
app.setTextColor(Color.BLACK);
app.setTypeface(verdana);
int pos = j+(k*5);
if((pos < mysize))
{
Drawable icon = getMyDrawable();
app.setCompoundDrawablesWithIntrinsicBounds(null, icon, null, null);
app.setText("some Name");
app.setTag(i+":"+pos);
app.setEllipsize(TextUtils.TruncateAt.END);
app.setOnClickListener(onMyClick);
}
trChild.addView(app);
}
catTable.addView(trChild);
}
TableRow.LayoutParams tableRowParams=
new TableRow.LayoutParams
(TableRow.LayoutParams.MATCH_PARENT,TableRow.LayoutParams.WRAP_CONTENT);
margin = pixeltoDp(5);
tableRowParams.setMargins(margin,0,margin, pixeltoDp(18));
catTable.setLayoutParams(tableRowParams);
}
row.setGravity(0x03);
table.addView(row);
return table;
}
ページ内のテキストビューのOnClickListenerは次のとおりです。
private View.OnClickListener onAppClick=new View.OnClickListener() {
public void onClick(View v) {
// TODO Auto-generated method stub
String gettext = (String)v.getTag();
String[] splittext = gettext.split(":");
Log.d("TAG","Click Event is Triggered");
}
};
私が直面している問題は、画面をスワイプするとビューページャーがスライドすることですが、onclicklistenerを使用してテキストからスワイプを開始すると、ページがスライドせず、クリックイベントも呼び出されません。テキストビューをクリックすると、クリックイベントが呼び出されます。クリックイベントを使用してテキストビューからスワイプを開始した場合に、ビューページャーがページをめくらない理由がわかりません。
バグの理由を見つけるために、ビューページャーにontouchlistenerを追加しました。テキストビューがなく、タッチイベントが呼び出されないページの部分でスワイプが発生すると、ビューページャーのタッチイベントが呼び出されることがわかりました。スワイプがテキストビューの上から始まる場合はすべて。textviewのonclicklistenerを削除すると、ビューページャー全体が問題なく正しく反転します。したがって、問題は、テキストビューのクリックイベントがビューページャーのタッチイベントを停止していることです。作成ページのコードで何か問題が発生したかどうかを教えてください。この関数で作成したビューは、最初に説明したチュートリアルに示されているように、ページアダプターを介してビューページャーに追加されます。