【问题标题】:Simple tween animation example简单的补间动画示例
【发布时间】:2013-04-08 17:50:23
【问题描述】:

我正在尝试实现http://developer.android.com/guide/topics/resources/animation-resource.html(“动画资源”)中描述的“超空间”补间动画 - 但它似乎不像所写的那样工作。当我运行应用程序时,我只会在应用程序标题栏下方看到一个空白视图。我究竟做错了什么?

根据示例,这是我的代码。我创建了 res/anim/hyperspace_jump.xml:

<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:shareInterpolator="false">
    <scale
        android:interpolator="@android:anim/accelerate_decelerate_interpolator"
        android:fromXScale="1.0" 
        android:toXScale="1.4" 
        android:fromYScale="1.0" 
        android:toYScale="0.6" 
        android:pivotX="50%"
        android:pivotY="50%"
        android:fillAfter="false"
        android:duration="700" />
    <set
        android:interpolator="@android:anim/accelerate_interpolator"
        android:startOffset="700">
        <scale
            android:fromXScale="1.4" 
            android:toXScale="0.0"
            android:fromYScale="0.6"
            android:toYScale="0.0" 
            android:pivotX="50%" 
            android:pivotY="50%" 
            android:duration="400" />
        <rotate
            android:fromDegrees="0" 
            android:toDegrees="-45"
            android:toYScale="0.0" 
            android:pivotX="50%" 
            android:pivotY="50%"
            android:duration="400" />
    </set>
</set>

我还创建了一个 layout/main.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
<TextView  
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:text="@string/hello"
    />
<ImageView android:id="@+id/ImageView01" android:layout_width="wrap_content" android:layout_height="wrap_content"></ImageView>

</LinearLayout>

我终于有一个活动了:

package com.tomoreilly.geology;

import android.app.Activity;
import android.os.Bundle;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.ImageView;

public class MainActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        ImageView image = (ImageView) findViewById(R.id.ImageView01);
        Animation hyperspaceJump = 
            AnimationUtils.loadAnimation(this, R.anim.hyperspace_jump);
        image.startAnimation(hyperspaceJump);
    }
}

但我在运行应用程序时没有看到任何动画。我是否遗漏了“动画资源”示例中未涵盖的一些细节?

谢谢, 汤姆

