`

旋转ImageView和TextView的效果实现

阅读更多


如图ImageView和TextView组成布局同时旋转。,求实现效果。
经过几天研究终于实现如图效果。代码如下,给需要的人吧。还涉及到部分背景图的效果。
public class IconViewGroup extends ViewGroup{
        TextView mTextView;
        ImageView mImageView;//显示对应的icon
        private Context mContext;
        /**
         * 命名区域
         */
        private final String namespace = "http://com.oppo.examples"; 
        /**
         * 保存创建旋转角度
         */
        private float mRotateDegrees; 
        /**
         * 保存创建背景图片的ID
         */
        private int mBackGroudDrawableId;
        /**
         * 利用图片ID加载图片
         */
        private Drawable mBackGroudDrawable;
        /**
         * 原始图片所需宽、高
         */
        private int mBackGroundWidth;
        private int mBackGroundHeight;
        private View view;
        
        private static final int ICON_WIDTH=46;//显示数字的TextView的长宽
        private static final int ICON_HEIGHT=46;
        
        private static final int TEXT_WIDTH=46;//显示数字的TextView的长宽
        private static final int TEXT_HEIGHT=260;
        
        public IconViewGroup(Context context) {
                super(context);
                // TODO Auto-generated constructor stub
        }
        public IconViewGroup(Context context, AttributeSet attrs) {
                super(context, attrs);
                init(context);
                mContext = context;
                mBackGroudDrawableId=attrs.getAttributeResourceValue(namespace, "background", R.drawable.item_on);
                mBackGroudDrawable = context.getResources().getDrawable(
                                mBackGroudDrawableId);                
                mRotateDegrees=attrs.getAttributeFloatValue(namespace, "rotateDegrees",30.0f);                
        }

        private void init(Context context) {
                // TODO Auto-generated method stub
                mTextView=new MyTextView(context);
                mTextView.setTextSize(28);
                mTextView.setGravity(Gravity.CENTER_VERTICAL);
//                mTextView.setBackgroundColor(0xFFFFFF00);
                mTextView.setText(R.string.app_name);
                mTextView.setTextColor(0xF0FFFFFF);
                mImageView=new ImageView(context);
                mImageView.setBackgroundResource(R.drawable.icon);
                this.addView(mTextView);
                this.addView(mImageView);
        }

        @Override
        protected void onLayout(boolean changed, int l, int t, int r, int b) {
                // TODO Auto-generated method stub
                int ivWidth=mImageView.getMeasuredWidth();
                int ivHeight=mImageView.getMeasuredHeight();
                int tvWidth=mTextView.getMeasuredWidth();
                int tvHeight=mTextView.getMeasuredHeight();
                mTextView.measure(r - l, b - t);
                mTextView.layout(5+ivWidth+10, getHeight()-tvHeight-5,getWidth(),getHeight()-5);
                mImageView.measure(r - l, b - t);
                mImageView.layout(5, 5+getHeight()-ivHeight, ivWidth,getHeight());

        }
        
        @Override
        protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
                // TODO Auto-generated method stub
                super.onMeasure(widthMeasureSpec, heightMeasureSpec);
                /**
                 * 设定View显示区域
                 */
                mBackGroundHeight=mBackGroudDrawable.getIntrinsicHeight();
                mBackGroundWidth=mBackGroudDrawable.getIntrinsicWidth();
                if (mRotateDegrees==90.0f) {
                        setMeasuredDimension(mBackGroundHeight, mBackGroundWidth);
                } else {
                        setMeasuredDimension(mBackGroundWidth, mBackGroundHeight);
                }                
        }
        
        @Override
        protected void dispatchDraw(Canvas canvas) {
                // TODO Auto-generated method stub
                canvas.rotate(mRotateDegrees);
                mBackGroudDrawable.setBounds(0, 0, mBackGroundWidth, mBackGroundHeight);
                mBackGroudDrawable.draw(canvas);
                super.dispatchDraw(canvas);
        }        
        
}


Android中ViewGroup等容器控件的使用
http://blog.csdn.net/arui319/archive/2010/09/07/5868466.aspx
  • 大小: 4.1 KB
分享到:
评论
1 楼 xinerfei2010 2013-08-16  
有源码吗  请发份源码给我可以吗 1126712385@qq.com

相关推荐

    TextView+Fragment实现底部导航栏

    本示例将详细讲解如何使用TextView和Fragment来实现这一功能。以下是对实现过程的详细解析: 1. **TextView作为导航按钮**: 在传统的底部导航栏实现中,我们通常会使用`BottomNavigationView`或自定义的`...

    自定义实现圆形旋转菜单

    在Android应用开发中,自定义视图是提升用户体验和实现独特功能的重要手段。本文将深入探讨如何基于Android的自定义ViewGroup实现一个圆形旋转菜单,该菜单能够跟随用户的手指移动进行旋转,并支持快速旋转效果。 ...

    安卓自定义控件相关-一个自定义imageview实现圆形显示的闪烁消息效果.rar

    总之,这个压缩包提供了一个自定义ImageView的例子,通过学习和实践这个例子,开发者可以了解自定义控件的基本流程,以及如何实现特殊的视觉效果,如圆形显示和闪烁消息。在实际开发中,可以根据这些基础知识进行...

    旋转效果的Menu菜单实现

    这可能包括一个ImageView用于显示图标,一个TextView用于显示文字,以及一个View作为旋转中心。 - 在Java或Kotlin代码中,根据布局文件创建自定义菜单视图的实例,并设置点击事件监听器。 2. 旋转动画实现: - ...

    TextView的展开与收缩

    另外,通过调整`Drawable`的`rotation`属性,可以实现箭头的旋转动画,使得展开和收缩过程更加直观。 4. **TVHeightDemo项目** `TVHeightDemo`这个项目的名称暗示这是一个关于`TextView`高度控制的演示应用。在这...

    自定义dialog实现processDialog“正在加载”效果

    Android提高篇之自定义dialog实现...1、使用imageview、textview自定义dialog 2、使用Animation实现图片旋转动画效果 3、通过自定义theme去掉dialog的title。 没有使用progressdialog,使用起来更加灵活,请大家参考。

    Android旋转菜单实现示例

    本篇文章将详细讲解如何在Android平台上实现一个旋转菜单的效果,这个示例被誉为“史上最简单的Android旋转菜单”。 首先,我们要了解旋转菜单的基本概念。旋转菜单通常是指一种以中心点为轴,通过动画效果展开或...

    主要记录下实现画廊效果

    例如,一个ImageView用于显示图片,一个TextView用于显示描述等。 - 在`onBindViewHolder()` 方法中,根据数据集设置ViewHolder的视图内容。 5. **滑动监听和动画** - 为了实现滑动效果,可以监听RecyclerView的`...

    旋转动画和帧动画制作自定义ProgressDialog

    为了实现旋转动画,我们可以将上述代码中的ImageView替换为自定义View,并在onDraw()方法中绘制旋转的图形。对于帧动画,只需将动画列表应用到该自定义View上。 最后,别忘了在适当的时候关闭ProgressDialog: ```...

    android加圈效果实现

    总之,实现“加圈效果”需要理解Android的动画机制,能够创建旋转动画,以及根据需求选择合适的方式显示这个动画。对于更高级的定制,需要掌握自定义View和Dialog的知识。通过分析DialogLoadding-master项目,开发者...

    Android TextView多文本折叠展开效果

    例如,我们可以创建一个包含TextView和ImageView的LinearLayout。TextView用于显示文本,而ImageView则作为展开或折叠的指示器。在XML布局文件中,我们将TextView的高度设置为固定行数(比如3行)乘以行高,而不是...

    旋转动画实现自定义的ProgressDialog

    这里我们添加了一个ImageView用于展示旋转动画,以及一个TextView显示提示文本。 接下来,我们需要创建旋转动画。在res/anim目录下创建一个名为`rotate_loader.xml`的文件,内容如下: ```xml android:pivotX=...

    仿乐安全的旋转动画.zip

    在Android中,自定义视图是一种强大的工具,开发者可以扩展系统提供的基础视图类,如View、ImageView或TextView,来实现特定的功能或视觉效果。RadiationView很可能就是这样的一个自定义视图,它扩展了View类,并...

    Android仿ios加载loading菊花图效果

    我们可以使用ImageView和TextView来实现这一点。在LoadingView中,我们使用ImageView来显示成功或失败状态的图片,并使用TextView来显示加载中的文字信息。 在上面的代码中,我们使用了一个ImageView控件,并将其...

    android 超炫的转盘效果

    Android提供了多种布局(如LinearLayout、RelativeLayout、ConstraintLayout)以及视图组件(如ImageView、TextView、Button等),通过这些基本元素我们可以构建出各种复杂的用户界面。转盘效果通常会涉及到自定义...

    android中翻页效果的实现

    在Android开发中,实现翻页效果可以为应用增添生动性和用户体验。这个Demo主要展示了如何在Android平台上创建一种类似书本翻页的动画效果。这种效果通常用于电子书应用或者需要展示多页面内容的场景。接下来,我们将...

    Android例子源码仿多看阅读的左右平移翻页效果小例子.zip

    在Android中,自定义View是扩展系统提供的基础视图类(如View、ImageView或TextView)以实现特定功能的方法。在这个例子中,开发者可能扩展了View类,添加了平移和旋转动画,以及页面边缘的阴影绘制,从而实现了翻页...

    Android 学习(16)ImageView

    5. **动画效果**:Android提供了多种方式给ImageView添加动画,如旋转、淡入淡出、平移等。这些可以通过`Animation`类或属性动画(`ObjectAnimator`、`ValueAnimator`)实现。 6. **多源图片**:ImageView还可以...

Global site tag (gtag.js) - Google Analytics