Android分辨率,dpi 、dp、px,App查询图片顺序

Android分辨率,dpi 、dp、px,App查询图片顺序,第1张

一、基本概念

1分辨率是手机屏幕的像素点数,一般为屏幕的“宽X高”,例如分辨率有2244X1080的手机,表示此屏幕在高度上是2244个像素点,在宽度方向上有1080个像素点。

2屏幕尺寸(英寸inch):是屏幕对角线测量的实际物理尺寸。

3屏幕密度dpi:是没英寸的像素点数,数值越高越清晰

4密度无关像素dp:密度无关像素等于160dpi屏幕上的一个物理像素

六种通用的密度:

ldpi(低)~120dpi

mdpi(中)~160dpi

hdpi(高)~240dpi

xhdpi(超高)~320dpi

xxhdpi(超超高)~480dpi

xxxhdpi(超超超高)~640dpi

px 、dp、dpi之间的转换关系

px = dp (dpi / 160)

dip: device independent pixels(设备独立像素) 一般我们为了支持多种分辨率如WVGA、HVGA和QVGA 推荐使用这个,不依赖像素。 dp: dip是一样的,谷歌官方推荐使用这个 px: pixels(像素) 不同设备显示效果相同,一般我们HVGA代表320x480像素,这

①首先在XML进行布局

<progressBar android:id="@+id/progressbar_updown"

android:layout_width="200dp"

android:layout_height="wrap_content"

style="android:attr/progressBarStyleHorizontal"

android:layout_gravity="center_vertical"

android:max="100"

android:progress="50"

android:secondaryProgress="70" >

②代码中运用

private ProgressBar myProgressBar;

//定义ProgressBar

myProgressBar = (ProgressBar) findViewById(Ridprogressbar_updown);

//ProgressBar通过ID来从XML中获取

myProgressBarincrementProgressBy(5);

//ProgressBar进度值增加5

myProgressBarincrementProgressBy(-5);

//ProgressBar进度值减少5

myProgressBarincrementSecondaryProgressBy(5);

//ProgressBar背后的第二个进度条 进度值增加5

myProgressBarincrementSecondaryProgressBy(-5);

//ProgressBar背后的第二个进度条 进度值减少5

先初始化;

注意自定义 的

private final String IMAGE_TYPE = "image/";private final int IMAGE_CODE = 0;

private void setImage() {

Intent getAlbum = new Intent(IntentACTION_GET_CONTENT);    getAlbumsetType(IMAGE_TYPE);    startActivityForResult(getAlbum, IMAGE_CODE);}

这里使用Intent获得相册数据,并返回原来界面;

这里说明一下

startActivityForResult(getAlbum, IMAGE_CODE);

补充{

startActivityForResult与startActivity的不同之处在于:

1、startActivity( ) 

仅仅是跳转到目标页面,若是想跳回当前页面,则必须再使用一次startActivity( )。

2、startActivityForResult( ) 

可以一次性完成这项任务,当程序执行到这段代码的时候,假若从T1Activity跳转到下一个Text2Activity,而当这个Text2Activity调用了finish()方法以后,程序会自动跳转回T1Activity,并调用前一个T1Activity中的onActivityResult( )方法。

}

startActivityForResult(getAlbum, IMAGE_CODE);

这里采用startActivityForResult来做跳转,此处的IMAGE_CODE实质是0为一个依据,可以写其他的值,但一定要>=0

然后重写onActivityResult用于接收刚刚得到的数据

protected  void onActivityResult(int requestCode, int resultCode, Intent data) {

Bitmap bm = null;    ContentResolver resolver = getContentResolver();    if (requestCode == IMAGE_CODE) {        try {

Uri originalUri = datagetData();            bm = MediaStoreImagesMediagetBitmap(resolver, originalUri);            imgShowsetImageBitmap(bm);        } catch (IOException e) {

eprintStackTrace();        }

}

补充{

ContentProvider-----数据提供给第三方应用程序使用时使用

因为在Android系统里面,数据库是私有的。一般情况下外部应用程序是没有权限读取其他应用程序的数据。如果你想公开你自己的数据,你有两个选择:你可以创建你自己的内容提供器(一个ContentProvider子类)或者你可以给已有的提供器添加数据-如果存在一个控制同样类型数据的内容提供器且你拥有写的权限

}

这里是创建一个新的内容提供器,然后在Activity当中通过getContentResolver()可以得到当前应用的 ContentResolver实例

if (requestCode == IMAGE_CODE) {

resultCode为回传的标记这句话是在确认是否回传的是你所需要的;如果是就执行try;不然就执行catch (IOException e) {

eprintStackTrace();}先说这里当try语句中出现异常是时,会执行catch中的语句,IOException e也就是实例化Exception类型的对象。e是此对象引用名称。然后e(引用)会自动调用Exception类中指定的方法,也就出现了eprintStackTrace() ;。printStackTrace()方法的意思是:在命令行打印异常信息在程序中出错的位置及原因。

try {

Uri originalUri = datagetData();    bm = MediaStoreImagesMediagetBitmap(resolver, originalUri);    imgShowsetImageBitmap(bm);接收数据处理数据并显示照片。

然后进行测试。

另附源码:

MainActivity:

package comexampleadministratormyapplication1;import androidgraphicsBitmapFactory;import androidsupportv7appAppCompatActivity;import androidosBundle;import javaioIOException;import androidnetUri;import androidosBundle;import androidproviderMediaStore;import androidappActivity;import androidcontentContentResolver;import androidcontentIntent;import androidgraphicsBitmap;import androidviewView;import androidviewViewOnClickListener;import androidwidgetButton;import androidwidgetImageView;public class MainActivity extends AppCompatActivity {    private final String IMAGE_TYPE = "image/";    private final int IMAGE_CODE = 0;    private Button choose=null;    private ImageView imgShow;    @Override    protected void onCreate(Bundle savedInstanceState) {        superonCreate(savedInstanceState);        setContentView(Rlayoutactivity_main);        init();}    private void init() {       choose=(Button) findViewById(Ridbutton1);        imgShow=(ImageView) findViewById(RidimgShow);        choosesetOnClickListener(listener);    }    private OnClickListener listener=new OnClickListener(){        @Override        public void onClick(View v) {

setImage();            }

};        private void setImage() {

Intent getAlbum = new Intent(IntentACTION_GET_CONTENT);            getAlbumsetType(IMAGE_TYPE);            startActivityForResult(getAlbum, IMAGE_CODE);        }    protected  void onActivityResult(int requestCode, int resultCode, Intent data) {

Bitmap bm = null;        ContentResolver resolver = getContentResolver();        if (requestCode == IMAGE_CODE) {            try {

Uri originalUri = datagetData();                bm = MediaStoreImagesMediagetBitmap(resolver, originalUri);                imgShowsetImageBitmap(bm);            } catch (IOException e) {

eprintStackTrace();            }

}

}

}

layout:activity_mainxml:

<xml version="10" encoding="utf-8"><LinearLayout xmlns:android=">

以上就是关于Android分辨率,dpi 、dp、px,App查询图片顺序全部的内容,包括:Android分辨率,dpi 、dp、px,App查询图片顺序、Android中dip,dp,sp,pt和px的区别详解、android 如何获取进度条的位置等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9279993.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-26
下一篇 2023-04-26

发表评论

登录后才能评论

评论列表(0条)

保存