我希望在屏幕中央有一个文本视图,其中一些自定义SeekBars位于圆圈的边缘周围。看起来应该是这样的。
这是我到目前为止的代码。为了使用更少的代码而不是自定义SeekBars,我将使用默认的SeekBars。我正在使用Vertical Seek Bar库https://github.com/AndroSelva/Vertical-SeekBar-Android
MainActivity:
public class MainActivity extends Activity implements OnSeekBarChangeListener {
TextView tv;
TextView ss;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
RelativeLayout layout = (RelativeLayout) findViewById(R.id.main_layout);
tv = (TextView)findViewById(R.id.seek_score);
ss = (TextView)findViewById(R.id.selected_segment);
RelativeLayout.LayoutParams lp = new RelativeLayout.LayoutParams(
RelativeLayout.LayoutParams.WRAP_CONTENT, RelativeLayout.LayoutParams.WRAP_CONTENT);
lp.addRule(RelativeLayout.RIGHT_OF, tv.getId());
VerticalSeekBar verticalSeekBar = (VerticalSeekBar) getLayoutInflater().inflate(R.layout.motif_segment, null);
verticalSeekBar.setName("Test Segment");
verticalSeekBar.setOnSeekBarChangeListener(this);
layout.addView(verticalSeekBar, lp);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return false;
}
@Override
public void onProgressChanged(SeekBar seekBar, int progress, boolean isUser) {
tv.setText(Integer.toString(progress / 100));
}
@Override
public void onStartTrackingTouch(SeekBar seekBar) {
}
@Override
public void onStopTrackingTouch(SeekBar seekBar) {
}
}
main_activity.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity"
android:id="@+id/main_layout"
android:layout_gravity="center"
>
<TextView
android:id="@+id/seek_score"
android:layout_width="50dip"
android:layout_height="50dip"
android:layout_centerHorizontal="true"
android:background="@drawable/circle"
android:gravity="center"
android:text="0"
android:layout_margin="40dip"
/>
<TextView
android:id="@+id/selected_segment"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:text="" />
</RelativeLayout>
答案 0 :(得分:1)
我希望在屏幕中央有一个文本视图 自定义SeekBars定位在圆圈边缘
如果编号的视图具有任意尺寸(表示它们比中心圆更大)并且您只想将它们放置在您的图像中,那么它非常简单:
如果您希望视图1,2,3,4具有圆的大小,则使用上方的位置,但也可以使用圆形视图的alignLeft / Right / top / Bottom属性。
如果这四个视图不是您要围绕圈子放置的单个视图,那么您应该创建一个自定义ViewGroup
来更准确地计算子视图的放置方式。