gpt4 book ai didi

android - float 操作按钮的 OnClick

转载 作者:塔克拉玛干 更新时间:2023-11-02 08:16:44 27 4
gpt4 key购买 nike

我刚开始使用 float 操作按钮,并试图让一些基本功能在今天发挥作用。目前我坚持让​​ onClick 功能正常工作。我从谷歌的 FAB 基本示例中提取了大部分代码,其中有一个 onChecked 方法,该方法将一个字符串发送到记录器以显示您已单击它。

@Override
public void onCheckedChanged(FloatingActionButton fabView, boolean isChecked) {
// When a FAB is toggled, log the action.

switch (fabView.getId()){
case R.id.fab_1:
break;
default:
break;
}
}

我原以为我可以替换其中的功能,但那没有影响。因此,我尝试像创建任何其他按钮一样创建 onClickListener,但这也没有任何影响。我不确定如何继续,因为这两个选项都不起作用。我的目标只是在单击 float 操作按钮时生成一个对话框,但现在我只是尝试使用占位符警报对话框。

这是 FloatingActionButtonFragment 类:

public class FloatingActionButtonFragment extends Fragment implements FloatingActionButton.OnCheckedChangeListener {


@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
View rootView = inflater.inflate(R.layout.fab_layout, container, false);

// Make this {@link Fragment} listen for changes in both FABs.
FloatingActionButton fab1 = (FloatingActionButton) rootView.findViewById(R.id.fab_1);
fab1.setOnCheckedChangeListener(this);

fab1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {

AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());
builder.setMessage("Are you sure?")
.setPositiveButton("Yes", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int id) {
}
})
.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int id) {
// User cancelled the dialog
}
});
// Create the AlertDialog object and return it
AlertDialog dialog = builder.create();
dialog.show();
}
});
return rootView;
}

@Override
public void onCheckedChanged(FloatingActionButton fabView, boolean isChecked) {
// When a FAB is toggled, log the action.

switch (fabView.getId()){
case R.id.fab_1:
break;
default:
break;
}
}

}

这是 FloatingActionButton 类:

public class FloatingActionButton extends FrameLayout implements Checkable {

/**
* Interface definition for a callback to be invoked when the checked state
* of a compound button changes.
*/
public static interface OnCheckedChangeListener {

/**
* Called when the checked state of a FAB has changed.
*
* @param fabView The FAB view whose state has changed.
* @param isChecked The new checked state of buttonView.
*/
void onCheckedChanged(FloatingActionButton fabView, boolean isChecked);
}

/**
* An array of states.
*/
private static final int[] CHECKED_STATE_SET = {
android.R.attr.state_checked
};

private static final String TAG = "FloatingActionButton";

// A boolean that tells if the FAB is checked or not.
private boolean mChecked;

// A listener to communicate that the FAB has changed it's state
private OnCheckedChangeListener mOnCheckedChangeListener;

public FloatingActionButton(Context context) {
this(context, null, 0, 0);
}

public FloatingActionButton(Context context, AttributeSet attrs) {
this(context, attrs, 0, 0);
}

public FloatingActionButton(Context context, AttributeSet attrs, int defStyleAttr) {
this(context, attrs, defStyleAttr, 0);
}

public FloatingActionButton(Context context, AttributeSet attrs, int defStyleAttr,
int defStyleRes) {
super(context, attrs, defStyleAttr);

setClickable(true);

// Set the outline provider for this view. The provider is given the outline which it can
// then modify as needed. In this case we set the outline to be an oval fitting the height
// and width.
setOutlineProvider(new ViewOutlineProvider() {
@Override
public void getOutline(View view, Outline outline) {
outline.setOval(0, 0, getWidth(), getHeight());
}
});

// Finally, enable clipping to the outline, using the provider we set above
setClipToOutline(true);
}

/**
* Sets the checked/unchecked state of the FAB.
* @param checked
*/
public void setChecked(boolean checked) {
// If trying to set the current state, ignore.
if (checked == mChecked) {
return;
}
mChecked = checked;

// Now refresh the drawable state (so the icon changes)
refreshDrawableState();

if (mOnCheckedChangeListener != null) {
mOnCheckedChangeListener.onCheckedChanged(this, checked);
}
}

/**
* Register a callback to be invoked when the checked state of this button
* changes.
*
* @param listener the callback to call on checked state change
*/
public void setOnCheckedChangeListener(OnCheckedChangeListener listener) {
mOnCheckedChangeListener = listener;
}

@Override
public boolean isChecked() {
return mChecked;
}

@Override
public void toggle() {
setChecked(!mChecked);
}

/**
* Override performClick() so that we can toggle the checked state when the view is clicked
*/
@Override
public boolean performClick() {
toggle();
return super.performClick();
}

@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
super.onSizeChanged(w, h, oldw, oldh);

// As we have changed size, we should invalidate the outline so that is the the
// correct size
invalidateOutline();
}

@Override
protected int[] onCreateDrawableState(int extraSpace) {
final int[] drawableState = super.onCreateDrawableState(extraSpace + 1);
if (isChecked()) {
mergeDrawableStates(drawableState, CHECKED_STATE_SET);
}
return drawableState;
}
}

此时这两个类都没有太多内容,它们大多是外壳,但我只想在继续之前先了解这个基本功能,作为菜鸟,我不知道为什么会这样'不工作。

最佳答案

如果您还没有 catch 截止日期,您必须将 float 操作按钮更改为谷歌在设计库中提供的按钮关注http://android-developers.blogspot.in/2015/05/android-design-support-library.html即可

添加到 XML 布局:

<android.support.design.widget.FloatingActionButton
android:id="@+id/myFAB"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/your_icon"
app:elevation="4dp"
... />

添加到代码后面:

FloatingActionButton myFab = (FloatingActionButton) myView.findViewById(R.id.myFAB); 
myFab.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
doMyThing();
}
});

更多详情请关注:FloatingActionButton example with Support Library

关于android - float 操作按钮的 OnClick,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30876515/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com