毕加索在肖像和风景模式下加载不同的图像



我有一个片段,它使用Picasso下载图像并将其显示在ImageView中。问题是图像处于纵向模式,如果手机切换到横向模式,则相同的图像会被拉伸。我寻找解决方案,但从一般意义上讲,我得到的是简单地将旋转到90度。但那不是我想要的。我想加载两个不同的图像,即一个图像url将用于人像模式,另一个将用于风景模式。我试着检测方向的变化,然后相应地加载图像。这没用。在横向模式下,肖像图像也在加载。有什么建议吗?

public class FragmentOne extends Fragment{
    Button next, previous;
    ProportionalImageView imageView;

    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        return inflater.inflate(R.layout.fragmentone, container, false);
    }
    @Override
    public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
        super.onViewCreated(view, savedInstanceState);
        next = (Button)view.findViewById(R.id.next);
        previous = (Button)view.findViewById(R.id.previous);
        imageView = (ProportionalImageView)view.findViewById(R.id.image);
        Picasso.with(getActivity())
                .load("http://i.imgur.com/h5iwVmh.jpg")
                .placeholder(R.drawable.placeholder)
                .into(imageView);

        next.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                ((ViewPager) ((MainActivity)getActivity()).findViewById(R.id.pager)).setCurrentItem(1);
            }
        });
        previous.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                ((ViewPager) ((MainActivity)getActivity()).findViewById(R.id.pager)).setCurrentItem(-1);
            }
        });
    }
    @Override
    public void onConfigurationChanged(Configuration newConfig) {
        super.onConfigurationChanged(newConfig);
        // Checks the orientation of the screen
        if (newConfig.orientation == Configuration.ORIENTATION_LANDSCAPE) {
            Picasso.with(getActivity())
                    .load("http://i.imgur.com/H0IXUy0.jpg")
                    .placeholder(R.drawable.placeholder)
                    .into(imageView);
        } else if (newConfig.orientation == Configuration.ORIENTATION_PORTRAIT){
            Picasso.with(getActivity())
                    .load("http://i.imgur.com/h5iwVmh.jpg")
                    .placeholder(R.drawable.placeholder)
                    .into(imageView);

        }
    }




}

您可以使用此代码来获取方向

Display display = ((WindowManager)    context.getSystemService(Context.WINDOW_SERVICE)).getDefaultDisplay();
int rotation = display.getRotation();

并根据旋转条件加载图像。exm:-if(旋转==你的条件){}

您也可以使用以下代码:

public void onConfigurationChanged(Configuration newConfig) {
    super.onConfigurationChanged(newConfig);
    // refresh the instructions image
    ImageView instructions = (ImageView) findViewById(R.id.img_instructions);
   if (newConfig.orientation == Configuration.ORIENTATION_LANDSCAPE) {
        //load image in picasso here
    } else {
        //load image in picasso here
    }
}

问题是当您旋转设备时,会再次调用onViewCreated(但它在调用onConfigurationChanged之后调用)

在您的代码中,图像已更改为横向onConfigurationChanged,但在此之后,当onViewCreated调用时,图像将更改为纵向。这就是为什么你总是有人像

因此,您应该在onViewCreated中而不是在onConfigurationChanged 中更改图像

@Override
    public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
    ...
    int currentOrientation = getResources().getConfiguration().orientation;
    if (currentOrientation == Configuration.ORIENTATION_LANDSCAPE) {
        // load you landscape image
    }
    else {
       // load your portrait image
    }
    ...
}

希望这能帮助

最新更新