【问题讨论】:

    标签: android animation


    【解决方案1】:

    要添加不同的答案,您还可以尝试使用 Universal Tween Engine 为您的 android UI 设置动画。事实上,您的动画需要很多行的 XML 格式,可以这样描述:

    Timeline.createSequence()
        // First, set your pivot (Tween.set() works instantly)
        .push(Tween.set(image, ViewAccessor.PIVOT_XY).target(0.5f, 0.5f))
    
        // Then, animate your scale and rotation as you want
        .push(Tween.to(image, ViewAccessor.SCALE_XY, 0.7f).target(1.4f, 0.6f))
        .beginParallel()
            .push(Tween.to(image, ViewAccessor.SCALE_XY, 0.4f).target(0, 0))
            .push(Tween.to(image, ViewAccessor.ROTATION, 0.4f).target(-45))
        .end()
    
        // Finally, start the animation!
        .start();
    

    当您有大量动作要排序时,它可能更具可读性。该引擎针对 android,尤其是游戏进行了高度优化,并且不分配任何内容,以提供最佳性能。

    它是完全开源的,有大量文档,并使用 Apache-2 许可证发布。

    如果你愿意,可以试试Android demo :)

    【讨论】:

    • 顺便说一句,这是一个令人惊叹的图书馆,至今仍能完美运行。
    【解决方案2】:

    您的 imageview 必须在 xml 或您的活动中定义一个源。

    xml:

    <ImageView android:id="@+id/ImageView01" 
       android:src="@drawable/someimage" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content">
    </ImageView>
    

    活动:

    ImageView image = (ImageView) findViewById(R.id.ImageView01);
    image.setImageResource(R.drawable.some_image);
    

    【讨论】:

      【解决方案3】:

      我猜 ViewFlipper 是必需的。因为当你想在动画之间做动画时,你需要 ViewFlipper 来做动画。

      做以下事情。我想解决问题。

      创建新的 XML 文件并在其中添加 ViewFlipper 选项卡...

      当你想做动画时,使用包含标签来包含所有其他布局。

      然后使用以下代码

      flipper = (ViewFlipper) findViewById(R.id.flipper);
      
      Button button1 = (Button) findViewById(R.id.Button01); // Button in one activity
      
      Button button2 = (Button) findViewById(R.id.Button02); // Button in second activity
      
      // Other Methods
      
      private Animation inFromRightAnimation() {
      
              // Animation inFromRight = new TranslateAnimation(
              /*
               * Animation inFromRight = new ScaleAnimation(
               * Animation.RELATIVE_TO_PARENT, 0.0f, Animation.RELATIVE_TO_PARENT,
               * 0.0f, Animation.RELATIVE_TO_PARENT, 0.0f,
               * Animation.RELATIVE_TO_PARENT, 0.0f);
               */
              Animation inFromRight = new TranslateAnimation(
                      Animation.RELATIVE_TO_SELF, 0.0f, Animation.RELATIVE_TO_SELF,
                      0.0f, Animation.RELATIVE_TO_SELF, -1.0f,
                      Animation.RELATIVE_TO_SELF, 0.0f);
      
              inFromRight.setDuration(500);
              inFromRight.setInterpolator(new AccelerateInterpolator());
              return inFromRight;
          }
      
          private Animation outToLeftAnimation() {
              // Animation outtoLeft = new TranslateAnimation(
              /*
               * Animation outtoLeft = new
               * ScaleAnimation(Animation.RELATIVE_TO_PARENT, 0.0f,
               * Animation.RELATIVE_TO_PARENT, 0.0f, Animation.RELATIVE_TO_PARENT,
               * 0.0f, Animation.RELATIVE_TO_PARENT, 0.0f);
               */
              Animation outtoLeft = new TranslateAnimation(
                      Animation.RELATIVE_TO_SELF, 0.0f, Animation.RELATIVE_TO_SELF,
                      0.0f, Animation.RELATIVE_TO_SELF, -1.0f,
                      Animation.RELATIVE_TO_SELF, 0.0f);
              outtoLeft.setDuration(500);
              outtoLeft.setInterpolator(new AccelerateInterpolator());
              return outtoLeft;
          }
      
          private Animation inFromLeftAnimation() {
              // Animation inFromLeft = new TranslateAnimation(
              /*
               * Animation inFromLeft = new
               * ScaleAnimation(Animation.RELATIVE_TO_PARENT, 0.0f,
               * Animation.RELATIVE_TO_PARENT, 0.0f, Animation.RELATIVE_TO_PARENT,
               * 0.0f, Animation.RELATIVE_TO_PARENT, 0.0f);
               */
              Animation inFromLeft = new TranslateAnimation(
                      Animation.RELATIVE_TO_SELF, 0.0f, Animation.RELATIVE_TO_SELF,
                      0.0f, Animation.RELATIVE_TO_SELF, -1.0f,
                      Animation.RELATIVE_TO_SELF, 0.0f);
              inFromLeft.setDuration(500);
              inFromLeft.setInterpolator(new AccelerateInterpolator());
              return inFromLeft;
          }
      
          private Animation outToRightAnimation() {
              // Animation outtoRight = new TranslateAnimation(
              /*
               * Animation outtoRight = new
               * ScaleAnimation(Animation.RELATIVE_TO_PARENT, 0.0f,
               * Animation.RELATIVE_TO_PARENT, 0.0f, Animation.RELATIVE_TO_PARENT,
               * 0.0f, Animation.RELATIVE_TO_PARENT, 0.0f);
               */
              Animation outtoRight = new TranslateAnimation(
                      Animation.RELATIVE_TO_SELF, 0.0f, Animation.RELATIVE_TO_SELF,
                      0.0f, Animation.RELATIVE_TO_SELF, -1.0f,
                      Animation.RELATIVE_TO_SELF, 0.0f);
              outtoRight.setDuration(500);
              outtoRight.setInterpolator(new AccelerateInterpolator());
              return outtoRight;
          }
      

      【讨论】:

      • 为什么把上面的答案复制粘贴到这里?
      【解决方案4】:
      package com.example;
      
      import android.app.Activity;
      import android.os.Bundle;
      import android.view.animation.AccelerateInterpolator;
      import android.view.animation.Animation;
      import android.view.animation.AnimationUtils;
      import android.view.animation.TranslateAnimation;
      import android.widget.Button;
      import android.widget.ImageView;
      import android.widget.ViewFlipper;
      
       public class TeeenAni extends Activity {
      
      ViewFlipper flipper;
      @Override
      public void onCreate(Bundle savedInstanceState) {
          super.onCreate(savedInstanceState);
          setContentView(R.layout.main);
          ImageView image = (ImageView) findViewById(R.id.ImageView01);
          Animation hyperspaceJump = 
           AnimationUtils.loadAnimation(this, R.anim.);
          image.startAnimation(hyperspaceJump);
         flipper = (ViewFlipper) findViewById(R.anim.hyperspace_jump);
      
          Button button1 = (Button) findViewById(R.id.Button01); 
      
          Button button2 = (Button) findViewById(R.id.Button02);
      }
          private Animation inFromRightAnimation() {
      
      
              Animation inFromRight = new TranslateAnimation(
                      Animation.RELATIVE_TO_SELF, 0.0f, Animation.RELATIVE_TO_SELF,
                      0.0f, Animation.RELATIVE_TO_SELF, -1.0f,
                      Animation.RELATIVE_TO_SELF, 0.0f);
      
              inFromRight.setDuration(500);
              inFromRight.setInterpolator(new AccelerateInterpolator());
              return inFromRight;
          }
      
          private Animation outToLeftAnimation() {
      
              Animation outtoLeft = new TranslateAnimation(
                      Animation.RELATIVE_TO_SELF, 0.0f, Animation.RELATIVE_TO_SELF,
                      0.0f, Animation.RELATIVE_TO_SELF, -1.0f,
                      Animation.RELATIVE_TO_SELF, 0.0f);
              outtoLeft.setDuration(500);
              outtoLeft.setInterpolator(new AccelerateInterpolator());
              return outtoLeft;
          }
      
          private Animation inFromLeftAnimation() {
      
              Animation inFromLeft = new TranslateAnimation(
                      Animation.RELATIVE_TO_SELF, 0.0f, Animation.RELATIVE_TO_SELF,
                      0.0f, Animation.RELATIVE_TO_SELF, -1.0f,
                      Animation.RELATIVE_TO_SELF, 0.0f);
              inFromLeft.setDuration(500);
              inFromLeft.setInterpolator(new AccelerateInterpolator());
              return inFromLeft;
          }
      
          private Animation outToRightAnimation() {
      
              Animation outtoRight = new TranslateAnimation(
                      Animation.RELATIVE_TO_SELF, 0.0f, Animation.RELATIVE_TO_SELF,
                      0.0f, Animation.RELATIVE_TO_SELF, -1.0f,
                      Animation.RELATIVE_TO_SELF, 0.0f);
              outtoRight.setDuration(500);
              outtoRight.setInterpolator(new AccelerateInterpolator());
              return outtoRight;
          }
      

      [R.anim.hyperspace_jump][1] }

      <?xml version="1.0" encoding="utf-8"?>
      <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
      android:orientation="vertical"
      android:layout_width="fill_parent"
      android:layout_height="fill_parent"
      >
      <TextView  
      android:layout_width="fill_parent" 
      android:layout_height="wrap_content" 
      android:text="@string/hello"
      />
       <ImageView android:id="@+id/ImageView01" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content">
       </ImageView>
      
      <ViewFlipper android:id="@+id/details"
      android:layout_width="fill_parent" 
      android:layout_height="fill_parent"/>
      
       <Button android:id="@+id/Button01" 
       android:layout_height="wrap_content" 
       android:layout_width="wrap_content" 
       android:text="Home"></Button>
      <Button android:id="@+id/Button02" 
      android:layout_height="wrap_content" 
      android:layout_width="wrap_content" 
      android:text="Gallary"></Button>
      

      【讨论】:

      • 请在您的答案中添加更多内容,而不仅仅是一些代码。为这段代码如何以及为什么解决问题添加一些推理。
      猜你喜欢
      • 2010-12-03
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-11-23
      • 1970-01-01
      相关资源
      最近更新 更多