android 按钮图片缩小,玩转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

android:orientation="vertical"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:id="@+id/layout1"

>

android:id="@+id/imgview"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:src="@drawable/yuanyuan"

/>

android:id="@+id/zoomcontrol"

android:layout_gravity="bottom"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

/>

ZoomExampleActivity.java

packagecom.loulijun.zoomcontroltest;

importandroid.app.Activity;

importandroid.graphics.Bitmap;

importandroid.graphics.BitmapFactory;

importandroid.graphics.Matrix;

importandroid.os.Bundle;

importandroid.util.DisplayMetrics;

importandroid.view.View;

importandroid.view.View.OnClickListener;

importandroid.widget.ImageView;

importandroid.widget.LinearLayout;

importandroid.widget.ZoomControls;

publicclassZoomExampleActivityextendsActivity {

privateLinearLayout layout1;

privateZoomControls zoom;

privateImageView img;

privateintid=0;

privateintdisplayWidth;

privateintdisplayHeight;

privatefloatscaleWidth =1;

privatefloatscaleHeight =1;

privateBitmap bmp;

@Override

publicvoidonCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

layout1 = (LinearLayout)findViewById(R.id.layout1);

//取得屏幕分辨率大小

DisplayMetrics dm =newDisplayMetrics();

getWindowManager().getDefaultDisplay().getMetrics(dm);

displayWidth = dm.widthPixels;

//屏幕高度减去zoomControls的高度

displayHeight = dm.heightPixels;

bmp = BitmapFactory.decodeResource(getResources(), R.drawable.yuanyuan);

img = (ImageView)findViewById(R.id.imgview);

//zoom.hide();隐藏zoomControls

//zoom.show();显示zoomCOntrols

zoom = (ZoomControls)findViewById(R.id.zoomcontrol);

img = (ImageView)findViewById(R.id.imgview);

zoom.setIsZoomInEnabled(true);

zoom.setIsZoomOutEnabled(true);

//图片放大

zoom.setOnZoomInClickListener(newOnClickListener()

{

publicvoidonClick(View v)

{

intbmpWidth = bmp.getWidth();

intbmpHeight = bmp.getHeight();

//设置图片放大但比例

doublescale =1.25;

//计算这次要放大的比例

scaleWidth = (float)(scaleWidth*scale);

scaleHeight = (float)(scaleHeight*scale);

//产生新的大小但Bitmap对象

Matrix matrix =newMatrix();

matrix.postScale(scaleWidth, scaleHeight);

Bitmap resizeBmp = Bitmap.createBitmap(bmp,0,0,bmpWidth,bmpHeight,matrix,true);

img.setImageBitmap(resizeBmp);

}

});

//图片减小

zoom.setOnZoomOutClickListener(newOnClickListener()

{

publicvoidonClick(View v) {

intbmpWidth = bmp.getWidth();

intbmpHeight = bmp.getHeight();

//设置图片放大但比例

doublescale =0.8;

//计算这次要放大的比例

scaleWidth = (float)(scaleWidth*scale);

scaleHeight = (float)(scaleHeight*scale);

//产生新的大小但Bitmap对象

Matrix matrix =newMatrix();

matrix.postScale(scaleWidth, scaleHeight);

Bitmap resizeBmp = Bitmap.createBitmap(bmp,0,0,bmpWidth,bmpHeight,matrix,true);

img.setImageBitmap(resizeBmp);

}

});

}

}

效果如下:

983bedd5b37e8a0d7d4f2e42d29b90ea.png

68d09f17d33b22c01e3a069cb98c8818.png

0ff974e2c7cc60d3222a7fee0e5eec52.png0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是实现图片放大缩小功能ZoomControls控件的用法实例: 1. 在 XML 布局文件中添加 ZoomControls 控件: ```xml <FrameLayout android:layout_width="match_parent" android:layout_height="match_parent"> <ImageView android:id="@+id/imageView" android:layout_width="match_parent" android:layout_height="match_parent" android:scaleType="matrix" android:src="@drawable/image" /> <ZoomControls android:id="@+id/zoomControls" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="bottom|right" /> </FrameLayout> ``` 2. 在 Activity 中获取 ImageView 和 ZoomControls 对象,并设置监听器: ```java public class MainActivity extends AppCompatActivity { private ImageView imageView; private ZoomControls zoomControls; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); imageView = findViewById(R.id.imageView); zoomControls = findViewById(R.id.zoomControls); zoomControls.setOnZoomInClickListener(new View.OnClickListener() { @Override public void onClick(View v) { float scale = imageView.getScaleX() + 0.5f; imageView.setScaleX(scale); imageView.setScaleY(scale); } }); zoomControls.setOnZoomOutClickListener(new View.OnClickListener() { @Override public void onClick(View v) { float scale = imageView.getScaleX() - 0.5f; if (scale < 1) { scale = 1; } imageView.setScaleX(scale); imageView.setScaleY(scale); } }); } } ``` 3. 在监听器中实现图片的缩放功能,通过 ImageView 的 setScaleX() 和 setScaleY() 方法实现缩放。 以上就是实现图片放大缩小功能ZoomControls控件的用法实例,希望能对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值