Android设置进度条拉伸,如何将background.png设置为进度条的背景,并进行拉伸,并将其填充到最大?...

由于一个主题,你是试图把你自己的形象在ProgressBar那么你应该创建自定义ProgressBar这将帮助你设置自己的图像作为背景和进度图像。

在这里,我给你一个方法如何做自定义ProgressBar。创建一个XML处理background.png作为proress酒吧的背景和progress.png与层列表proress酒吧的进度指示器属性...命名XML作为progressbar.xml

android:id="@android:id/background"

android:drawable="@drawable/background"/>

android:id="@+id/progress"

android:drawable="@drawable/progress">

创建自定义ProgressBar命名为CustomProgressBar其中扩展ProgressBar。 CustomProgressBar.java

public class CustomProgressBar extends ProgressBar {

public CustomProgressBar(Context context) {

super(context);

}

public CustomProgressBar(Context context, AttributeSet attrs) {

super(context, attrs);

}

public CustomProgressBar(Context context, AttributeSet attrs, int defStyle) {

super(context, attrs, defStyle);

}

@Override

protected synchronized void onDraw(Canvas canvas) {

// update the size of the progress bar and overlay

updateProgressBar();

// paint the changes to the canvas

super.onDraw(canvas);

}

@Override

public synchronized void setProgress(int progress) {

super.setProgress(progress);

// the setProgress super will not change the details of the progress bar

// anymore so we need to force an update to redraw the progress bar

invalidate();

}

private float getScale(int progress) {

float scale = getMax() > 0 ? (float) progress/(float) getMax() : 0;

return scale;

}

private void updateProgressBar() {

Drawable progressDrawable = getProgressDrawable();

if (progressDrawable != null && progressDrawable instanceof LayerDrawable) {

LayerDrawable d = (LayerDrawable) progressDrawable;

final float scale = getScale(getProgress());

// get the progress bar and update it's size

Drawable progressBar = d.findDrawableByLayerId(R.id.progress);

final int width = d.getBounds().right - d.getBounds().left;

if (progressBar != null) {

Rect progressBarBounds = progressBar.getBounds();

progressBarBounds.right = progressBarBounds.left + (int) (width * scale + 0.5f);

progressBar.setBounds(progressBarBounds);

}

}

}

}

在styles.xml创建自定义进度条样式属性...

true

repeat

3500

48dip

48dip

48dip

48dip

false

@drawable/progressbar

@android:drawable/progress_indeterminate_horizontal

1dip

10dip

添加自定义CustomProgressBar到您的XML。假设,你把CustomProgressBar.java文件中com.widgets.custom包......那么XML进度条会...

android:id="@+id/regularprogressbar"

style="@style/Widget.ProgressBar.RegularProgressBar"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:layout_marginTop="50dip" />

在你的Activity类初始化定义进度栏和根据需要使用。但是我给演示活动类更好地了解...

public class ProgressBarActivity extends Activity {

private SaundProgressBar mRegularProgressBar;

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

mRegularProgressBar = (SaundProgressBar) findViewById(R.id.regularprogressbar);

new UpdateBarTask().execute();

}

private class UpdateBarTask extends AsyncTask {

@Override

protected Void doInBackground(Void... params) {

int max = mRegularProgressBar.getMax();

for (int i = 0; i <= max; i++) {

try {

// update every second

Thread.sleep(100);

} catch (InterruptedException e) {

}

publishProgress(i);

}

return null;

}

@Override

protected void onProgressUpdate(Integer... values) {

mRegularProgressBar.setProgress(values[0]);

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,关于您的问题,使用Flask-Sockets可以建立WebSocket连接以便在后台与浏览器进行实时通信。您可以编写一个Flask-Sockets的视图函数,以响应前端发送的WebSocket请求。在视图函数中,您可以使用TensorFlow或PyTorch等深度学习框架进行模型训练并且将训练进度发送到前端进行展示。以下是实现的一般流程: 1. 创建一个Flask-Sockets应用,并在WSGI服务器中运行它。 2. 在前端,您需要使用JavaScript编写代码建立WebSocket连接,以便将进度条的更新推送到您的服务器。 3. 在服务器的Flask-Sockets视图函数中,您可以启动后台任务来训练模型,这个任务可以是多线程的。 4. 在模型训练的函数中,定期检查模型的训练进度并将进度信息发送到前端,以便更新进度条。 下面是示例代码,用于建立Flask-Sockets应用并在后台执行模型训练任务: ```python from flask import Flask, render_template from flask_sockets import Sockets import threading app = Flask(__name__) sockets = Sockets(app) # 定义一个后台线程,训练模型并将训练进度发送到前端 def model_train(): # TensorFlow或PyTorch等框架训练代码 for i in range(1000): progress = i / 1000.0 # 将进度条信息发送到前端 sockets.send("progress %.2f" % progress) # 停止1秒,模拟训练过程 time.sleep(1) # Flask-Sockets视图函数,建立WebSocket连接 @sockets.route('/echo') def echo_socket(ws): while not ws.closed: # 接收前端发送的消息 message = ws.receive() if message is not None: if message == 'train': # 创建一个后台线程来训练模型 train_thread = threading.Thread(target=model_train) train_thread.start() # Flask应用的路由 @app.route('/') def index(): return render_template('index.html') if __name__ == '__main__': from gevent import pywsgi from geventwebsocket.handler import WebSocketHandler server = pywsgi.WSGIServer(('localhost', 5000), app, handler_class=WebSocketHandler) server.serve_forever() ``` 在前端,您需要使用JavaScript建立WebSocket连接,并更新进度条: ```html <!DOCTYPE html> <html> <head> <title>WebSocket Example</title> <script type="text/javascript"> var ws = new WebSocket("ws://" + document.location.host + "/echo"); ws.onmessage = function(evt) { if (evt.data.indexOf("progress") === 0) { // 找到名为 progress 的进度条元素 var progressBar = document.getElementById("progress"); // 更新进度条 progressBar.value = parseFloat(evt.data.substring(9)); } }; function train() { // 向WebSocket发送训练命令 ws.send("train"); } </script> </head> <body> <h1>Websocket Example</h1> <input type="button" value="Train Model" onclick="train()"> <progress id="progress" max="1" value="0"></progress> </body> </html> ``` 当用户点击训练按钮时,前端将向WebSocket发送一个'train'的消息,服务器将在后台启动模型训练任务并定期将训练进度发送回前端。前端接收到进度信息后,将更新进度条的值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值