`

【转】玩转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. }  

 效果如下:
 

 


分享到:
评论

相关推荐

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

    总的来说,这个实例展示了如何使用Android的ZoomControls控件实现基础的图片放大和缩小功能,对于初学者来说是一个很好的起点。不过在实际项目中,开发者应考虑使用更现代的方法来提高用户体验。

    ZoomControls放大与缩小

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

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

    这篇教程主要涵盖了九种常见的Android控件及其使用示例,包括ZoomControls、Include、VideoView、WebView、RatingBar、Tab、Spinner、Chronometer以及ScrollView。下面我们将逐一详细探讨这些控件的功能和用法。 1....

    ZoomControls 缩放

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

    Android 类似于放大镜源码.zip

    1. **放大与缩小**:在Android中,可以使用`ScaleGestureDetector`来检测用户的双指缩放手势,从而实现图像的放大和缩小。当用户在屏幕上做捏合动作时,`ScaleGestureDetector`会监听到这一事件,并通过调用相应的回...

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

    在大多数编程环境中,ZoomControls通常是一个派生自基础控件的类,例如Android中的ZoomControls继承自ViewGroup。这样的设计允许开发者利用已有的控件属性和方法,同时添加特定于缩放功能的特性。在学习ZoomControls...

    Android-GPS定位与Google地图管理模块的代码设计.pdf

    【Android-GPS定位与Google地图管理模块的代码设计】这篇技术文档主要讲解了如何在Android平台上构建基于GPS定位和Google地图的导航系统。系统开发采用了Java语言和Eclipse开发工具,涉及的关键技术包括GPS定位、...

    android缩放组件源码

    在这个项目中,我们可能会看到`ZoomControls`类的实现,这是一个预定义的Android控件,用于提供简单的放大和缩小功能。`ZoomControls`通常用于地图应用或其他需要用户进行缩放操作的场景。 源码分析: 1. **...

    Android_UI类继承关系图

    Android UI类继承关系图描述了Android开发中,用户界面组件之间的层次结构和继承关系。在Android开发中,UI组件构建在一种称为View的类之上,View又是Object的子类,构成了一个庞大的类体系。通过继承关系图,开发者...

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

    移动互联网应用

    Android控件及布局的使用

    ### Android控件及布局的使用知识点详解 #### 第一章:Android基础 ##### 1.1 Android开发环境搭建 - **安装JDK (Java Development Kit)**:Java是Android开发的基础语言,因此首先需要安装JDK。可以从Oracle官网...

    Android2.2 API中文文档——View

    在Android开发中,`View`是最基本的UI组件,所有可见的用户界面元素都是通过继承`View`类实现的。`View`类定义了控件的行为和外观,并且提供了绘制、布局、处理触摸事件等功能。本文档将详细介绍Android2.2版本中的`...

    Android利用AsyncTask异步类实现网页内容放大缩小

    此外,`ZoomControls`类提供了放大和缩小网页的UI控件,它们可以通过`webView.setBuiltInZoomControls(true)`自动创建和管理,或者像`WebActivity`那样手动添加。 总的来说,`WebActivity`利用AsyncTask异步加载...

    ArcGIS Runtime SDK for Android开发基础

    **ArcGIS Runtime SDK for Android开发基础** ArcGIS Runtime SDK for Android是Esri公司推出的一款用于在Android平台上构建地理信息系统(GIS)应用的开发工具。它允许开发者创建具有地图查看、地理编码、空间分析...

    Android地图使用文档

    本篇文章将深入解析如何在Android应用中使用Google地图,以及如何处理地图的关键元素和功能。 首先,我们需要了解`MapView`类。`MapView`是Android SDK中用于展示地图的控件,它是`MapView`类的实例,继承自`...

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

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

    Android开发规范

    在Android开发中,遵循一套规范是非常重要的,它能提高代码的可读性、可维护性和团队协作效率。以下是一些关键的Android开发规范和注意事项: **布局方面:** 1. **优先使用线性布局(LinearLayout)**,因为它简单...

    Android Map

    在Android平台上,地图功能是应用开发中的重要组成部分,它允许用户查看地理位置、导航以及执行其他与位置相关的操作。本文将详细探讨"Android Map"的相关知识点,包括地图的显示、缩放、位置查询以及如何实现个人...

Global site tag (gtag.js) - Google Analytics