0

我实现水平滚动视图,该物品,其中含有的ImageView和一个TextView的Android水平类别与图像查看

这是我的主要活动:

public class MainActivity extends Activity implements OnClickListener{ 
    List elementlist; 
    LinearLayout layout; 

    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 

     elementlist=new ArrayList<Element>(); 

     elementlist.add(new Element("Item 1", "p1")); 
     elementlist.add(new Element("Item 2", "p2")); 
     elementlist.add(new Element("Item 3", "p3")); 
     elementlist.add(new Element("Item 4", "p4")); 
     elementlist.add(new Element("Item 5", "p5")); 

     layout=(LinearLayout)findViewById(R.id.lay); 


     populate_list(); 

    } 

    private void populate_list() 
    { 

     Iterator<Element> i=elementlist.iterator(); 
     while(i.hasNext()) 
     { 
      Element e= (Element)i.next(); 

      LayoutInflater inflater=(LayoutInflater)getSystemService(LAYOUT_INFLATER_SERVICE); 
      View v=inflater.inflate(R.layout.list_element, null); 

      ImageView iw=(ImageView)v.findViewById(R.id.imageView1); 
      TextView tw=(TextView)v.findViewById(R.id.textView1); 
      iw.setImageDrawable(getResources().getDrawable(getResources().getIdentifier(e.getImagename(), "drawable", this.getPackageName()))); 
      tw.setText(e.getDisplayname()); 

      layout.addView(v); 
     } 



    } 
} 

元素类:

public class Element { 
private String displayname; 
private String imagename; 
public Element(String displayname, String imagename) { 
    this.displayname = displayname; 
    this.imagename = imagename; 
} 

public String getDisplayname() { 
    return displayname; 
} 

public String getImagename() { 
    return imagename; 
}} 

activity_main.xml:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" > 

    <HorizontalScrollView 
     android:id="@+id/horizontalScrollView1" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_alignParentBottom="true" 
     android:layout_alignParentLeft="true" 
     android:layout_alignParentRight="true" 
     android:layout_alignParentTop="true" > 

     <LinearLayout 
      android:id="@+id/lay" 
      android:layout_width="wrap_content" 
      android:layout_height="match_parent" 
      android:orientation="horizontal" > 
     </LinearLayout> 
    </HorizontalScrollView> 

</RelativeLayout> 

而且listelement.xml:

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" > 


    <ImageView 
     android:id="@+id/imageView1" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_alignParentLeft="true" 
     android:layout_alignParentRight="true" 
     android:layout_alignParentTop="true" /> 

    <LinearLayout 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_alignBottom="@+id/imageView1" 
     android:layout_centerHorizontal="true" 
     android:background="#000000" 
     android:layout_alignParentRight="true" 
     android:layout_alignParentLeft="true" 
     android:orientation="vertical" > 


     <TextView 
     android:id="@+id/textView1" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:gravity="center" 
     android:textAppearance="?android:attr/textAppearanceMedium" 
     android:textColor="#ffffff" /> 


    </LinearLayout> 

</RelativeLayout> 

现在,我的情况是,我有两个要求:

  1. 虽然滚动列表的大小应减少(如在画廊的情况下,诺基亚N72,N95等)

  2. 滚动结束后,列表会自动跳到最近的项目,尺寸再次增加,即该项目的宽度适合屏幕宽度或至少出现在中心。

我该如何满足我的要求?

我想正是做这样

While the layout is static

当用户滚动,它应该是这样的: While the user is scrolling

回答

1

从你的问题,我认为在大小需减量不与位移成正比,即你有1个更大的尺寸和1个更小的尺寸

继续我的假设,我建议你通过问题 - Complete Working Sample of the Gmail Three-Fragment Animation Scenario?,它会告诉你四个处理你需要调整大小动画的实现

+0

其实是的,它不需要完全成比例,但我需要一个渐变缩放。 – gaurav414u 2013-12-22 07:59:49

+0

我已经通过使用一些矩阵变换和数学在垂直自定义ListView中实现了这一点。在这种情况下,缩放和旋转与儿童与列表中心的距离成正比,而且看起来很酷。 – gaurav414u 2013-12-22 08:01:29