`

【转】玩转Android---UI篇---ZoomControls放大缩小图片

 
阅读更多

ZoomControls控件是一个可以缩放但控件,效果如下图

以下是它但一些主要但方法

hasFocus ():判断焦点

hide ():隐藏

onTouchEvent (MotionEvent event):现这个方法来处理触摸屏移动事件

setIsZoomInEnabled (boolean isEnabled):是否允许放大

setIsZoomOutEnabled (boolean isEnabled):是否允许缩小

setOnZoomInClickListener (View.OnClickListener listener):注册放大监听器

setOnZoomOutClickListener (View.OnClickListener listener):注册缩小监听器

setZoomSpeed (long speed):设置缩放速度

show ():显示

 

这里面,如果将setIsZoomInEnabled()方法设置为false,那么这个放大的按钮就变成了灰色,不能用了,其实这个控件就是两个按钮而已,只是有外观,没有功能,如果你要放大图片或者缩小图片,还是要在监听事件中实现

开始看代码

main.xml

Java代码  收藏代码
  1. <?xml version= "1.0"  encoding= "utf-8" ?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"   
  3.     android:orientation="vertical"   
  4.     android:layout_width="fill_parent"   
  5.     android:layout_height="fill_parent"   
  6.     android:id="@+id/layout1"   
  7.     >  
  8. <ImageView  
  9.     android:id="@+id/imgview"   
  10.     android:layout_width="wrap_content"   
  11.     android:layout_height="wrap_content"   
  12.     android:src="@drawable/yuanyuan"   
  13.     />  
  14.       
  15. <ZoomControls  
  16.     android:id="@+id/zoomcontrol"   
  17.     android:layout_gravity="bottom"   
  18.     android:layout_width="wrap_content"   
  19.     android:layout_height="wrap_content"    
  20. />  
  21. </LinearLayout>  
 

ZoomExampleActivity.java

Java代码  收藏代码
  1. package  com.loulijun.zoomcontroltest;  
  2.   
  3. import  android.app.Activity;  
  4. import  android.graphics.Bitmap;  
  5. import  android.graphics.BitmapFactory;  
  6. import  android.graphics.Matrix;  
  7. import  android.os.Bundle;  
  8. import  android.util.DisplayMetrics;  
  9. import  android.view.View;  
  10. import  android.view.View.OnClickListener;  
  11. import  android.widget.ImageView;  
  12. import  android.widget.LinearLayout;  
  13. import  android.widget.ZoomControls;  
  14.   
  15. public   class  ZoomExampleActivity  extends  Activity {  
  16.     private  LinearLayout layout1;  
  17.     private  ZoomControls zoom;  
  18.     private  ImageView img;  
  19.     private   int  id= 0 ;  
  20.     private   int  displayWidth;  
  21.     private   int  displayHeight;  
  22.     private   float  scaleWidth =  1 ;  
  23.     private   float  scaleHeight =  1 ;  
  24.     private  Bitmap bmp;  
  25.     @Override   
  26.     public   void  onCreate(Bundle savedInstanceState) {  
  27.         super .onCreate(savedInstanceState);  
  28.         setContentView(R.layout.main);  
  29.           
  30.         layout1 = (LinearLayout)findViewById(R.id.layout1);  
  31.         //取得屏幕分辨率大小   
  32.         DisplayMetrics dm = new  DisplayMetrics();  
  33.         getWindowManager().getDefaultDisplay().getMetrics(dm);  
  34.         displayWidth = dm.widthPixels;  
  35.         //屏幕高度减去zoomControls的高度   
  36.         displayHeight = dm.heightPixels;  
  37.         bmp = BitmapFactory.decodeResource(getResources(), R.drawable.yuanyuan);  
  38.         img = (ImageView)findViewById(R.id.imgview);  
  39.         //zoom.hide();隐藏zoomControls   
  40.         //zoom.show();显示zoomCOntrols   
  41.           
  42.         zoom = (ZoomControls)findViewById(R.id.zoomcontrol);  
  43.         img = (ImageView)findViewById(R.id.imgview);  
  44.         zoom.setIsZoomInEnabled(true );  
  45.         zoom.setIsZoomOutEnabled(true );  
  46.         //图片放大   
  47.         zoom.setOnZoomInClickListener(new  OnClickListener()  
  48.         {  
  49.             public   void  onClick(View v)  
  50.             {  
  51.                 int  bmpWidth = bmp.getWidth();  
  52.                 int  bmpHeight = bmp.getHeight();  
  53.                 //设置图片放大但比例   
  54.                 double  scale =  1.25 ;  
  55.                 //计算这次要放大的比例   
  56.                 scaleWidth = (float )(scaleWidth*scale);  
  57.                 scaleHeight = (float )(scaleHeight*scale);  
  58.                 //产生新的大小但Bitmap对象   
  59.                 Matrix matrix = new  Matrix();  
  60.                 matrix.postScale(scaleWidth, scaleHeight);  
  61.                 Bitmap resizeBmp = Bitmap.createBitmap(bmp,0 , 0 ,bmpWidth,bmpHeight,matrix, true );  
  62.                 img.setImageBitmap(resizeBmp);  
  63.   
  64.             }  
  65.         });  
  66.         //图片减小   
  67.         zoom.setOnZoomOutClickListener(new  OnClickListener()  
  68.         {  
  69.   
  70.             public   void  onClick(View v) {  
  71.                 int  bmpWidth = bmp.getWidth();  
  72.                 int  bmpHeight = bmp.getHeight();  
  73.                 //设置图片放大但比例   
  74.                 double  scale =  0.8 ;  
  75.                 //计算这次要放大的比例   
  76.                 scaleWidth = (float )(scaleWidth*scale);  
  77.                 scaleHeight = (float )(scaleHeight*scale);  
  78.                 //产生新的大小但Bitmap对象   
  79.                 Matrix matrix = new  Matrix();  
  80.                 matrix.postScale(scaleWidth, scaleHeight);  
  81.                 Bitmap resizeBmp = Bitmap.createBitmap(bmp,0 , 0 ,bmpWidth,bmpHeight,matrix, true );  
  82.                 img.setImageBitmap(resizeBmp);  
  83.             }  
  84.               
  85.         });  
  86.     }  
  87. }  

 效果如下:
 

 


分享到:
评论

相关推荐

    ZoomControls放大与缩小

    ZoomControls控件是一个可以缩放的控件,以下是它但一些主要但方法 hasFocus ():判断焦点 hide ():隐藏 onTouchEvent (MotionEvent event):现这个方法来处理触摸屏移动事件 setIsZoomInEnabled (boolean is...

    Android编程实现图片放大缩小功能ZoomControls控件用法实例

    主要介绍了Android编程实现图片放大缩小功能ZoomControls控件用法,结合具体实例形式分析了Android ZoomControls控件实现图片缩放的具体操作方法与相关注意事项,需要的朋友可以参考下

    ZoomControls 缩放

    一般应用开发过程中,会在屏幕的右下角有两个缩放控件(缩小和放大),这个控件就是ZoomControls 如何使用其实现放大缩小功能: 1:首先在布局文件中配置ZoomControls控件 &lt;ZoomControls android:id="@+id/...

    Android开发教程之Android控件--千锋培训

    文档介绍了控件介绍,1、ZoomControls 的 Demo,2、Include的Demo,3、VideoView的Demo,4、WebView的Demo,5、RatingBar的Demo,6、Tab的Demo,7、Spinner的Demo,8、Chronometer的Demo,9、ScrollView的Demo

    移动互联网-缩放控件ZoomControls.ppt

    移动互联网应用

    智能家居系统 缩放控件ZoomControls.doc

    智能家居系统 缩放控件ZoomControls.doc 学习资料 复习资料 教学资源

    Android 将 android view 的位置设为右下角的解决方法

    在做android开发时有这样一个需求,我们需要把地图的zoomcontroller放置于地图的右下角。... ZoomControls android:id=”@+id/zoomcontroller”  android:layout_gravity=”bottom” android:gravity=”right”

    指尖疯Android4.4视频第5集:图像类系列组件

    4. ZoomControls控件。 ImageView/ImageButton控件属于非常简单的控件,我们就从这两个入手开始。剩余的控件和手机等移动设备关系比较紧密,我们随后看看基于移动设备有什么新特性的控件。本集的口号是“我的面子我...

    Android Google Maps网络地图程序源代码

    部分源代码:   MyMap = (MapView) findViewById(R.... mZoom = (ZoomControls) MyMap.getZoomControls(); linearlayout = (LinearLayout) findViewById(R.id.zoomview); linearlayout.addView(mZoom);    

Global site tag (gtag.js) - Google Analytics