如何更改 ZoomButtonsController 中按钮触摸的颜色
How do you change the button touched colors in a ZoomButtonsController
我正在我的应用程序中实现 ZoomButtonsContainer。除了 + 和 - 按钮在按下时的颜色是一种黄赭色外,它运行良好。我想更改它以反映我的应用程序的颜色。我正在使用 Theme.AppCompat.Light.DarkActionBar.
我已经尝试覆盖我的 activity 主题中的一些样式属性,但是 none 有任何 effect.I 尝试过以下内容:
<item name="android:colorPressedHighlight">@color/plum</item>
<item name="android:colorActivatedHighlight">@color/plum</item>
有什么解决办法吗?
我已经解决了这个问题,方法是绕过它,方法更彻底,效果更好。我已经在 ZoomButtonsController 中用我自己的布局完全替换了按钮。我展示了下面的代码,以防对任何人有用。
步骤:
- 以我需要的样式创建按钮布局,但参考使用的默认布局。
- 为按钮创建背景以显示启用/按下/默认所需的颜色。
- 使用此布局创建 My_ZoomControls class,根据需要从默认 ZoomControls 获取代码。
- 创建一个 My_ZoomButtonsController 从 ZoomButtonsController 扩展但引用 My_ZoomControls。
- 通过切换默认布局并将其替换为我的自定义布局来进行初始化。
- 包括在从 window 分离时调用 setVisible(false) 的代码,并且根据 ZoomButtonsController 的文档更改可见性。
- 请注意,您需要注意控制器 "ownerView" 每个解决方案 here
zoom_contols.xml
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/popup_player_background"
android:orientation="horizontal">
<ZoomButton
android:id="@+id/zoomOut"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/zoom_controls_item_background"
android:contentDescription="@string/app_name"
android:gravity="center"
android:paddingEnd="20dp"
android:paddingLeft="10dp"
android:paddingRight="20dp"
android:paddingStart="10dp"
android:src="@drawable/minus_circled"
android:tint="@color/plum"/>
<ZoomButton
android:id="@+id/zoomIn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/zoom_controls_item_background"
android:contentDescription="@string/app_name"
android:paddingEnd="10dp"
android:paddingLeft="20dp"
android:paddingRight="10dp"
android:paddingStart="20dp"
android:src="@drawable/plus_circled"
android:tint="@color/plum"/>
</LinearLayout>
zoom_contols_item_background
<?xml version="1.0" encoding="utf-8"?>
<item android:state_enabled="false">
<shape
android:shape="rectangle">
<stroke android:width="1dp" android:color="@color/plum"/>
<solid android:color="@color/gray"/>
<padding android:bottom="2dp"
android:left="2dp"
android:right="2dp"
android:top="2dp"/>
<corners android:radius="5dp"/>
</shape>
</item>
<item android:state_pressed="true">
<shape
android:shape="rectangle">
<stroke android:width="1dp" android:color="@color/plum"/>
<solid android:color="@color/plum_light"/>
<padding android:bottom="2dp"
android:left="2dp"
android:right="2dp"
android:top="2dp"/>
<corners android:radius="5dp"/>
</shape>
</item>
<item>
<shape
android:shape="rectangle">
<stroke android:width="1dp" android:color="@color/transparent"/>
<solid android:color="@color/transparent"/>
<padding android:bottom="2dp"
android:left="2dp"
android:right="2dp"
android:top="2dp"/>
<corners android:radius="5dp"/>
</shape>
</item>
My_ZoomControls
public class My_ZoomControls extends LinearLayout {
private final ZoomButton mZoomInButton;
private final ZoomButton mZoomOutButton;
public My_ZoomControls(Context context) {
super(context);
setFocusable(false);
LayoutInflater inflater = (LayoutInflater) context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
inflater.inflate(R.layout.zoom_controls, this, true);
mZoomInButton = (ZoomButton) findViewById(R.id.zoomIn);
mZoomOutButton = (ZoomButton) findViewById(R.id.zoomOut);
}
public void setOnZoomInClickListener(OnClickListener listener) {
mZoomInButton.setOnClickListener(listener);
}
public void setOnZoomOutClickListener(OnClickListener listener) {
mZoomOutButton.setOnClickListener(listener);
}
@Override
public boolean onTouchEvent(MotionEvent event) {
return true;
}
public void setIsZoomInEnabled(boolean isEnabled) {
mZoomInButton.setEnabled(isEnabled);
}
public void setIsZoomOutEnabled(boolean isEnabled) {
mZoomOutButton.setEnabled(isEnabled);
}
}
My_ZoomButtonsController
public class My_ZoomButtonsController extends ZoomButtonsController {
private My_ZoomControls mControls;
private OnZoomListener mZoomListener;
private View.OnAttachStateChangeListener mAttachStateChangeListener;
public My_ZoomButtonsController(View ownerView) {
super(ownerView);
}
public void setZoomControls(My_ZoomControls mControls) {
this.mControls = mControls;
this.mControls.setOnZoomInClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (mZoomListener != null) mZoomListener.onZoom(true);
}
});
this.mControls.setOnZoomOutClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (mZoomListener != null) mZoomListener.onZoom(false);
}
});
this.mControls.addOnAttachStateChangeListener(new View.OnAttachStateChangeListener() {
@Override
public void onViewAttachedToWindow(View v) {
if (mAttachStateChangeListener != null) mAttachStateChangeListener.onViewAttachedToWindow(v);
}
@Override
public void onViewDetachedFromWindow(View v) {
if (mAttachStateChangeListener != null) mAttachStateChangeListener.onViewDetachedFromWindow(v);
}
});
}
public void setOnZoomListener(OnZoomListener listener) {
mZoomListener = listener;
}
public void setOnAttachStateChangeListener(View.OnAttachStateChangeListener listener) {
mAttachStateChangeListener = listener;
}
@Override
public void setZoomOutEnabled(boolean enabled) {
mControls.setIsZoomOutEnabled(enabled);
}
@Override
public void setZoomInEnabled(boolean enabled) {
mControls.setIsZoomInEnabled(enabled);
}
}
实施。 zoomInGrid 是我放置我的应用程序特定代码以进行放大的地方。
private void setZoomButtonsController() {
pZoomButtonsController = new My_ZoomButtonsController(pBtnSort);
ViewGroup container = pZoomButtonsController.getContainer();
View controls = pZoomButtonsController.getZoomControls();
ViewGroup.LayoutParams params = controls.getLayoutParams();
container.removeView(controls);
My_ZoomControls layout = new My_ZoomControls(My_Application_Base.getInstance().getApplicationContext());
container.addView(layout, params);
pZoomButtonsController.setZoomControls(layout);
pZoomButtonsController.setOnZoomListener(new ZoomButtonsController.OnZoomListener() {
@Override
public void onZoom(boolean zoomIn) {
zoomInGrid(zoomIn);
}
@Override
public void onVisibilityChanged(boolean visible) {
if ((!visible) && (pZoomButtonsController != null)) {
pZoomButtonsController.setVisible(false);
}
}
});
pZoomButtonsController.setOnAttachStateChangeListener(new View.OnAttachStateChangeListener() {
@Override
public void onViewAttachedToWindow(View v) {
}
@Override
public void onViewDetachedFromWindow(View v) {
if (pZoomButtonsController != null) {
pZoomButtonsController.setVisible(false);
}
}
});
}
我正在我的应用程序中实现 ZoomButtonsContainer。除了 + 和 - 按钮在按下时的颜色是一种黄赭色外,它运行良好。我想更改它以反映我的应用程序的颜色。我正在使用 Theme.AppCompat.Light.DarkActionBar.
我已经尝试覆盖我的 activity 主题中的一些样式属性,但是 none 有任何 effect.I 尝试过以下内容:
<item name="android:colorPressedHighlight">@color/plum</item>
<item name="android:colorActivatedHighlight">@color/plum</item>
有什么解决办法吗?
我已经解决了这个问题,方法是绕过它,方法更彻底,效果更好。我已经在 ZoomButtonsController 中用我自己的布局完全替换了按钮。我展示了下面的代码,以防对任何人有用。
步骤:
- 以我需要的样式创建按钮布局,但参考使用的默认布局。
- 为按钮创建背景以显示启用/按下/默认所需的颜色。
- 使用此布局创建 My_ZoomControls class,根据需要从默认 ZoomControls 获取代码。
- 创建一个 My_ZoomButtonsController 从 ZoomButtonsController 扩展但引用 My_ZoomControls。
- 通过切换默认布局并将其替换为我的自定义布局来进行初始化。
- 包括在从 window 分离时调用 setVisible(false) 的代码,并且根据 ZoomButtonsController 的文档更改可见性。
- 请注意,您需要注意控制器 "ownerView" 每个解决方案 here
zoom_contols.xml
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/popup_player_background"
android:orientation="horizontal">
<ZoomButton
android:id="@+id/zoomOut"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/zoom_controls_item_background"
android:contentDescription="@string/app_name"
android:gravity="center"
android:paddingEnd="20dp"
android:paddingLeft="10dp"
android:paddingRight="20dp"
android:paddingStart="10dp"
android:src="@drawable/minus_circled"
android:tint="@color/plum"/>
<ZoomButton
android:id="@+id/zoomIn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/zoom_controls_item_background"
android:contentDescription="@string/app_name"
android:paddingEnd="10dp"
android:paddingLeft="20dp"
android:paddingRight="10dp"
android:paddingStart="20dp"
android:src="@drawable/plus_circled"
android:tint="@color/plum"/>
</LinearLayout>
zoom_contols_item_background
<?xml version="1.0" encoding="utf-8"?>
<item android:state_enabled="false">
<shape
android:shape="rectangle">
<stroke android:width="1dp" android:color="@color/plum"/>
<solid android:color="@color/gray"/>
<padding android:bottom="2dp"
android:left="2dp"
android:right="2dp"
android:top="2dp"/>
<corners android:radius="5dp"/>
</shape>
</item>
<item android:state_pressed="true">
<shape
android:shape="rectangle">
<stroke android:width="1dp" android:color="@color/plum"/>
<solid android:color="@color/plum_light"/>
<padding android:bottom="2dp"
android:left="2dp"
android:right="2dp"
android:top="2dp"/>
<corners android:radius="5dp"/>
</shape>
</item>
<item>
<shape
android:shape="rectangle">
<stroke android:width="1dp" android:color="@color/transparent"/>
<solid android:color="@color/transparent"/>
<padding android:bottom="2dp"
android:left="2dp"
android:right="2dp"
android:top="2dp"/>
<corners android:radius="5dp"/>
</shape>
</item>
My_ZoomControls
public class My_ZoomControls extends LinearLayout {
private final ZoomButton mZoomInButton;
private final ZoomButton mZoomOutButton;
public My_ZoomControls(Context context) {
super(context);
setFocusable(false);
LayoutInflater inflater = (LayoutInflater) context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
inflater.inflate(R.layout.zoom_controls, this, true);
mZoomInButton = (ZoomButton) findViewById(R.id.zoomIn);
mZoomOutButton = (ZoomButton) findViewById(R.id.zoomOut);
}
public void setOnZoomInClickListener(OnClickListener listener) {
mZoomInButton.setOnClickListener(listener);
}
public void setOnZoomOutClickListener(OnClickListener listener) {
mZoomOutButton.setOnClickListener(listener);
}
@Override
public boolean onTouchEvent(MotionEvent event) {
return true;
}
public void setIsZoomInEnabled(boolean isEnabled) {
mZoomInButton.setEnabled(isEnabled);
}
public void setIsZoomOutEnabled(boolean isEnabled) {
mZoomOutButton.setEnabled(isEnabled);
}
}
My_ZoomButtonsController
public class My_ZoomButtonsController extends ZoomButtonsController {
private My_ZoomControls mControls;
private OnZoomListener mZoomListener;
private View.OnAttachStateChangeListener mAttachStateChangeListener;
public My_ZoomButtonsController(View ownerView) {
super(ownerView);
}
public void setZoomControls(My_ZoomControls mControls) {
this.mControls = mControls;
this.mControls.setOnZoomInClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (mZoomListener != null) mZoomListener.onZoom(true);
}
});
this.mControls.setOnZoomOutClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (mZoomListener != null) mZoomListener.onZoom(false);
}
});
this.mControls.addOnAttachStateChangeListener(new View.OnAttachStateChangeListener() {
@Override
public void onViewAttachedToWindow(View v) {
if (mAttachStateChangeListener != null) mAttachStateChangeListener.onViewAttachedToWindow(v);
}
@Override
public void onViewDetachedFromWindow(View v) {
if (mAttachStateChangeListener != null) mAttachStateChangeListener.onViewDetachedFromWindow(v);
}
});
}
public void setOnZoomListener(OnZoomListener listener) {
mZoomListener = listener;
}
public void setOnAttachStateChangeListener(View.OnAttachStateChangeListener listener) {
mAttachStateChangeListener = listener;
}
@Override
public void setZoomOutEnabled(boolean enabled) {
mControls.setIsZoomOutEnabled(enabled);
}
@Override
public void setZoomInEnabled(boolean enabled) {
mControls.setIsZoomInEnabled(enabled);
}
}
实施。 zoomInGrid 是我放置我的应用程序特定代码以进行放大的地方。
private void setZoomButtonsController() {
pZoomButtonsController = new My_ZoomButtonsController(pBtnSort);
ViewGroup container = pZoomButtonsController.getContainer();
View controls = pZoomButtonsController.getZoomControls();
ViewGroup.LayoutParams params = controls.getLayoutParams();
container.removeView(controls);
My_ZoomControls layout = new My_ZoomControls(My_Application_Base.getInstance().getApplicationContext());
container.addView(layout, params);
pZoomButtonsController.setZoomControls(layout);
pZoomButtonsController.setOnZoomListener(new ZoomButtonsController.OnZoomListener() {
@Override
public void onZoom(boolean zoomIn) {
zoomInGrid(zoomIn);
}
@Override
public void onVisibilityChanged(boolean visible) {
if ((!visible) && (pZoomButtonsController != null)) {
pZoomButtonsController.setVisible(false);
}
}
});
pZoomButtonsController.setOnAttachStateChangeListener(new View.OnAttachStateChangeListener() {
@Override
public void onViewAttachedToWindow(View v) {
}
@Override
public void onViewDetachedFromWindow(View v) {
if (pZoomButtonsController != null) {
pZoomButtonsController.setVisible(false);
}
}
});
}