在对话框内悬停时更改视图的背景

Posted

技术标签:

【中文标题】在对话框内悬停时更改视图的背景【英文标题】:change background of views on hover inside dialog 【发布时间】:2014-11-17 18:57:51 【问题描述】:

我正在尝试构建共享对话框。 在这个分享对话框中,我有 facebook、whatsapp、mail 等等。

我正在尝试使每个视图的背景在触摸时发生变化以指示触摸。 到目前为止没有问题。 问题是我还想让用户将手指移动到其他选项中,当他这样做时,以前的背景会恢复到原来的颜色并且新的视图背景会发生变化。

我根本无法获得悬停事件,只要第一个onTouchEvent还活着,我就无法触发其他onTouchEvent。

这是我目前的代码:

public class customDialogFragment1 extends DialogFragment 


public customDialogFragment1() 


@Override
public Dialog onCreateDialog(Bundle savedInstanceState) 

    postShareUrl=getActivity().getResources().getString(R.string.servicePostShareUrl);
    id=getArguments().getString("body");
    postTitle=getArguments().getString("subject");
    Intent sendIntent = new Intent(android.content.Intent.ACTION_SEND);
    sendIntent.setType("text/plain");

    Dialog dialog = new Dialog(getActivity(),android.R.style.Theme_Translucent_NoTitleBar);

    AlertDialog.Builder builder = new AlertDialog.Builder(getActivity(),android.R.style.Theme_Translucent_NoTitleBar);
    LayoutInflater inflater = (LayoutInflater) getActivity()
            .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    View v = inflater.inflate(R.layout.share_title_layout, null);
    // Set title divider color


    TextView txtTitle= (TextView) v.findViewById(R.id.share_title);
    Typeface tf = Typeface.createFromAsset(getActivity().getResources().getAssets(),
            "fonts/OpenSansHebrew-Bold.ttf");

    txtTitle.setTypeface(tf);
    View layout=inflater.inflate(R.layout.custom_share_layout_inner,null);
    builder.setView(layout);

    ImageView facebook= (ImageView) layout.findViewById(R.id.imgFaceebook);
    ImageView whatsapp= (ImageView) layout.findViewById(R.id.imgWhatsapp);
    ImageView more= (ImageView) layout.findViewById(R.id.imgMore);
    ImageView mail= (ImageView) layout.findViewById(R.id.imgMail);

    facebook.setOnClickListener(imageClickListener);
    whatsapp.setOnClickListener(imageClickListener);
    more.setOnClickListener(imageClickListener);
    mail.setOnClickListener(imageClickListener);

    List activities = getActivity().getPackageManager().queryIntentActivities(sendIntent, 0);
    Context context=(Activity)getActivity();
    for(int i=0;i<activities.size();i++) 
        ResolveInfo appPacageName = (ResolveInfo) activities.get(i);
        Log.i("pacageName", appPacageName.toString());
        if (appPacageName.toString().contains("com.facebook.composer")) 
            shareCheckList[0] = appPacageName;
         else if (appPacageName.toString().contains("whatsapp")) 
            shareCheckList[1] = appPacageName;
         else if (appPacageName.toString().contains("mail")) 
            shareCheckList[2] = appPacageName;
        
    
    dialog.setContentView(layout);
    Window window = dialog.getWindow();
    window.setLayout(LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT);
    window.setGravity(Gravity.CENTER);
    window.setLayout(MainActivity.screenWidth-90,350);

    return dialog;

这是我的 ontouch 监听器:

private View.OnClickListener imageClickListener=new View.OnClickListener() 
    @Override
    public void onClick(View v) 
        Intent intent = new Intent(android.content.Intent.ACTION_SEND);
        intent.setType("text/plain");
        intent.putExtra(Intent.EXTRA_SUBJECT,getArguments().getString("subject"));
        intent.putExtra(Intent.EXTRA_TEXT,getArguments().getString("body"));

        switch (v.getId())
            case R.id.imgFaceebook:

                    if(!shareCheckList[0].toString().isEmpty())
                        intent.setClassName(shareCheckList[0].activityInfo.packageName, shareCheckList[0].activityInfo.name);                        
                        ((Activity)getActivity()).startActivity(intent);
                break;
            case R.id.imgWhatsapp:                   
                        intent.setClassName(shareCheckList[1].activityInfo.packageName, shareCheckList[1].activityInfo.name);                         
                        ((Activity)getActivity()).startActivity(intent);
                
                break;
            case R.id.imgMail:
                try                      
                        intent.setClassName(shareCheckList[2].activityInfo.packageName, shareCheckList[2].activityInfo.name);

                        ((Activity)getActivity()).startActivity(intent);


                break;
            case R.id.imgMore:
                CustomDialogFragment2 cdf=new CustomDialogFragment2();
                Bundle bundle = new Bundle();
                bundle.putString("body",id);
                bundle.putString("subject", postTitle);
                cdf.setArguments(bundle);
                cdf.show(getActivity().getFragmentManager(), "customDialogFragment2");
                break;

        

    
;

【问题讨论】:

【参考方案1】:

如果我理解正确,你应该使用状态列表:

http://developer.android.com/guide/topics/resources/drawable-resource.html#StateList

只需为每个 ImageView 创建 xml 可绘制文件,并为每个状态项设置您需要的来源。

【讨论】:

嘿,谢谢你的链接,但它只是解决方案的一部分......想象你按下屏幕上的某个地方,当你仍然按下时,将手指移动到某个视图和那个动作(开始其他地方并输入一些视图边界)触发该视图的一些操作(在我的情况下更改背景颜色)。当您的触摸在视图内时,您带来的解决方案只有效果。

以上是关于在对话框内悬停时更改视图的背景的主要内容,如果未能解决你的问题,请参考以下文章

如何更改 jQuery UI 对话框的背景颜色?

悬停时背景图像更改

更改嵌套 div 内鼠标悬停时的图层颜色

如何使用另一个表单上的打开文件对话框更改表单的背景图像

定向更改时的列表视图的自定义对话框(横向模式)

悬停时更改 div 内 H2 的字体颜色